canvas仿iwatch时钟效果

 更新时间:2017年03月06日 16:31:03   作者:shangpudxd  
本文主要介绍了canvas仿iwatch时钟效果的实例,具有很好的参考价值。下面跟着小编一起来看下吧

效果图:

图(1)

图(2)

代码如下:

<!doctype html>
<html>
<head>
 <meta charset="UTF-8">
 <title>Title</title>
<style>
*{margin:0; padding:0;}
body{ background:#000; text-align:center;}
canvas{ background:#fff;}
</style>
<script>
function toDou(iNum){
 return iNum<10?'0'+iNum:''+iNum;
}
function d2a(n){
 return n*Math.PI/180;
}
window.onload = function(){
 var oC = document.getElementById('c1');
 var gd = oC.getContext('2d');
 var cx = oC.width/2,
 cy = oC.height/2;
 function clock(){
 gd.clearRect(0,0,oC.width,oC.height);
 var oDate = new Date();
 var H = oDate.getHours()%12;
 var M = oDate.getMinutes();
 var S = oDate.getSeconds();
 var MS = oDate.getMilliseconds();
 drawArc(60,0,(H*30+M/60*30),'orange');
 drawArc(80,0,(M*6+S/60*6),'purple');
 drawArc(100,0,(S*6+MS/1000*6),'aqua');
 var str = toDou(H)+':'+toDou(M)+':'+toDou(S);
 gd.font = '20px 微软雅黑';
 gd.textAlign = 'center';
 gd.textBaseline = 'middle';
 gd.fillText(str,cx,cy);
 }
 clock()
 setInterval(clock,1);
 function drawArc(r,s,e,color){
 color = color||'black';
 gd.beginPath();
 gd.arc(cx,cy,r,d2a(s-90),d2a(e-90),false);
 gd.strokeStyle = color;
 gd.lineWidth = 20;
 gd.stroke();
 }
};
</script>
</head>
<body>
 <canvas id="c1" width="800" height="600"></canvas>
</body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

相关文章

  • 页面加载完毕后滚动条自动滚动一定位置

    页面加载完毕后滚动条自动滚动一定位置

    希望页面加载完毕后向左自动滚动一定位置,下面有个不错的方法可以轻松帮大家实现下
    2014-02-02
  • JavaScript实现的伸展收缩型菜单代码

    JavaScript实现的伸展收缩型菜单代码

    这篇文章主要介绍了JavaScript实现的伸展收缩型菜单代码,可实现JavaScript响应鼠标事件动态遍历及修改页面元素属性的功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • 详解CocosCreator MVC架构

    详解CocosCreator MVC架构

    这篇文章主要介绍了CocosCreator MVC架构,同学们在制作游戏过程中,尽量使用一些架构,会避免很多问题
    2021-04-04
  • javascript文本模板用法实例

    javascript文本模板用法实例

    这篇文章主要介绍了javascript文本模板用法,实例分析了文本模板的相关实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • javascript中负数算术右移、逻辑右移的奥秘探索

    javascript中负数算术右移、逻辑右移的奥秘探索

    javascript中负数的算术右移和逻辑右移都十分的让人迷惑,特别是逻辑右移,接下来的文章中将为大家详细介绍下为什么右移之后,一个很小的负数也会得到一个无比巨大的数
    2013-10-10
  • JavaScript自动内存管理与垃圾回收策略详细分析讲解

    JavaScript自动内存管理与垃圾回收策略详细分析讲解

    JS的垃圾回收机制是为了以防内存泄漏,内存泄漏的含义就是当已经不需要某块内存时这块内存还存在着,垃圾回收机制就是间歇的不定期的寻找到不再使用的变量,并释放掉它们所指向的内存。因为内存的大小是有限的,所以当内存不再需要的时候,我们需要对其进行释放
    2023-01-01
  • EditPlus中的正则表达式 实战(4)

    EditPlus中的正则表达式 实战(4)

    这篇文章主要介绍了 EditPlus中的正则表达式 实战(4)的相关资料,需要的朋友可以参考下
    2016-12-12
  • 聊聊鉴权那些事(推荐)

    聊聊鉴权那些事(推荐)

    这篇文章主要介绍了聊聊鉴权那些事(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 微信小程序实现文字无限轮播效果

    微信小程序实现文字无限轮播效果

    这篇文章主要为大家详细介绍了微信小程序实现文字无限轮播效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • 利用javascript实现全部删或清空所选的操作

    利用javascript实现全部删或清空所选的操作

    这篇文章主要介绍了利用javascript实现全部删或清空所选的操作,需要的朋友可以参考下
    2014-05-05

最新评论