使用canvas繪制一個圓形時鐘?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
攸縣網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),攸縣網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為攸縣數(shù)千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的攸縣做網(wǎng)站的公司定做!代碼如下:
<!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width,initial-scale=1"/> <title>canvas clock</title> <style type="text/css"> div{ text-align: center; margin-top: 250px; } #clock{ border: 1px solid #ccc; } </style> </head> <body> <div> <canvas id="clock" height="200px" width="200px"></canvas> </div> <script type="text/javascript"> var dom=document.getElementById("clock"); var ctx=dom.getContext("2d"); var width=ctx.canvas.width; var heigth=ctx.canvas.height; var r=width/2; //描繪時分秒小數(shù)和小數(shù)點(diǎn) function drawBackground(){ ctx.save(); ctx.translate(r,r); //中心原點(diǎn)位置 ctx.beginPath(); //起始位置 ctx.lineWidth=10; //圓 ctx.arc(0,0,r-5,0,2*Math.PI,false); ctx.stroke(); var hourNumbers=[3,4,5,6,7,8,9,10,11,12,1,2]; ctx.font="18px Arial"; ctx.textAlign="center"; ctx.textBaseline="middle"; hourNumbers.forEach(function(number,i){ var rad=2*Math.PI/12*i; var x=Math.cos(rad)*(r-30); var y=Math.sin(rad)*(r-30); ctx.fillText(number,x,y); }); for (var i=0;i<60;i++) { var rad=2*Math.PI/60*i; var x=Math.cos(rad)*(r-18); var y=Math.sin(rad)*(r-18); ctx.beginPath(); if(i%5===0){ ctx.fillStyle="#000"; ctx.arc(x,y,2,2*Math.PI,false); }else{ ctx.fillStyle="#ccc"; ctx.arc(x,y,2,2*Math.PI,false); } ctx.fill(); } } //描繪時針 function drawHour(hour,minute){ ctx.save(); ctx.beginPath(); var rad=2*Math.PI / 12 * hour; var mrad=2*Math.PI / 12 / 60 * minute; ctx.rotate(rad + mrad); ctx.lineWidth=6; ctx.lineCap="round"; ctx.moveTo(0,10); ctx.lineTo(0,-r/2); ctx.stroke(); ctx.restore(); } //描繪分針 function drawMinute(minute){ ctx.save(); ctx.beginPath(); var rad=2*Math.PI/60*minute; ctx.rotate(rad); ctx.lineWidth=3; ctx.lineCap="round"; ctx.moveTo(0,10); ctx.lineTo(0,-r+30); ctx.stroke(); ctx.restore(); } //描繪秒針 function drawSecond(second){ ctx.save(); ctx.beginPath(); ctx.fillStyle="#C14543"; var rad=2*Math.PI/60*second; ctx.rotate(rad); ctx.moveTo(-2,20); ctx.lineTo(2,20); ctx.lineTo(1,-r+18); ctx.lineTo(-1,-r+18) ctx.fill(); ctx.restore(); } //中間固定園點(diǎn) function drawDot(){ ctx.beginPath(); ctx.fillStyle="#fff"; ctx.arc(0,0,3,0,2*Math.PI,false); ctx.fill(); } function draw(){ ctx.clearRect(0,0,width,heigth); var now=new Date(); var hour=now.getHours(); var minute=now.getMinutes(); var second=now.getSeconds(); drawBackground(); drawHour(hour,minute); drawMinute(minute); drawSecond(second); drawDot(); ctx.restore(); } draw(); setInterval(draw,1000) </script> </body> </html>
效果如下:
看完上述內(nèi)容,你們掌握使用canvas繪制一個圓形時鐘的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站bm7419.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
網(wǎng)站題目:使用canvas繪制一個圓形時鐘-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://bm7419.com/article44/dssiee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、用戶體驗、網(wǎng)站維護(hù)、電子商務(wù)、營銷型網(wǎng)站建設(shè)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容