最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

会走动的图形html5时钟示例_html5教程技巧

来源:动视网 责编:小采 时间:2020-11-27 15:18:45
文档

会走动的图形html5时钟示例_html5教程技巧

会走动的图形html5时钟示例_html5教程技巧:使用HTML5制作时钟 代码如下: html5时钟 var Clock = function (canvas, options) { this.canvas = canvas; this.ctx = this.canvas.getContext(2d); this.options = options; }; Clock.prototy
推荐度:
导读会走动的图形html5时钟示例_html5教程技巧:使用HTML5制作时钟 代码如下: html5时钟 var Clock = function (canvas, options) { this.canvas = canvas; this.ctx = this.canvas.getContext(2d); this.options = options; }; Clock.prototy
 使用HTML5制作时钟


代码如下:



html5时钟



var Clock = function (canvas, options) {
this.canvas = canvas;
this.ctx = this.canvas.getContext("2d");
this.options = options;
};

Clock.prototype = {
constructor: Clock,
drawCircle: function () {
var ctx = this.ctx;
ctx.strokeStyle = "black";
ctx.arc(this.canvas.width / 2, this.canvas.height / 2, 50, 0, 2 * Math.PI, false);
ctx.stroke();
},
drawNum: function () {
var ctx = this.ctx;
var angle = Math.PI * 2 / 12;
for (var i = 1; i <= 12; i += 1) {
ctx.font = "20px Georgia";
ctx.textAlign = "center";
ctx.textBaseline = 'middle';
ctx.fillText(String(i), this.canvas.width / 2 + Math.cos(3 *Math.PI / 2 + angle * i) * 40, this.canvas.height / 2 + Math.sin(3 * Math.PI / 2 + angle * i) * 40);
}
},
drawPointer: function () {
var ctx = this.ctx;
var that = this;
var date, hour, minute, second;
date = new Date();
hour = date.getHours();
if (hour > 12) {
hour = hour % 12;
}
minute = date.getMinutes();
second = date.getSeconds();

var b = minute * Math.PI / 30;
var c = second * Math.PI / 30;
var a = hour * Math.PI / 6 + Math.PI / 6 * minute / 60;
var minuteAngle = Math.PI * 2 / 3600;
var secondAngle = Math.PI * 2 / 60;
var hourAngle = Math.PI * 2 / 12 / 3600;

ctx.beginPath();
ctx.save();
ctx.translate(that.canvas.width / 2, that.canvas.height / 2);
ctx.arc(0, 0, 3, 0, 2 * Math.PI, false);
ctx.fill();
ctx.closePath();
ctx.beginPath();
a += hourAngle;
ctx.rotate(a);
ctx.fillRect(-2, -22, 4, 30);
ctx.closePath();
ctx.beginPath();
b += minuteAngle;
ctx.rotate(b - a);
ctx.fillRect(-1.5, -26, 3, 35);
ctx.closePath();
ctx.beginPath();
c += secondAngle;
ctx.rotate(c - b);
ctx.fillRect(-1, -30, 2, 40);
ctx.closePath();
ctx.restore();
},
rePaint: function () {
this.drawPointer();
this.drawCircle();
this.drawNum();
},
tik: function () {
var that = this;
var ctx = this.ctx;
this.rePaint();
window.timer = setInterval(function () {
ctx.clearRect(0, 0, that.canvas.width, that.canvas.height);
that.rePaint();
}, 1000);
}
};

var options;
var clock = new Clock(document.getElementById("canvas"), options);
clock.tik();



保存后使用浏览器运行,可以看到走动的圆形时钟,大家试试看吧

文档

会走动的图形html5时钟示例_html5教程技巧

会走动的图形html5时钟示例_html5教程技巧:使用HTML5制作时钟 代码如下: html5时钟 var Clock = function (canvas, options) { this.canvas = canvas; this.ctx = this.canvas.getContext(2d); this.options = options; }; Clock.prototy
推荐度:
标签: 教程 时钟 html5
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top