JavaScript Canvas绘制圆形时钟效果


Posted in Javascript onAugust 20, 2020

本文实例为大家分享了Canvas时钟效果展示的具体代码,供大家参考,具体内容如下

<html lang="en"> 
<head> 
 <meta charset="UTF-8"> 
 <title></title> 
 <style> 
 canvas{ 
  display: block; 
  margin: 0 auto; 
  background-color: #fdffad; 
  border: 1px solid #000; 
 } 
 </style> 
 <script type="text/javascript"> 
 
 document.addEventListener('DOMContentLoaded',function(){ 
  var oC=document.querySelector('canvas'); 
  var gd=oC.getContext('2d'); 
  var r=oC.width/2; 
 
  function drawBackground() { 
  gd.save(); 
  //渐变 
 
  var ra = gd.createLinearGradient(600, 0, 400, 0); 
  ra.addColorStop(1, '#2dd9ff'); 
  ra.addColorStop(0, '#8c48dd'); 
 
  //表盘 
  gd.translate(r, r); 
  gd.beginPath(); 
  gd.fillStyle = ra; 
  gd.lineWidth = 10; 
  gd.strokeStyle = '#211f4e'; 
  gd.arc(0, 0, r-5, 0, Math.PI *2, false); 
  gd.fill(); 
  gd.stroke(); 
  //数字 
  for (var i = 1; i < 13; i++) { 
   var rad=i * Math.PI * 2 / 12; 
   var x = Math.sin(rad)*(r-70); 
   var y= -Math.cos(rad)*(r-70); 
   gd.fillStyle = "red"; 
   gd.font = "bold 80px Calibri"; 
   gd.lineWidth = 1; 
   gd.textAlign = 'center'; 
   gd.textBaseline = 'middle'; 
   gd.strokeText(i, x, y); 
  } 
  //点 
  for (var i = 0; i < 60; i++) { 
   gd.beginPath(); 
   var rad=i * Math.PI * 2 / 60; 
   var x = Math.sin(rad)*(r-30); 
   var y= -Math.cos(rad)*(r-30); 
   if (i % 5 == 0) { 
   gd.fillStyle = 'red'; 
   } 
   else { 
   gd.fillStyle = '#ccc' 
   } 
   gd.lineWidth = 2; 
   gd.arc(x, y, 6, 0, Math.PI * 2, false); 
   gd.fill(); 
   gd.stroke(); 
   gd.closePath(); 
  } 
  } 
  //时针 
  function drawHour(h,m){ 
  gd.save(); 
  gd.beginPath(); 
  var rad=2*Math.PI/12*h; 
  var mrad=2*Math.PI/12/60*m; 
  gd.rotate(rad+mrad); 
  gd.lineWidth=20; 
  gd.lineCap='round'; 
  gd.moveTo(0,10); 
  gd.lineTo(0,-r/3); 
  gd.stroke(); 
  gd.closePath(); 
  gd.restore(); 
  } 
  //分针 
  function drawMinutes(m){ 
  gd.save(); 
  gd.beginPath(); 
  var rad=2*Math.PI/60*m; 
  gd.rotate(rad); 
  gd.lineWidth=10; 
  gd.lineCap='round'; 
  gd.moveTo(0,10); 
  gd.lineTo(0,-r/2); 
  gd.stroke(); 
  gd.closePath(); 
  gd.restore(); 
  } 
  //秒针 
  function drawSeconds(s){ 
  gd.save(); 
  gd.beginPath(); 
  var rad=2*Math.PI/60*s; 
  gd.rotate(rad); 
  gd.fillStyle='red'; 
  gd.moveTo(-2,20); 
  gd.lineTo(2,20); 
  gd.lineTo(1,-r+100); 
  gd.lineTo(-1,-r+100); 
  gd.fill(); 
  gd.closePath(); 
  gd.restore(); 
  } 
  //圆点 
  function drawPoint(){ 
  gd.beginPath(); 
  gd.fillStyle='#fff'; 
  gd.arc(0,0,5,Math.PI*2,false); 
  gd.fill(); 
  } 
 
  function drawClock(){ 
  gd.clearRect(0,0,oC.width,oC.height); 
  var oDate=new Date(); 
  var h=oDate.getHours(); 
  var m=oDate.getMinutes(); 
  var s=oDate.getSeconds(); 
  drawBackground(); 
  drawHour(h,m); 
  drawMinutes(m); 
  drawSeconds(s); 
  drawPoint(); 
  gd.restore(); 
 
  } 
  drawClock(); 
  setInterval(drawClock,1000); 
 },false); 
 </script> 
