canvas时钟--效果图

一、先来简单介绍画时钟需要的canvas知识

1.在HTML页面中添加canvas元素,必须定义canvas元素的id属性值以便接下来的调用。

HTML代码:

<canvas id="canvas" class="canvas" width="400" height="400" border:></canvas>

2.使用id寻找canvas元素,在js代码中使用document.getElementById()等方法获取id。

var canvas = document.getElementById("canvas");

3.通过canvas元素的getContext方法来获取其上下文(Context),即创建Context对象,以获取允许绘画的2D环境。

var ctx = canvas.getContext("2d");

4.先来认识一下canvas的绘制方法。

(1)绘制矩形的两种方法:fillRect 和 strokeRect

  前者用于绘制用颜色填充(fill)区域的矩形,后者用于绘制轮廊(stroke)或线条。图形指定颜色用到了两个属性,即fillStyle 和 strokeStyle,前者用于指定要绘制的填充区域的颜色,后者用于指定要绘制的线条颜色。

//绘制填充颜色矩形,默认黑色
ctx.fillStyle="red";
ctx.fillRect(0,0,200,100);

//绘制有颜色线条
ctx.strokeStyle="blue";
ctx.strokeRect(0,0,100,50);

(2)绘制圆形

  绘制圆形是会用到四种方法:beginPath、arc、closePath和fill或stroke。

//画圆填充红颜色//绘制园用法:ctx.arc(x,y,radius,startAngle,endAngle,anticlockwise);
ctx.beginPath();
ctx.fillStyle="red";
ctx.arc(0,0,100,0,2*Math.PI,true);
ctx.closePath();
ctx.fill();

//线条蓝色画圆
ctx.beginPath();
ctx.strokeStyle="blue";
ctx.lineWidth=10;//设置线条宽度
ctx.arc(0,0,174,0,Math.PI*2,true);
ctx.stroke();

(3)绘制直线

  用到两个主要方法:moveTo 和 lineTo 以及stroke。

ctx.moveTo(x,y)——规定线起始点(x,y)。ctx.lineTo(x,y)——规定直线路线的终点。

ctx.moveTo(,);
ctx.lineTo(,);
ctx.stroke();//该方法用于沿该路径绘制线条

二、画canvas时钟过程

首先,定义画布字体的为圆角,让我们看起来美美的:ctx.lineCap="round";

其次,非常重要,时钟是随着时分秒针的转动而转动的,so——我们需要画布范围内必须设计画布不断清除和刷新:ctx.clearRect(0,0,400,400);

再次,一个画布初始中心点(0,0)是在画布左上角,so——画时钟需要把中心点转移:ctx.translate(200,200);

最后,也是最重要的,每多一个save()保存就必须在下面补上一个还原restore();

1、画分刻线

  画线嘛,上面咱们已经讲过画线的步骤,就不多说啦!只需要注意用到rotate()方法将,先用ctx.moveTo(),ctx.lineTo在画布右侧画出第一根分刻线,再定义需要旋转的角度变量——rotateD,经过ctx.rotate(rotateD)方法来for循环以及画布不断清除刷新的状态,即可画出分刻线。

  当然这里还需要注意一点:画布需要用到另个方法来包含要执行的内容,分别是save()、restore()。save() 方法把当前状态的一份拷贝压入到一个保存图像状态的栈中。这就允许你临时地改变图像状态,然后,通过调用 restore() 来恢复以前的值。我打个比喻:我有一只手,戴上手套去完成一些事情,手套摘下来之后,我的手还是我的手。额,有点。。。呵呵

//画刻度线
        for (var i = 0; i ; i++) {
            ctx.save();
            ctx.beginPath();
            var rotateD = i*Math.PI*2/60;
            ctx.rotate(rotateD);
            ctx.lineWidth = 4;
            ctx.moveTo(170,0);
            ctx.lineTo(160,0);
            ctx.stroke();
            ctx.restore();
        };

2、画时刻线

  同理,画时刻线只需要修改线宽以及旋转角度

3、画时针

  在前面new一个data变量var date = new Date;,并且定义一个时针随时间变化旋转角度也变化的变量rotateH。

  小时针旋转角度rotateH;

  公式:rotateH = 时针旋转角度 +分针旋转角度/12 - 直角 = data.getHours()/12*2*Math.PI + date.getMinutes()/60/12*Math.PI*2 - Math.PI/2;

  (为什么会减Math.PI/2呢,因为时针的初始值为(-12,0)、(125,0);针指向正好是在三点中位置,所以需要减掉一个直角才能从十二点开始旋转)。

