<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>canvas绘制表盘</title>
</head>
<body>
  <canvas id='box' width="500" height="500" >
    您的浏览器不支持canvas
  </canvas>
  <script>
    var box = document.getElementById('box');
    var cxt = box.getContext('2d');
    // 时钟动起来
    var timer = null;
    function clock(){
      var date = new Date();
      var s = date.getSeconds();

      var m = date.getMinutes()+s/60;

      var h = date.getHours()+m/60;
      h = h>12? h-12:h;
      // 清画布
      cxt.clearRect(0,0,500,500);
      // 画表盘
      cxt.strokeStyle = '#f0f';
      cxt.lineWidth = 6;
      cxt.beginPath();
      cxt.arc(250,250,100,0,2*Math.PI);
      cxt.stroke();
      // 画时钟刻度
      for(var i=0; i<12; i++){
        cxt.save();
        cxt.translate(250,250);
        cxt.rotate(30*i*Math.PI/180);
        cxt.lineWidth = 3;
        cxt.beginPath();
        cxt.moveTo(0,-80);
        cxt.lineTo(0,-92);
        cxt.stroke();
        cxt.restore();
      }
      //画分钟刻度
      for(var i=0; i<60; i++){
        cxt.save();
        cxt.translate(250,250);
        cxt.rotate(6*i*Math.PI/180);
        cxt.lineWidth = 2;
        cxt.beginPath();
        cxt.moveTo(0,-86);
        cxt.lineTo(0,-92);
        cxt.stroke();
        cxt.restore();
      }
      // 画时针
      cxt.save();
      cxt.lineWidth = 5;
      cxt.translate(250,250);
      cxt.rotate(h*30*Math.PI/180);
      cxt.beginPath();
      cxt.moveTo(0,6);
      cxt.lineTo(0,-40);
      cxt.stroke();
      cxt.restore();
      // 画分针
      cxt.save();
      cxt.lineWidth = 3;
      cxt.translate(250,250);
      cxt.rotate(m*6*Math.PI/180);
      cxt.beginPath();
      cxt.moveTo(0,8);
      cxt.lineTo(0,-60);
      cxt.stroke();
      cxt.restore();
      // 画秒针
      cxt.save();
      cxt.lineWidth = 1;
      cxt.translate(250,250);
      cxt.rotate(s*6*Math.PI/180);
      cxt.beginPath();
      cxt.moveTo(0,10);
      cxt.lineTo(0,-75);
      cxt.stroke();
      cxt.restore();
      // 画中心的小圆固定三根针
      cxt.save();
      cxt.beginPath();
      cxt.fillStyle = '#0f0';
      cxt.lineWidth = 2;
      cxt.translate(250,250);
      cxt.arc(0,0,2,0,360,false);
      cxt.stroke();
      cxt.fill();
      cxt.restore();
      // 画秒针上的园
      cxt.save();
      cxt.fillStyle = '#f00';
      cxt.lineWidth = 2;
      cxt.translate(250,250);
      cxt.rotate(s*6*Math.PI/180);
      cxt.beginPath();
      cxt.arc(0,-60,2,0,360,false);
      cxt.stroke();
      cxt.fill();
      cxt.restore();
    }
    clock();
    timer = setInterval(clock,1000);
  </script>
</body>
</html>

