博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js css3实现钟表效果
阅读量:5291 次
发布时间:2019-06-14

本文共 3407 字,大约阅读时间需要 11 分钟。

原理:

利用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);

最终效果

 

 

 

 

整体代码:

                                            

 

转载于:https://www.cnblogs.com/xiaofenguo/p/10622391.html

你可能感兴趣的文章
Js函数初学者练习(一)switch-case结构实现计算器。
查看>>
P2P综述
查看>>
细读 php json数据和JavaScript json数据
查看>>
第五章 如何使用Burp Target
查看>>
Sprint阶段测试评分总结
查看>>
Servlet3.0新特性
查看>>
java内存溢出怎么解决
查看>>
JS对象以及"继承"
查看>>
Ewebeditor最新漏洞及漏洞大全
查看>>
socket计划编制的原则
查看>>
sqlite3经常使用命令&语法
查看>>
[leetcode] 309. Best Time to Buy and Sell Stock with Cooldown(medium)
查看>>
解决微信授权回调页面域名只能设置一个的问题 [php]
查看>>
数组去重一步到位
查看>>
HDU 4671 Backup Plan 构造
查看>>
linux下编译openjdk8
查看>>
【python】--迭代器生成器装饰器
查看>>
Pow(x, n)
查看>>
安卓当中的线程和每秒刷一次
查看>>
MySQL Proxy
查看>>