4、画分针

  定义一个分针随时间变化旋转角度也变化的变量rotateM。

  公式:rotateM = 分针旋转角度 + 秒针旋转角度/60 -直角 = date.getMinutes()/60*Math.PI*2 + date.getSeconds()/60/60*Math.PI*2 - Math.PI/2;

5、画秒针

定义一个分针随时间变化旋转角度也变化的变量rotateS。

  公式:rotateM = 秒针旋转角度 - 减直角 = date.getSeconds()/60*Math.PI*2 - Math.PI/2;

6、时针数字略

三、canvas实现时钟完整代码

 js完整代码:

jQuery(function($){
	function clock(){
		var canvas= document.getElementById("canvas");
    	var ctx = canvas.getContext("2d");
    	var date = new Date;
    	ctx.lineCap = "round";//字体变圆角
    	ctx.clearRect(0,0,400,400);//不断清除画布 不断再执行刷新

    	ctx.save();//每多一个保存就必须在下面补上一个还原restore()
    	ctx.translate(200, 200);//中心点转移

    	//画刻度线
    	for (var i = 0; i < 60; i++) {
    		ctx.save();
	    	ctx.beginPath();
	    	var rotateD = i*Math.PI*2/60;
	    	ctx.rotate(rotateD);
	    	ctx.lineWidth = 4;
	    	ctx.moveTo(170,0);
	    	ctx.lineTo(160,0);
	    	ctx.stroke();
	    	ctx.restore();
    	};
    	for (var i = 0; i < 12; i++) {
    		ctx.save();
	    	ctx.beginPath();
	    	var rotateB = i*Math.PI*2/12;
	    	ctx.lineWidth = 6;
	    	ctx.rotate(rotateB);
	    	ctx.moveTo(170,0);
	    	ctx.lineTo(150,0);
	    	ctx.stroke();
	    	ctx.restore();
    	};
    	//画时针
    	var rotateH = date.getHours()/12*Math.PI*2 + date.getMinutes()/60/12*Math.PI*2 - Math.PI/2;
    	ctx.save();
    	ctx.beginPath();
    	ctx.rotate(rotateH);
    	ctx.lineWidth=12;
    	ctx.moveTo(-12,0);
    	ctx.lineTo(125,0);
    	ctx.stroke();
    	ctx.restore();

    	//画分针
    	var rotateM = date.getMinutes()/60*Math.PI*2 + date.getSeconds()/60/60*Math.PI*2 - Math.PI/2;
    	ctx.save();
    	ctx.strokeStyle="red";
    	ctx.beginPath();
    	ctx.rotate(rotateM);
    	ctx.lineWidth=9;
    	ctx.moveTo(-12,0);
    	ctx.lineTo(135,0);
    	ctx.stroke();
    	ctx.restore();

    	//画秒针
    	var rotateS = date.getSeconds()/60*Math.PI*2 - Math.PI/2;
    	ctx.save();
    	ctx.strokeStyle="red";
    	ctx.beginPath();
    	ctx.rotate(rotateS);
    	ctx.lineWidth=6;
    	ctx.moveTo(-16,0);
    	ctx.lineTo(140,0);
    	ctx.stroke();

    	//画中心圆点
    	ctx.fillStyle="red";
    	ctx.arc(0,0,10,0,2*Math.PI)
    	ctx.closePath();
    	ctx.fill();

    	//画秒针圆圈头
    	ctx.strokeStyle="red";
    	ctx.moveTo(160,0);
    	ctx.arc(150,0,8,0,2*Math.PI);
    	ctx.stroke();
    	ctx.restore();

        // 画clock的表盘
        ctx.beginPath();
        ctx.strokeStyle="blue";
        ctx.lineWidth=10;
        ctx.arc(0,0,174,0,Math.PI*2);
        ctx.stroke();

    	ctx.restore();
    	window.requestAnimationFrame(clock);
	};
    window.requestAnimationFrame(clock);
});

  总结,写得粗糙,仅供参考,期待共同探讨!

