這篇文章主要介紹javascript+HTML5 canvas如何繪制時鐘功能,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
為順城等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及順城網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站建設(shè)、做網(wǎng)站、順城網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
效果如下:
代碼:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>www.jb51.net canvas繪制時鐘</title>
<style>
div{text-align:center;margin-top:250px;}
</style>
</head>
<body>
<div>
<canvas id="clock" width="300px" height="300px"></canvas>
</div>
<script>
var dom=document.getElementById("clock");
var ctx=dom.getContext("2d");
var width=ctx.canvas.width;
var height=ctx.canvas.height;
var r=width/2;
var rem=width/200;
function drawBackground(){
ctx.save();
ctx.translate(r,r);//重新定義圓點到中心
ctx.beginPath();
ctx.lineWidth=10*rem;
ctx.arc(0,0,r-5*rem,0,Math.PI*2,false);//圓點坐標(biāo),起始角0,結(jié)束角2π,順時針
ctx.stroke();
var hourNum=[3,4,5,6,7,8,9,10,11,12,1,2];//數(shù)組存小時數(shù)
ctx.font="18px Arial";
ctx.textAlign="center";
ctx.textBaseline="middle";
hourNum.forEach(function (num,i) {
var rad=2*Math.PI/12*i;//弧度
var x=(r-30*rem)*Math.cos(rad);
var y=(r-30*rem)*Math.sin(rad);
ctx.fillText(num,x,y);
});
for(var i=0;i<60;i++){//畫圓點
var rad=2*Math.PI/60*i;
var x=(r-18*rem)*Math.cos(rad);
var y=(r-18*rem)*Math.sin(rad);
ctx.beginPath();
if(i%5==0){
ctx.fillStyle="#000";
ctx.arc(x,y,2,0,Math.PI*2,false);
}
else{
ctx.fillStyle="#ccc";
ctx.arc(x,y,2,0,Math.PI*2,false);
}
ctx.fill();
}
ctx.closePath();
}
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*rem;
ctx.moveTo(0,10*rem);
ctx.lineTo(0,-r/2);
ctx.lineCap="round";
ctx.stroke();
ctx.restore();
}
function drawMinute(minute,second){//分針
ctx.save();
ctx.beginPath();
var rad=2*Math.PI/60*minute;
var srad=2*Math.PI/60/60*second;
ctx.rotate(rad+srad);
ctx.lineWidth=3*rem;
ctx.moveTo(0,10*rem);
ctx.lineTo(0,-r+30*rem);
ctx.lineCap="round";
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*rem,20*rem);
ctx.lineTo(2*rem,20*rem);
ctx.lineTo(1*rem,-r+18*rem);
ctx.lineTo(-1*rem,-r+18*rem);
ctx.fill();
ctx.restore();
}
function drawDot(){//畫中心圓圈
ctx.beginPath();
ctx.fillStyle="#fff";
ctx.arc(0,0,3*rem,0,2*Math.PI,false);
ctx.fill();
}
function draw(){
ctx.clearRect(0,0,width,height);
var now=new Date();
var hour=now.getHours();
var minute=now.getMinutes();
var second=now.getSeconds();
drawBackground();//背景
drawHour(hour,minute);//小時
drawMinute(minute,second);//分鐘
drawSecond(second);//秒鐘
drawDot();//中心圓點
ctx.restore();
}
setInterval(draw,1000);
</script>
</body>
</html>
其中的rem值是為了使canvas畫布大小變化時時鐘的樣式能夠保持
1、js屬于一種解釋性腳本語言;2、在絕大多數(shù)瀏覽器的支持下,js可以在多種平臺下運行,擁有著跨平臺特性;3、js屬于一種弱類型腳本語言,對使用的數(shù)據(jù)類型未做出嚴(yán)格的要求,能夠進(jìn)行類型轉(zhuǎn)換,簡單又容易上手;4、js語言安全性高,只能通過瀏覽器實現(xiàn)信息瀏覽或動態(tài)交互,從而有效地防止數(shù)據(jù)的丟失;5、基于對象的腳本語言,js不僅可以創(chuàng)建對象,也能使用現(xiàn)有的對象。
以上是“javascript+HTML5 canvas如何繪制時鐘功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章標(biāo)題:javascript+HTML5canvas如何繪制時鐘功能
轉(zhuǎn)載來于:http://www.rwnh.cn/article6/jcghig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、面包屑導(dǎo)航、網(wǎng)站內(nèi)鏈、云服務(wù)器、定制開發(fā)、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)