canvas仿iwatch时钟效果


Posted in Javascript onMarch 06, 2017

效果图:

canvas仿iwatch时钟效果

图(1)

canvas仿iwatch时钟效果

图(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>

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

Javascript 相关文章推荐
javascript类型转换使用方法
Feb 08 Javascript
js脚本获取webform服务器控件的方法
May 16 Javascript
jQuery判断一个元素是否可见的方法
Jun 05 Javascript
js点击文本框弹出可选择的checkbox复选框
Feb 03 Javascript
JavaScript学习笔记之数组的增、删、改、查
Mar 23 Javascript
深入理解jQuery.data() 的实现方式
Nov 30 Javascript
Angular 4 指令快速入门教程
Jun 07 Javascript
webpack 1.x升级过程中的踩坑总结大全
Aug 09 Javascript
setTimeout时间设置为0详细解析
Mar 13 Javascript
vue开发环境配置跨域的方法步骤
Jan 16 Javascript
详解微信小程序支付流程与梳理
Jul 16 Javascript
jquery实现简单每周轮换的日历
Sep 10 jQuery
jQuery滚动监听实现商城楼梯式导航效果
Mar 06 #Javascript
纯JS实现弹性导航条效果
Mar 06 #Javascript
JS实现颜色动态淡化效果
Mar 06 #Javascript
vue模板语法-插值详解
Mar 06 #Javascript
js中的面向对象入门
Mar 06 #Javascript
jQuery插件FusionCharts实现的2D面积图效果示例【附demo源码下载】
Mar 06 #Javascript
Vue 2.x教程之基础API
Mar 06 #Javascript
You might like
php mysql索引问题
2008/06/07 PHP
php自动给文章加关键词链接的函数代码
2012/11/29 PHP
使用php 获取时间今天明天昨天时间戳的详解
2013/06/20 PHP
php设置允许大文件上传示例代码
2014/03/10 PHP
Linux中用PHP判断程序运行状态的2个方法
2014/05/04 PHP
Symfony生成二维码的方法
2016/02/04 PHP
启用OPCache提高PHP程序性能的方法
2019/03/21 PHP
Thinkphp5 如何隐藏入口文件index.php(URL重写)
2019/10/16 PHP
JavaScript中判断函数是new还是()调用的区别说明
2011/04/07 Javascript
JavaScript高级程序设计 阅读笔记(四) ECMAScript中的类型转换
2012/02/27 Javascript
IE6浏览器下resize事件被执行了多次解决方法
2012/12/11 Javascript
深入了解javascript中的prototype与继承
2013/04/14 Javascript
html页面显示年月日时分秒和星期几的两种方式
2013/08/20 Javascript
js替代copy(示例代码)
2013/11/27 Javascript
vuejs动态组件给子组件传递数据的方法详解
2016/09/09 Javascript
概述VUE2.0不可忽视的很多变化
2016/09/25 Javascript
JS实现的相册图片左右滚动完整实例
2016/11/23 Javascript
JS库 Highlightjs 添加代码行号的实现代码
2017/09/13 Javascript
解决vue页面刷新或者后退参数丢失的问题
2018/03/13 Javascript
jQuery实现监听下拉框选中内容发生改变操作示例
2018/07/13 jQuery
解决Vue2.0中使用less给元素添加背景图片出现的问题
2018/09/03 Javascript
vue打开其他项目页面并传入数据详解
2020/11/25 Vue.js
Python 文件操作实现代码
2009/10/07 Python
python 2.7.13 安装配置方法图文教程
2018/09/18 Python
python写入数据到csv或xlsx文件的3种方法
2019/08/23 Python
Lentiamo荷兰:在线订购隐形眼镜、隐形眼镜液和太阳镜
2019/10/25 全球购物
党的群众路线对照检查材料思想汇报
2014/09/25 职场文书
公司员工培训管理制度
2015/08/04 职场文书
建议书的格式及范文
2015/09/14 职场文书
MySQL 覆盖索引的优点
2021/05/19 MySQL
详解JVM系列之内存模型
2021/06/10 Javascript
详解nginx进程锁的实现
2021/06/14 Servers
JS轻量级函数式编程实现XDM二
2022/06/16 Javascript
css3手动实现pc端横向滚动
2022/06/21 HTML / CSS
前端与RabbitMQ实时消息推送未读消息小红点实现示例
2022/07/23 Java/Android
SQLyog的下载、安装、破解、配置教程(MySQL可视化工具安装)
2022/09/23 MySQL