canvas画时钟,重拾乐趣!的更多相关文章

  1. canvas画时钟

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  2. canvas 画时钟 会动呦

    //半径 var r = 130; //重置原点 ctx.save(); ctx.translate(400, 500); //使用translate重置原点 function drawClock() ...

  3. html5学习(一)--canvas画时钟

    利用空余时间学习一下html5. <!doctype html> <html> <head></head> <body> <canva ...

  4. 用canvas画时钟

    效果图在博客首页上. html: <canvas id="canvas" >Your browser does not support canvas</canva ...

  5. 深夜,用canvas画一个时钟

    深夜,用canvas画一个时钟 查看demo 这几天准备阿里巴巴的笔试,可以说已经是心力交瘁,自从阿里和蘑菇街的内推被刷掉之后,开始越来越怀疑起自己的能力来,虽然这点打击应该是微不足道的.毕竟校招在刚 ...

  6. 简单酷炫的Canvas数字时钟

    声明:本文为原创文章,如需转载,请注明来源WAxes,谢谢! 我记得很早之前就看过这个DEMO,是岑安大大博客里看到的: 就是这个数字时钟,当时觉得这个创意不错,但是也没去折腾.直到昨天同事又在网上看 ...

  7. [JS,Canvas]日历时钟

    [JS,Canvas]日历时钟 Html: <!doctype html> <html> <head> <meta charset="UTF-8&q ...

  8. CSS魔法堂:重拾Border之——更广阔的遐想

    前言  当CSS3推出border-radius属性时我们是那么欣喜若狂啊,一想到终于不用再添加额外元素来模拟圆角了,但发现border-radius还分水平半径和垂直半径,然后又发现border-t ...

  9. CSS魔法堂:重拾Border之——图片作边框

    前言  当CSS3推出border-radius属性时我们是那么欣喜若狂啊,一想到终于不用再添加额外元素来模拟圆角了,但发现border-radius还分水平半径和垂直半径,然后又发现border-t ...

随机推荐

  1. ZOJ 1108 & HDU 1160 - FatMouse's Speed

    题目大意:给你n只老鼠的体重w和速度s,让你找出最长的子序列使得w[i] < w[j] 且 s[i] > s[j] (i < j).求最长序列的长度并输出该序列. LIS(Longe ...

  2. CentOS6.5编译安装Redis

    一.首先要检测是否安装gcc yum install gcc-c++ yum install -y tcl 进入redis目录 cd /usr/local/redis .编译安装 make make ...

  3. vim列编辑

    命令模式下:ctrl + v(我在gvim,win7中是ctrl +shift + q)进入列编辑模,选中要编辑的行(j 上,k下) 输入 “I” (大写的 I,光标定位到选中的第一行),输入要编辑的 ...

  4. 转:找不到include xgpio.h;Unresolved include xgpio.h

    这个文档讲解的是在SDK下出现的问题,如果在ISE下编译是有错的,不能正常进入SDK,那这篇文档不适合你. 问题是这样的.根据教程<XILINX FPGA Verilog编程大全>做SOC ...

  5. HDU-2573-Typing

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2573 这题把%s与gets()的输入法搞混了一直感觉没有错,就是找不出哪里错了, 题目思路不是很难. ...

  6. jQuery内容过滤器

    jQuery内容过滤器 <h1>this is h1</h1> <div id="p1"> <h2>this is h2</h ...

  7. Pomelo框架

    一个典型的多进程MMO运行架构, 如下图所示: pomelo框架的组成如图所示: 架构把游戏服务器做了抽象, 抽象成为两类:前端服务器和后端服务器, 如图: 前端服务器(frontend)的职责: 负 ...

  8. CRtmpServer分析与应用

    CRtmpServer分析与应用 官方地址:http://www.rtmpd.com/ CRtmpServer是一款不错的开源流媒体服务器,用c++语言编写,跨平台.官方介绍CRtmpServer不仅 ...

  9. 图片上传之FileAPI与NodeJs

    HTML5之fileAPI HTML5之fileAPI使得我们处理图片上传更加简单. 实例 html代码 <div class="form-group"> <la ...

  10. Introduce: IEPI.BIATranscribe 图像表格拓写工具

    应用场合 数据表格是学术.文案工作中常用的表述形式.我们经常需要从第三方获取所需的数据.有些时候这些数据并非以可直接编辑的形式(如电子表格文档),而是以打印件或者扫描件的形式提供.假如需要对数据进行进 ...