本文实例为大家分享了js Canvas圆形时钟的具体实现代码,供大家参考,具体内容如下
<!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);
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# Canvas
# 时钟
# html5 canvas js(数字时钟)实例代码
# JS+Canvas绘制时钟效果
# js Canvas实现圆形时钟教程
# JS+Canvas绘制动态时钟效果
# javascript结合Canvas 实现简易的圆形时钟
# js+html5实现canvas绘制网页时钟的方法
# JavaScript html5 canvas绘制时钟效果
# JavaScript学习小结之使用canvas画“哆啦A梦”时钟
# JS+H5 Canvas实现时钟效果
# JS+Canvas实现动态时钟效果
# 大家分享
# 具体内容
# 大家多多
# body
# ccc
# solid
# height
# id
相关文章:
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
如何快速搭建高效WAP手机网站吸引移动用户?
高防服务器租用首荐平台,企业级优惠套餐快速部署
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何选择高效可靠的多用户建站源码资源?
Android自定义listview布局实现上拉加载下拉刷新功能
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
建站之星与建站宝盒如何选择最佳方案?
高端网站建设与定制开发一站式解决方案 中企动力
建站三合一如何选?哪家性价比更高?
5种Android数据存储方式汇总
建站主机CVM配置优化、SEO策略与性能提升指南
如何高效完成自助建站业务培训?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
C#如何序列化对象为XML XmlSerializer用法
建站之星Pro快速搭建教程:模板选择与功能配置指南
开心动漫网站制作软件下载,十分开心动画为何停播?
高防服务器如何保障网站安全无虞?
临沂网站制作公司有哪些,临沂第四中学官网?
建站之星如何助力网站排名飙升?揭秘高效技巧
建站主机服务器选型指南与性能优化方案解析
定制建站是什么?如何实现个性化需求?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
已有域名如何免费搭建网站?
营销式网站制作方案,销售哪个网站招聘效果最好?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
如何在阿里云域名上完成建站全流程?
建站之星多图banner生成与模板自定义指南
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
如何快速使用云服务器搭建个人网站?
如何通过虚拟机搭建网站?详细步骤解析
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何在VPS电脑上快速搭建网站?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何在宝塔面板创建新站点?
南京网站制作费用,南京远驱官方网站?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
音响网站制作视频教程,隆霸音响官方网站?
如何高效完成独享虚拟主机建站?
专业商城网站制作公司有哪些,pi商城官网是哪个?
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
*请认真填写需求信息,我们会在24小时内与您取得联系。