【实现效果图示】
【实现代码】
<!DOCTYPE html>
<html lang="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<head><title>时尚钟表</title></head><body onload="draw()"><canvas id="myCanvus" width="400px" height="400px" style="border:0px dashed black;">出现文字表示您的浏览器不支持HTML5</canvas></body>
</html>
<script type="text/javascript">
<!--
/*****************************************************************
* 将全体代码(从<!DOCTYPE到script>)拷贝下来,粘贴到文本编辑器中,
* 另存为.html文件,再用chrome浏览器打开,就能看到实现效果。
******************************************************************/
function draw(){var canvas=document.getElementById('myCanvus'); canvas.width=400;canvas.height=400; context=canvas.getContext('2d'); context.translate(200,200);clock=new Clock(200); clock.init();animate();
};// 绘图上下文
var context;// 时钟对象
var clock;function animate(){ context.clearRect(-200,-200,400,400);// 清屏clock.paintBg(context);clock.paintScale(context);clock.paintPointers(context);if(true){window.requestAnimationFrame(animate);}
}// 钟表类
function Clock(radius){this.radius=radius;this.img;this.init=function(){this.img=new Image();this.img.src="bg.jpg";}// 画背景this.paintBg=function(ctx){ctx.beginPath();ctx.arc(0,0,200,0,2*Math.PI,true);ctx.closePath();ctx.stroke();// 用以上的圆去切割下面的图片ctx.clip();ctx.drawImage(this.img,0,0,400,400,-200,-200,400,400);ctx.fillStyle="red";var width = ctx.canvas.width;var height = ctx.canvas.height;var BL = width / 200;var r=this.radius;ctx.save();//保存一下最开始时钟的环境ctx.beginPath();ctx.lineWidth = 13.8 * BL;//线要 乘上 比例ctx.arc(0, 0, r - ctx.lineWidth / 2, 2 * Math.PI, false);//乘上比例ctx.strokeStyle = "#000080";ctx.stroke();ctx.fillStyle="white";var hourNumber = [3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 1, 2];ctx.font = 18 * BL + 'px Arial';//字体也有乘比例 字符串拼接ctx.textAlign = 'center';ctx.textBaseline = 'middle';hourNumber.forEach(function (number, i) {var rad = 2 * Math.PI / 12 * i;var x = Math.cos(rad) * (r - 30 * BL);var y = Math.sin(rad) * (r - 30 * BL);ctx.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 * BL);var y = Math.sin(rad) * (r - 18 * BL);ctx.beginPath();if (i % 5 == 0) {ctx.fillStyle = '#800080';ctx.arc(x, y, 2 * BL, 0, 2 * Math.PI, false);} else {ctx.fillStyle = '#c0c0c0';ctx.arc(x, y, 2 * BL, 0, 2 * Math.PI, false);}ctx.fill();}ctx.restore();};// 画汉字this.paintScale=function(ctx){var arr=["富强","民主","文明","和谐","自由","平等","公正","法治","爱国","敬业","诚信","友善"];var offset=16;ctx.save();ctx.rotate(getRad(-94.5));for(var i=0;i<60;i++){var degree=i*6;var x=(this.radius-offset)*Math.cos(getRad(degree));var y=(this.radius-offset)*Math.sin(getRad(degree));if((i % 5)==0){ctx.save(); var x1=(this.radius-20)*Math.cos(getRad(degree));var y1=(this.radius-20)*Math.sin(getRad(degree));ctx.translate(x1,y1);ctx.rotate(getRad(degree+96));ctx.font="bold 16px 宋体";ctx.fillStyle='white';ctx.fillText(arr[i/5],0,0);ctx.restore();} }ctx.restore();};// 画指针this.paintPointers=function(ctx){var date = new Date();var hour=date.getHours();var minute=date.getMinutes();var second=date.getSeconds();ctx.font="bold 12px 宋体";ctx.fillStyle="white";ctx.fillText(hour+":"+minute+":"+second,-20,-100);var angleS=second*6;var angleM=minute*6;var angleH=hour*30+angleM/360*30;var width = ctx.canvas.width;var height = ctx.canvas.height;var BL = width / 200;context.save();context.rotate(getRad(-90));var x,y;// 画时针x=(this.radius-60)*Math.cos(getRad(angleH));y=(this.radius-60)*Math.sin(getRad(angleH));ctx.strokeStyle = "white";ctx.lineWidth = 3 * BL;//定义指针的宽ctx.lineCap = 'round';//指针顶部为弧ctx.beginPath();ctx.moveTo(-x/8, -y/8);ctx.lineTo(x,y);ctx.stroke();ctx.closePath();// 画分针x=(this.radius-45)*Math.cos(getRad(angleM));y=(this.radius-45)*Math.sin(getRad(angleM));ctx.strokeStyle = "white";ctx.lineWidth = 2 * BL;//定义指针的宽ctx.lineCap = 'round';//指针顶部为弧ctx.beginPath();ctx.moveTo(-x/8, -y/8);ctx.lineTo(x,y);ctx.stroke();ctx.closePath();context.restore();// 画秒针ctx.save();ctx.lineWidth=0.5;ctx.strokeStyle = "black";ctx.beginPath();var r=this.radius;ctx.rotate(getRad(angleS));ctx.moveTo(-2 * BL, 20 * BL);//画出一个秒针 x轴-2 y轴20ctx.lineTo(2 * BL, 20 * BL);ctx.lineTo(1, -r + 18 * BL);ctx.lineTo(-1, -r + 18 * BL);ctx.fill();ctx.stroke();ctx.closePath();ctx.strokeStyle = 'yellow';ctx.beginPath();ctx.arc(1, -r + 18 * BL, 2 * BL, 0, 2 * Math.PI, false);ctx.closePath();ctx.stroke();ctx.restore();// 画中心小圆点ctx.save();ctx.beginPath();ctx.arc(0,0,5,0,2*Math.PI,true);ctx.closePath();ctx.strokeStyle="#6F00D2";ctx.fillStyle="#F9F900";ctx.fill(); ctx.stroke();ctx.restore();};
}// 常规函数:角度得到弧度
function getRad(degree){return degree/180*Math.PI;
}/*----------------------------------
有一天,我突然想明白了一件事:我们都会死的。
也许是十年后,
也许是二十年后,
也许是五十年后,
谁知道呢?
有一天我终将死去,
这个世界上会没有我任何存在过的痕迹。
----------------------------------*/
//-->
</script>
【下载地址】
https://files.cnblogs.com/files/heyang78/66.fashion-clock-20240315-2.rar?t=1710515286&download=true