当前位置:

html5 canvas仿百度时间

本文最后更新于2015-08-10,已超过 1年没有更新,如果文章内容、图片或者下载资源失效,请留言反馈,我会及时处理,谢谢!

温馨提示:本文共5161个字,读完预计13分钟。

今天帮同事做了一个仿百度时间的demo,时钟用的是html5的canvas,其他都是利用js实现。效果如下图:

html5 canvas仿百度时间-何海宝的博客

html5 canvas仿百度时间-何海宝的博客

友情提示:该demo暂时支持兼容到IE9以上以及其他主流浏览器,如需支持IE6-8请自行下载html5shiv.js和excanvas.js。

具体实现代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
<!doctype html>
<html lang="en">
<head>
	<meta charset="UTF-8" />
	<title>DEMO</title>
	<style>
		html,body,div,p{margin:0;padding:0;}
		.beijingtime-box{width: 540px;height: 100px;font-family: "Microsoft Yahei", arial;overflow: hidden;background-color:#056AC1!important;background-image: linear-gradient(top,#056AC1,#5FA2DD);background-image: -moz-linear-gradient(top,#056AC1,#5FA2DD);background-image: -webkit-linear-gradient(top,#056AC1,#5FA2DD);background-image: -o-linear-gradient(top,#056AC1,#5FA2DD);background-image: -ms-linear-gradient(top,#056AC1,#5FA2DD);}
		#clock{width: 64px;height: 64px;float: left;margin: 20px 0 0 50px;}
		.beijing_time{margin: 0 7px 0 25px;font-size: 55px;color:#fff;height: 100px;line-height: 100px;width: 228px;letter-spacing: 1px;float: left;white-space: nowrap;}
		.beijing_time_second{font-size: 32px;}
		.beijing_datebox{float: left;text-align: left;font-size: 20px;color: #fff;margin-top: 20px;}
		.beijing_week{display: block;}
		.beijing_date{font-size: 15px;}
	</style>
</head>
<body>
	<div class="beijingtime-box">
		<canvas id="clock" width="64" height="64"></canvas>
		<p class="beijing_time"></p>
		<p class="beijing_datebox">
			<span class="beijing_week"></span>
			<span class="beijing_date"></span>
		</p>
	</div>
 
	<script>
	window.onload = function(){
	    // inner variables
		var canvas, ctx;
		var clockRadius = 250;
		var clockImage;
 
		// draw functions :
		function clear() { // clear canvas function
		    ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
		}
 
		function drawScene() { // main drawScene function
		    clear(); // clear canvas
 
		    // get current time
		    var date = new Date();
		    var hours = date.getHours();
		    var minutes = date.getMinutes();
		    var seconds = date.getSeconds();
		    hours = hours > 12 ? hours - 12 : hours;
		    var hour = hours + minutes / 60;
		    var minute = minutes + seconds / 60;
 
		    // save current context
		    ctx.save();
 
		    // draw clock image (as background)
		    ctx.drawImage(clockImage, 0, 0, 64, 64);
 
		    ctx.translate(canvas.width / 2, canvas.height / 2);
		    ctx.beginPath();
 
		    // draw hour
		    ctx.save();
		    var theta = (hour - 3) * 2 * Math.PI / 12;
		    ctx.rotate(theta);
		    ctx.beginPath();
		    ctx.moveTo(-1, -3);
		    ctx.lineTo(-1, 3);
		    ctx.lineTo(clockRadius * 0.1, 1);
		    ctx.lineTo(clockRadius * 0.1, -1);
		    ctx.fillStyle = 'white';
		    ctx.fill();
		    ctx.restore();
 
		    // draw minute
		    ctx.save();
		    var theta = (minute - 15) * 2 * Math.PI / 60;
		    ctx.rotate(theta);
		    ctx.beginPath();
		    ctx.moveTo(-3, -2);
		    ctx.lineTo(-3, 2);
		    ctx.lineTo(clockRadius * 0.1, 1);
		    ctx.lineTo(clockRadius * 0.1, -1);
		    ctx.fillStyle = 'white';
		    ctx.fill();
		    ctx.restore();
 
		    // draw second
		    ctx.save();
		    var theta = (seconds - 15) * 2 * Math.PI / 60;
		    ctx.rotate(theta);
		    ctx.beginPath();
		    ctx.moveTo(-4, -1);
		    ctx.lineTo(-4, 1);
		    ctx.lineTo(clockRadius * 0.01, 1);
		    ctx.lineTo(clockRadius * 0.1, -1);
		    ctx.fillStyle = 'red';
		    ctx.fill();
		    ctx.restore();
		    ctx.restore();
		}
 
	    canvas = document.getElementById('clock');
	    ctx = canvas.getContext('2d');
		clockImage = new Image();
		clockImage.src = '';
                drawScene();
		setInterval(drawScene, 1000);
 
	     //获取当前日期
	     function getCurDate(){
	     	var d = new Date();
			 var week = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六")[d.getDay()];
			 var years = d.getFullYear();
			 var month = add_zero(d.getMonth()+1);
			 var days = add_zero(d.getDate());
			 var hours = add_zero(d.getHours());
			 var minutes = add_zero(d.getMinutes());
			 var seconds = add_zero(d.getSeconds());
 
			 document.querySelector('.beijing_time').innerHTML = hours+"<span>:</span>"+minutes+" <span class='beijing_time_second'>"+seconds+"</span>";		 		 
			 document.querySelector('.beijing_week').innerHTML = week;
			 document.querySelector('.beijing_date').innerHTML = years+"年"+month+"月"+days+"日 ";
	     }
	     function add_zero(temp){
		  if(temp<10) return "0"+temp;
		  else return temp;
		}
		 getCurDate();
		 setInterval(function(){ getCurDate(); },1000);
 
	};
	</script>
</body>
</html>
版权申明:本文地址 ,本博客所有文章除特别声明外,均采用署名-非商业性使用-禁止演绎 4.0 国际 许可协议。请尊重他人的劳动成果!

我要说两句