全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

js Canvas绘制圆形时钟效果

本文实例为大家分享了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 


相关文章: c# await 一个已经完成的Task会发生什么  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  外贸公司网站制作哪家好,maersk船公司官网?  中山网站制作网页,中山新生登记系统登记流程?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  黑客如何通过漏洞一步步攻陷网站服务器?  郑州企业网站制作公司,郑州招聘网站有哪些?  如何在宝塔面板创建新站点?  如何在香港免费服务器上快速搭建网站?  韩国服务器如何优化跨境访问实现高效连接?  如何通过二级域名建站提升品牌影响力?  如何通过主机屋免费建站教程十分钟搭建网站?  如何在橙子建站上传落地页?操作指南详解  建站之星与建站宝盒如何选择最佳方案?  如何在云虚拟主机上快速搭建个人网站?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  建站VPS选购需注意哪些关键参数?  如何用免费手机建站系统零基础打造专业网站?  Swift中switch语句区间和元组模式匹配  长沙做网站要多少钱,长沙国安网络怎么样?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  制作网站的公司有哪些,做一个公司网站要多少钱?  如何在云主机快速搭建网站站点?  如何用狗爹虚拟主机快速搭建网站?  如何制作网站标识牌,动态网站如何制作(教程)?  建站之星下载版如何获取与安装?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  图册素材网站设计制作软件,图册的导出方式有几种?  网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  如何在万网ECS上快速搭建专属网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  如何通过山东自助建站平台快速注册域名?  建站之星Pro快速搭建教程:模板选择与功能配置指南  建站与域名管理如何高效结合?  创业网站制作流程,创业网站可靠吗?  建站之星导航配置指南:自助建站与SEO优化全解析  建站之星安装步骤有哪些常见问题?  宝塔新建站点报错如何解决?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  Python lxml的etree和ElementTree有什么区别  网站设计制作企业有哪些,抖音官网主页怎么设置?  ,制作一个手机app网站要多少钱?  建站VPS能否同时实现高效与安全翻墙?  c# 在ASP.NET Core中管理和取消后台任务  如何快速辨别茅台真假?关键步骤解析  如何通过VPS建站实现广告与增值服务盈利? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。