原理:
利用transform-origin改变旋转的圆心,实现秒数和分钟数的刻度线,利用transfrom translate实现钟表小时刻度的显示
html:
1 绘制圆盘
.time{ width: 300px;height: 300px;border-radius: 50%;margin: 100px auto;background-color: #000;color: #fff;position: relative;padding: 5px;}
2 绘制秒数
css
.second,.minute,.hour{ position: absolute; left: 0; right: 0; top: 0; bottom: 0; } .second div,.minute div{ background-color: #fff; position:absolute; width: 2px; left: 50%; top: 50%; transform: translate(50%,145px); } .second div{ height: 5px; }
js:
function draw(num,r,className,flag){ for(var i=0; i '+(i+1)+''); }else{ var second=$(''); } $(".time").append(second); } }draw(60,145,'second');
绘制的是60个刻度,每个刻度的角度是360/60*i
4 绘制分钟刻度,12个刻度线,原理同上
css
.minute div{ height: 10px; transrform: translate(50%,135px); }
js
draw(12,120,'minute',true)
没有减60 是这样的
5 绘制钟表中心点以及秒针 分针 时针
css:
.time .line,.time .hour-line,.time .minute-line,.time .second-line{ position:absolute; top: 50%; left: 50%; background-color: #fff; transform-origin: left top; /*transform: rotate(-90deg);*/ } .time .line{ width: 14px; height: 14px; border-radius: 50%; margin-left: -7px; margin-top: -7px; } .time .hour-line{ width: 70px; height: 4px; margin-top: -2px; } .time .minute-line{ width: 90px; height: 2px; margin-top: -2px; } .time .second-line{ width: 120px; height: 2px; margin-top: -1px; }
获取当前时间,获取时分秒,获取时针 分针 秒针 旋转的角度,算出的角度是从0开始旋转的,需要减去90度
js
function drawLine(hour,minute,second){ var secondAngle=360/60*second-90;//秒 var minuteAngle=360/60*minute-90;//秒 var hourAngle=360/12*(hour+minute/60)-90;//秒 $(".hour-line").css({ 'transform':"rotate("+hourAngle+"deg)" }); $(".minute-line").css({ 'transform':"rotate("+minuteAngle+"deg)" }); $(".second-line").css({ 'transform':"rotate("+secondAngle+"deg)" }); }setInterval(function(){ var time=new Date(); var hour=time.getHours(); if(hour>12){ hour=hour-12; } var minute=time.getMinutes(); var second=time.getSeconds(); drawLine(hour,minute,second); },1000);
最终效果
整体代码: