js Canvas绘制圆形时钟效果

发布时间 - 2026-01-10 23:07:56    点击率:

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


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 网站制作大概要多少钱一个,做一个平台网站大概多少钱?  IOS倒计时设置UIButton标题title的抖动问题  JavaScript如何实现音频处理_Web Audio API如何工作?  香港服务器如何优化才能显著提升网站加载速度?  如何在IIS中新建站点并解决端口绑定冲突?  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法  如何在Tomcat中配置并部署网站项目?  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  成都网站制作公司哪家好,四川省职工服务网是做什么用?  做企业网站制作流程,企业网站制作基本流程有哪些?  大同网页,大同瑞慈医院官网?  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  网站优化排名时,需要考虑哪些问题呢?  JS去除重复并统计数量的实现方法  Thinkphp 中 distinct 的用法解析  Laravel如何使用Gate和Policy进行授权?(权限控制)  Swift中switch语句区间和元组模式匹配  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  香港服务器部署网站为何提示未备案?  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  Swift开发中switch语句值绑定模式  如何获取PHP WAP自助建站系统源码?  在Oracle关闭情况下如何修改spfile的参数  HTML 中动态设置元素 name 属性的正确语法详解  如何在搬瓦工VPS快速搭建网站?  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  如何快速搭建高效WAP手机网站?  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  jquery插件bootstrapValidator表单验证详解  如何在Windows虚拟主机上快速搭建网站?  WEB开发之注册页面验证码倒计时代码的实现  如何快速生成凡客建站的专业级图册?  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  制作电商网页,电商供应链怎么做?  Python文本处理实践_日志清洗解析【指导】  网站制作大概多少钱一个,做一个平台网站大概多少钱?  linux top下的 minerd 木马清除方法  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  如何在Windows环境下新建FTP站点并设置权限?  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  魔方云NAT建站如何实现端口转发?