js Canvas繪制圓形時(shí)鐘效果
本文實(shí)例為大家分享了js Canvas圓形時(shí)鐘的具體實(shí)現(xiàn)代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<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" src="js/clock.js"></script>
</body>
</html>
js
var dom=document.getElementById('clock');
var cxt=dom.getContext("2d");
var width=cxt.canvas.width;
var height=cxt.canvas.height;
var r=width/2;
function drawBackground(){
cxt.save();
cxt.translate(r,r);
cxt.beginPath();
cxt.lineWidth=10;
cxt.arc(0,0,r-5,0,2*Math.PI,false);
cxt.stroke();
cxt.font="18px Arial";
cxt.textAlign='center'
cxt.textBaseline='middle'
var hourNums=[3,4,5,6,7,8,9,10,11,12,1,2];
hourNums.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);
cxt.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);
cxt.beginPath();
if(i % 5===0){
cxt.fillStyle="#000"
cxt.arc(x,y,2,0,2*Math.PI,false);
}
else{
cxt.fillStyle="#ccc"
cxt.arc(x,y,2,0,2*Math.PI,false);
}
cxt.fill();
}
}
function drawHour(hour,minute){
cxt.save();
cxt.beginPath();
var rad=2*Math.PI/12*hour;
var mrad=2*Math.PI/12/60*minute
cxt.rotate(rad+mrad);
cxt.lineWidth=6;
cxt.lineCap='round'
cxt.moveTo(0,10);
cxt.lineTo(0,-r/2);
cxt.stroke();
cxt.restore();
}
function drawMinute(minute){
cxt.save();
cxt.beginPath();
var rad=2*Math.PI/60*minute;
cxt.rotate(rad);
cxt.lineWidth=3;
cxt.lineCap='round'
cxt.moveTo(0,10);
cxt.lineTo(0,-r+30);
cxt.stroke();
cxt.restore();
}
function drawSecond(second){
cxt.save();
cxt.beginPath();
cxt.fillStyle='#c14543'
var rad=2*Math.PI/60*second;
cxt.rotate(rad);
cxt.moveTo(-2,20);
cxt.lineTo(2,20);
cxt.lineTo(1,-r+18);
cxt.lineTo(-1,-r+18);
cxt.fill();
cxt.restore();
}
function drawDot(){
cxt.beginPath();
cxt.fillStyle='#fff'
cxt.arc(0,0,3,0,2*Math.PI,false);
cxt.fill();
}
function draw(){
cxt.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);
drawSecond(second);
drawDot();
cxt.restore();
}
draw();
setInterval(draw,1000);
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- html5 canvas js(數(shù)字時(shí)鐘)實(shí)例代碼
- JS+Canvas繪制時(shí)鐘效果
- js Canvas實(shí)現(xiàn)圓形時(shí)鐘教程
- JS+Canvas繪制動(dòng)態(tài)時(shí)鐘效果
- javascript結(jié)合Canvas 實(shí)現(xiàn)簡(jiǎn)易的圓形時(shí)鐘
- js+html5實(shí)現(xiàn)canvas繪制網(wǎng)頁(yè)時(shí)鐘的方法
- JavaScript html5 canvas繪制時(shí)鐘效果
- JavaScript學(xué)習(xí)小結(jié)之使用canvas畫“哆啦A夢(mèng)”時(shí)鐘
- JS+H5 Canvas實(shí)現(xiàn)時(shí)鐘效果
- JS+Canvas實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果
相關(guān)文章
javascript實(shí)現(xiàn)簡(jiǎn)易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)簡(jiǎn)易計(jì)算器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
Jquery Autocomplete 結(jié)合asp.net使用要點(diǎn)
Jquery的Autocomplete是一個(gè)很好的智能提示插件,但是在實(shí)際使用過(guò)程中還是會(huì)遇到一些小問(wèn)題.2010-10-10
CountUp.js數(shù)字滾動(dòng)插件使用方法詳解
這篇文章主要為大家詳細(xì)介紹了CountUp.js數(shù)字滾動(dòng)插件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
關(guān)于List.ToArray()方法的效率測(cè)試
這篇文章主要介紹了關(guān)于List.ToArray()方法的效率測(cè)試的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
javaScript 動(dòng)態(tài)訪問(wèn)JSon元素示例代碼
訪問(wèn)JSon元素的方法有很多,在搜的時(shí)候會(huì)找到很多,本文使用javascript來(lái)動(dòng)態(tài)訪問(wèn)json元素,感興趣的朋友可以練練手哦2013-08-08
在頁(yè)面中輸出當(dāng)前客戶端時(shí)間javascript實(shí)例代碼
這篇文章主要介紹了在頁(yè)面中輸出當(dāng)前客戶端時(shí)間javascript實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-03-03
一文詳解Proxy和Object.defineProperty的使用與區(qū)別
在JavaScript中,對(duì)象是一種核心的數(shù)據(jù)結(jié)構(gòu),而對(duì)對(duì)象的操作也是開發(fā)中經(jīng)常遇到的任務(wù),本文將深入比較Proxy和Object.defineProperty,感興趣的小伙伴可以了解下2023-12-12
JavaScript遍歷數(shù)組的方法代碼實(shí)例
這篇文章主要介紹了JavaScript遍歷數(shù)組的方法代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
使用Axios結(jié)合Typescript二次封裝完整詳細(xì)場(chǎng)景使用案例
本文詳細(xì)介紹了如何使用TypeScript對(duì)Axios進(jìn)行二次封裝,以提高HTTP請(qǐng)求的統(tǒng)一管理和可維護(hù)性,通過(guò)創(chuàng)建Axios實(shí)例、封裝請(qǐng)求和響應(yīng)處理、錯(cuò)誤處理以及創(chuàng)建特定的API服務(wù),可以實(shí)現(xiàn)更加一致和方便的API調(diào)用,需要的朋友可以參考下2024-11-11
關(guān)于JS與jQuery中的文檔加載問(wèn)題
本文通過(guò)實(shí)例代碼給大家講解了js和jquery中的文檔加載問(wèn)題,感興趣的的朋友一起看看吧2017-08-08

