css模拟时钟

思路:

画时钟数字(x,y)坐标

x = x0 + r*cos(deg)
y = y0 + r*sin(deg)

知识点:

  1. 创建元素: createElement
  2. 添加元素: appendChild
  3. css3旋转: transform:rotate(30deg);
  4. css3改变旋转中心点: transform-origin:0 0;
  5. 获取当前时间, 把时间数字转换为度数
  1. <!DOCTYPE html> 

  2. <html lang="en"> 

  3. <head> 

  4. <meta charset="UTF-8"> 

  5. <title>Title</title> 

  6. <style> 

  7. * { margin: 0; padding: 0; } 

  8. #bg { 

  9. width: 400px; 

  10. height: 400px; 

  11. background: #ddd; 

  12. border-radius: 10px; 

  13. /* div上下左右垂直居中 */ 

  14. position: absolute; 

  15. left: 50%; 

  16. top: 50%; 

  17. margin-top: -200px; 

  18. margin-left: -200px; 




  19. #bg #clock { 

  20. width: 360px; 

  21. height: 360px; 

  22. background: #fff; 

  23. border-radius: 50%; 

  24. display: inline-block; 

  25. margin: 20px; 

  26. position: relative; 




  27. #hour { 

  28. width: 70px; 

  29. height: 16px; 

  30. background: #000; 

  31. position: absolute; 

  32. left: 180px; 

  33. top: 172px; 

  34. border-radius: 16px; 

  35. transform-origin:0 8px; 



  36. #minute { 

  37. width: 120px; 

  38. height: 12px; 

  39. background: #000; 

  40. position: absolute; 

  41. left: 180px; 

  42. top: 174px; 

  43. border-radius: 12px; 

  44. transform-origin:0 6px; 



  45. #second { 

  46. width: 140px; 

  47. height: 6px; 

  48. background: #f00; 

  49. position: absolute; 

  50. left: 180px; 

  51. top: 177px; 

  52. border-radius: 6px; 

  53. transform-origin:0 1px; 

  54. /*transform:rotate(30deg);*/ 

  55. /*animation: clockRotate 3s linear infinite;*/ 




  56. @keyframes clockRotate { 

  57. from {transform:rotate(0deg);} 

  58. to {transform:rotate(360deg);} 




  59. #point{ 

  60. width: 30px; 

  61. height: 30px; 

  62. border-radius: 50%; 

  63. background: #000; 

  64. position: absolute; 

  65. left: 50%; 

  66. top: 50%; 

  67. margin: -15px 0 0 -15px; 




  68. #clock .number{ 

  69. position: absolute; 

  70. font-size: 28px; 

  71. width: 50px; 

  72. height: 50px; 

  73. line-height: 50px; 

  74. text-align: center; 



  75. </style> 

  76. </head> 

  77. <body> 

  78. <div id="bg"> 

  79. <div id="clock"> 

  80. <div id="hour"></div> 

  81. <div id="minute"></div> 

  82. <div id="second"></div> 

  83. <div id="point"></div> 

  84. </div> 

  85. </div> 


  86. <script> 

  87. var clock = document.getElementById('clock'); 

  88. var r = 150; 

  89. var angle = Math.PI * 2; // 2PI = 360° 

  90. for (var i = 1; i <=12; i++) { 

  91. var deg = angle/12 * i - Math.PI/2; 

  92. var x = r + r*Math.cos(deg); 

  93. var y = r + r*Math.sin(deg); 

  94. //console.log(x,y); 

  95. var num = document.createElement('div');//创建div 

  96. num.className = 'number';//设置class样式 

  97. num.innerText = i; 

  98. //设置坐标 

  99. num.style.top = y + 'px'; 

  100. num.style.left = x + 'px'; 

  101. //添加 

  102. clock.appendChild(num); 




  103. //TODO 1. 数字转换度数 

  104. function run() { 

  105. var date = new Date(); 

  106. //时(0-23) 分(0-59)秒(0-59) 

  107. var hour = date.getHours(); 

  108. var minute = date.getMinutes(); 

  109. var second = date.getSeconds(); 


  110. var hourDeg = 360/12 * hour - 90; 

  111. var minuteDeg = 360/60 * minute - 90; 

  112. var secondDeg = 360/60 * second - 90; 


  113. var hourDiv = document.getElementById('hour'); 

  114. var minuteDiv = document.getElementById('minute'); 

  115. var secondDiv = document.getElementById('second'); 


  116. hourDiv.style.transform = 'rotate('+hourDeg+'deg)'; 

  117. minuteDiv.style.transform = 'rotate('+minuteDeg+'deg)'; 

  118. secondDiv.style.transform = 'rotate('+secondDeg+'deg)'; 




  119. //TODO 2. 设置定时器 

  120. run(); 

  121. setInterval(function () { 

  122. run(); 

  123. },1000); 

  124. </script> 

  125. </body> 

  126. </html> 

css模拟时钟的更多相关文章

  1. 【CSS3】纯CSS代码实现模拟时钟,+js对时功能。

    使用CSS3纯代码来实现模拟时钟,及指针动画功能. 在这里主要使用到css3一些基本元素: border-radius:圆角边框,画圆形:表盘 Transform:变换,旋转,扭曲:刻度盘,指针形状 ...

  2. 纯js+html+css实现模拟时钟

    前几天没事写的个模拟时钟,代码仅供小白参考,大神请自动绕过. <!DOCTYPE html> <html lang="en"> <head> & ...

  3. 一个模拟时钟的时间选择器 ClockPicker

    最近开发的一个模拟时钟的时间选择器 ClockPicker,用于 Bootstrap,或者单独作为一个 jQuery 插件. 源代码托管在 GitHub 上: ClockPicker 最近项目中需要用 ...

  4. 模拟时钟(AnalogClock)和数字时钟(DigitalClock)

    Demo2\clock_demo\src\main\res\layout\activity_main.xml <LinearLayout xmlns:android="http://s ...

  5. android脚步---数字时钟和模拟时钟

    时钟UI组件是两个非常简单的组件,分为Digitalclock  和Analogclock, main.xml文件,书中程序有问题,加了两个组件,一个Button和一个<Chronometer ...

  6. css模拟Bootstrap响应式布局——栅格

    做作业的时候遇见用css模拟Bootstrap的栅格布局,学习了一下.发现这个很有用,用来在不同的平台上得到很好地用户体验,比如Phone.Pad.大屏幕显示器.小屏幕显示器.自己模拟用css写了一下 ...

  7. Java多线程之sleep方法阻塞线程-模拟时钟

    package org.study2.javabase.ThreadsDemo.status; import java.text.SimpleDateFormat; import java.util. ...

  8. 模拟时钟(AnalogClock)

    模拟时钟(AnalogClock) 显示一个带时钟和分针的表面 会随着时间的推移变化 常用属性: android:dial 可以为表面提供一个自定义的图片 下面我们直接看代码: 1.Activity ...

  9. 巧妙使用div+css模拟表格对角线

    首先声明: 这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点.如果对此深以为然的朋友,请一笑过之... 有时在插入文档时,要用到表格对角线,常见 ...

随机推荐

  1. docker基础之镜像

    获取镜像 从 Docker Registry 获取镜像的命令是 docker pull.其命令格式为: docker pull [选项] [Docker Registry地址]<仓库名>: ...

  2. string类型用法大全

    使用标准C++中string类,要包含头文件< string > string类的构造函数 //string(const char *s); 用字符串s初始化 string s1(&quo ...

  3. Hadoop — Yarn原理解析

    1. 概述 Yarn是一个资源调度平台,负责为运算程序提供服务器运算资源,相当于一个分布式的操作系统平台:而MapReduce等运算程序则相当运行于操作系统之上的应用程序. 2. YARN的重要概念 ...

  4. es6之箭头函数

    => 箭头函数是ES6增加的函数表达式.将function关键字和函数名都删掉,并使用“=>”连接参数列表和函数体(低版本浏览器不支持) 箭头函数看上去只是语法的变动,其实也影响了this ...

  5. Ubuntu swap

    问:我是一个Ubuntu 14.04 LTS版本的新手.我需要一块额外的swap文件来提高我Ubuntu服务器的性能.我怎样才能通过SSH连接用相关命令为我的Ubuntu 14.04 LTS 增加一块 ...

  6. Java根类Object的方法说明

    Java中的Object类是所有类的父类,它提供了以下11个方法: public final native Class<?> getClass() public native int ha ...

  7. hadoop1.2.1的安装

    前提:1.机器最好都做ssh免密登录,最后在启动hadoop的时候会简单很多 免密登录看免密登录 2.集群中的虚拟机最好都关闭防火墙,否则很麻烦 3集群中的虚拟机中必须安装jdk. 具体安装步骤如下: ...

  8. IEEE LaTeX模板使用BibTeX

    IEEE LaTeX 模板使用 BibTeX 在Google Scholar获得的文献引用格式一般是BibTex的,而IEEE Transactions的模板默认用的是BibItem.目前没有什么自动 ...

  9. luogu 2569 股票交易 单调队列dp

    注意转移方程 分1.凭空买 2.不买不卖 3.在原来基础上买 4.在原来基础上卖 四种情况 head=1,tail=0;再判断一下head<=tail也可以 #include<bits/s ...

  10. nth-of-type(n)

    :nth-of-type(n) 选择器匹配属于父元素的特定类型的第 N 个子元素的每个元素. p:nth-of-type(2) { background:#ff0000; } 规定属于其父元素的第二个 ...