</head> 
<body> 
<canvas width="800" height="800"></canvas> 
</body> 
</html>

效果图:

JavaScript Canvas绘制圆形时钟效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jQuery+HttpHandler实现图片裁剪效果代码(适用于论坛, SNS)
Sep 02 Javascript
JS中不为人知的五种声明Number的方式简要概述
Feb 22 Javascript
PHP abstract与interface之间的区别
Nov 11 Javascript
Jquery动态替换div内容及动态展示的方法
Jan 23 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【二】
May 10 Javascript
JavaScript之WebSocket技术详解
Nov 18 Javascript
详解Node.js:events事件模块
Nov 24 Javascript
快速使用node.js进行web开发详解
Apr 26 Javascript
原生JS实现图片网格式渐显、渐隐效果
Jun 05 Javascript
Vue用v-for给循环标签自身属性添加属性值的方法
Oct 18 Javascript
基于Element封装一个表格组件tableList的使用方法
Jun 29 Javascript
vuex 多模块时 模块内部的mutation和action的调用方式
Jul 24 Javascript
基于JavaScript实现的插入排序算法分析
Apr 14 #Javascript
基于JavaScript实现的折半查找算法示例
Apr 14 #Javascript
AngularJS之自定义服务详解(factory、service、provider)
Apr 14 #Javascript
基于JavaScript实现的顺序查找算法示例
Apr 14 #Javascript
vue组件中点击按钮后修改输入框的状态实例代码
Apr 14 #Javascript
angularjs实现首页轮播图效果
Apr 14 #Javascript
如何使用bootstrap框架 bootstrap入门必看!
Apr 13 #Javascript
You might like
discuz7 phpMysql操作类
2009/06/21 PHP
php UTF8 文件的签名问题
2009/10/30 PHP
让PHP以ROOT权限执行系统命令的方法
2011/02/10 PHP
使用Thinkphp框架开发移动端接口
2015/08/05 PHP
ZF框架实现发送邮件的方法
2015/12/03 PHP
基于PHP后台的Android新闻浏览客户端
2016/05/23 PHP
thinkPHP5框架设置404、403等http状态页面的方法
2018/06/05 PHP
php抽象方法和普通方法的区别点总结
2019/10/13 PHP
慎用 somefunction.prototype 分析
2009/06/02 Javascript
js写一个弹出层并锁屏效果实现代码
2012/12/07 Javascript
2012年开发人员的16款新鲜的jquery插件体验分享
2012/12/28 Javascript
jquery cookie的用法总结
2013/11/18 Javascript
jquery checkbox实现单选小例
2013/11/27 Javascript
jQuery动态创建html元素的常用方法汇总
2014/09/05 Javascript
基于Phantomjs生成PDF的实现方法
2016/11/07 Javascript
js实现随机抽选效果、随机抽选红色球效果
2017/01/13 Javascript
详解如何在Vue2中实现组件props双向绑定
2017/03/29 Javascript
移动端滑动切换组件封装 vue-swiper-router实例详解
2018/11/25 Javascript
JavaScript设计模式之责任链模式实例分析
2019/01/16 Javascript
Nodejs技巧之Exceljs表格操作用法示例
2019/11/06 NodeJs
Nodejs + Websocket 指定发送及群聊的实现
2020/01/09 NodeJs
[02:16]DOTA2英雄基础教程 干扰者
2014/01/15 DOTA
[10:34]DOTA2上海特级锦标赛全纪录
2016/03/25 DOTA
[07:37]DOTA2-DPC中国联赛2月2日Recap集锦
2021/03/11 DOTA
python利用paramiko连接远程服务器执行命令的方法
2017/10/16 Python
Python从列表推导到zip()函数的5种技巧总结
2019/10/23 Python
详解Python 循环嵌套
2020/07/09 Python
Move Free官方海外旗舰店:美国骨关节健康专业品牌
2017/12/06 全球购物
美国领先的精品家居照明和装饰产品在线零售商:LightsOnline.com
2018/01/23 全球购物
CHARLES & KEITH英国官网:新加坡时尚品牌
2018/07/04 全球购物
通信工程毕业生自荐信
2013/11/01 职场文书
索桥的故事教学反思
2014/02/06 职场文书
经管应届生求职信范文
2014/05/18 职场文书
2015新员工试用期工作总结
2014/12/12 职场文书
2015年农村党员干部主题教育活动总结
2015/03/25 职场文书
员工升职自荐信
2015/03/27 职场文书