canvas绘制表盘时钟的更多相关文章

  1. 用canvas绘制一个时钟

    实现一个时钟的绘制和时间的显示 一,首先是页面的搭建html部分以及一点点的css代码,因为css这块用的比较少,所以就没有单独出来: <!DOCTYPE html> <html l ...

  2. 使用canvas绘制一个时钟

    周末学习canvas的一些基础功能,顺带写了一个基础的时钟.现在加工一下,做的更好看一点,先放上效果图: 谈一些自己的理解: (1).要绘制一个新的样式(不想被其他样式影响,或者影响到其他样式),那么 ...

  3. canvas绘制简易时钟

    时钟绘制的非常简易,但该有的都有了. 效果图如下, <!DOCTYPE html> <html> <head lang="en"> <me ...

  4. 应用canvas绘制动态时钟--每秒自动动态更新时间

    使用canvas绘制时钟 下文是部分代码,完整代码参照:https://github.com/lemoncool/canvas-clock,可直接下载. 首先看一下效果图:每隔一秒会动态更新时间 一. ...

  5. html5、canvas绘制本地时钟

    效果图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  6. Python Turtle库绘制表盘时钟

    运行效果: 源代码: 1 # coding=utf-8 2 3 import turtle 4 from datetime import * 5 6 # 抬起画笔,向前运动一段距离放下 7 def S ...

  7. 使用canvas绘制时钟

    使用canvas绘制时钟  什么使canvas呢?HTML5 <canvas> 元素用于图形的绘制,通过脚本 (通常是JavaScript)来完成.<canvas> 标签只是图 ...

  8. HTML5 之Canvas 绘制时钟 Demo

    <!DOCTYPE html> <html> <head> <title>Canvas 之 时钟 Demo</title> <!--简 ...

  9. canvas绘制时钟及注释及save和restore的用法

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

随机推荐

  1. JAVA高级编程数据源datasource

    原文链接 数据源 通过jdbc连接数据库,多建立几条连接放在数据源里面.可以设置数据源的最大连接数,同时活跃的连接数,最少空闲的连接数,能够同时接收处理的连接数等等. dbcp数据源 需要的jar包: ...

  2. python3报:ImportError: No module named 'MySQLdb'

    问题描述: 项目在转到python3.6时,原先的导入MySQLdb模块都提示无法导入,pip install mysqldb也安装失败. 问题原因: python2和python3在数据库模块支持这 ...

  3. 1.HTTP与HTTPS区别

    1.HTTP与HTTPS区别 HTTP协议默认采用80端口 HTTPS协议默认采用443 HTTPS相较于HTTP协议更安全一些,采用SSL+安全证书,但是效率低 2.使用代码格式模拟HTTP请求(H ...

  4. 一起探讨Go 语言为什么能成功?

    导读 两位创造者Rob Pike和Robert Griesemer一起探讨了Go成功的原因. 常言道,历史不会重演,但总会惊人的相似. 如果您想创建一种编程语言,多向那些有经验的人士学习,他们有很多可 ...

  5. Android 记住密码和自动登录界面的实现(SharedPreferences 的用法)

    原文:http://blog.csdn.net/liuyiming_/article/details/7704923 SharedPreferences介绍: SharedPreferences是An ...

  6. [理解] Linux 作为一个服务器是怎样的存在 (一)

    长期以来我就一直有一个疑问, 为什么当我们选择使用服务器的时候都会选择 Linux 作为操作系统, 以至于只要说到服务器就会不由自主的想到Linux, 那么Linux到底是什么呢? 当然我也不会妄谈天 ...

  7. FFmpeg——命令笔记

    1. 获取 dshow设备列表 ffmpeg -list_devices true -f dshow -i dummy 2. 通过UDP流推ts文件: ffmpeg.exe -re -i zhen.t ...

  8. Python 基础之面向对象之常用魔术方法

    一.__init__魔术属性 触发时机:实例化对象,初始化的时候触发功能:为对象添加成员,用来做初始化的参数:参数不固定,至少一个self参数返回值:无 1.基本用法 #例:class MyClass ...

  9. 利用Python进行数据分析笔记-时间序列(时区、周期、频率)

    此文对Python中时期.时间戳.时区处理等阐述十分清楚,特别值得推荐学习. 原文链接:https://blog.csdn.net/wuzlun/article/details/80287517

  10. 跨服务器的SQL语句如何书写

    select  *  into  本地库名..表名  from  OPENDATASOURCE(                  'SQLOLEDB',                  'Data ...