css模拟时钟
思路:
画时钟数字(x,y)坐标
x = x0 + r*cos(deg)
y = y0 + r*sin(deg)
知识点:
- 创建元素: createElement
- 添加元素: appendChild
- css3旋转: transform:rotate(30deg);
- css3改变旋转中心点: transform-origin:0 0;
- 获取当前时间, 把时间数字转换为度数
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- <style>
- * { margin: 0; padding: 0; }
- #bg {
- width: 400px;
- height: 400px;
- background: #ddd;
- border-radius: 10px;
- /* div上下左右垂直居中 */
- position: absolute;
- left: 50%;
- top: 50%;
- margin-top: -200px;
- margin-left: -200px;
- }
- #bg #clock {
- width: 360px;
- height: 360px;
- background: #fff;
- border-radius: 50%;
- display: inline-block;
- margin: 20px;
- position: relative;
- }
- #hour {
- width: 70px;
- height: 16px;
- background: #000;
- position: absolute;
- left: 180px;
- top: 172px;
- border-radius: 16px;
- transform-origin:0 8px;
- }
- #minute {
- width: 120px;
- height: 12px;
- background: #000;
- position: absolute;
- left: 180px;
- top: 174px;
- border-radius: 12px;
- transform-origin:0 6px;
- }
- #second {
- width: 140px;
- height: 6px;
- background: #f00;
- position: absolute;
- left: 180px;
- top: 177px;
- border-radius: 6px;
- transform-origin:0 1px;
- /*transform:rotate(30deg);*/
- /*animation: clockRotate 3s linear infinite;*/
- }
- @keyframes clockRotate {
- from {transform:rotate(0deg);}
- to {transform:rotate(360deg);}
- }
- #point{
- width: 30px;
- height: 30px;
- border-radius: 50%;
- background: #000;
- position: absolute;
- left: 50%;
- top: 50%;
- margin: -15px 0 0 -15px;
- }
- #clock .number{
- position: absolute;
- font-size: 28px;
- width: 50px;
- height: 50px;
- line-height: 50px;
- text-align: center;
- }
- </style>
- </head>
- <body>
- <div id="bg">
- <div id="clock">
- <div id="hour"></div>
- <div id="minute"></div>
- <div id="second"></div>
- <div id="point"></div>
- </div>
- </div>
- <script>
- var clock = document.getElementById('clock');
- var r = 150;
- var angle = Math.PI * 2; // 2PI = 360°
- for (var i = 1; i <=12; i++) {
- var deg = angle/12 * i - Math.PI/2;
- var x = r + r*Math.cos(deg);
- var y = r + r*Math.sin(deg);
- //console.log(x,y);
- var num = document.createElement('div');//创建div
- num.className = 'number';//设置class样式
- num.innerText = i;
- //设置坐标
- num.style.top = y + 'px';
- num.style.left = x + 'px';
- //添加
- clock.appendChild(num);
- }
- //TODO 1. 数字转换度数
- function run() {
- var date = new Date();
- //时(0-23) 分(0-59)秒(0-59)
- var hour = date.getHours();
- var minute = date.getMinutes();
- var second = date.getSeconds();
- var hourDeg = 360/12 * hour - 90;
- var minuteDeg = 360/60 * minute - 90;
- var secondDeg = 360/60 * second - 90;
- var hourDiv = document.getElementById('hour');
- var minuteDiv = document.getElementById('minute');
- var secondDiv = document.getElementById('second');
- hourDiv.style.transform = 'rotate('+hourDeg+'deg)';
- minuteDiv.style.transform = 'rotate('+minuteDeg+'deg)';
- secondDiv.style.transform = 'rotate('+secondDeg+'deg)';
- }
- //TODO 2. 设置定时器
- run();
- setInterval(function () {
- run();
- },1000);
- </script>
- </body>
- </html>
css模拟时钟的更多相关文章
- 【CSS3】纯CSS代码实现模拟时钟,+js对时功能。
使用CSS3纯代码来实现模拟时钟,及指针动画功能. 在这里主要使用到css3一些基本元素: border-radius:圆角边框,画圆形:表盘 Transform:变换,旋转,扭曲:刻度盘,指针形状 ...
- 纯js+html+css实现模拟时钟
前几天没事写的个模拟时钟,代码仅供小白参考,大神请自动绕过. <!DOCTYPE html> <html lang="en"> <head> & ...
- 一个模拟时钟的时间选择器 ClockPicker
最近开发的一个模拟时钟的时间选择器 ClockPicker,用于 Bootstrap,或者单独作为一个 jQuery 插件. 源代码托管在 GitHub 上: ClockPicker 最近项目中需要用 ...
- 模拟时钟(AnalogClock)和数字时钟(DigitalClock)
Demo2\clock_demo\src\main\res\layout\activity_main.xml <LinearLayout xmlns:android="http://s ...
- android脚步---数字时钟和模拟时钟
时钟UI组件是两个非常简单的组件,分为Digitalclock 和Analogclock, main.xml文件,书中程序有问题,加了两个组件,一个Button和一个<Chronometer ...
- css模拟Bootstrap响应式布局——栅格
做作业的时候遇见用css模拟Bootstrap的栅格布局,学习了一下.发现这个很有用,用来在不同的平台上得到很好地用户体验,比如Phone.Pad.大屏幕显示器.小屏幕显示器.自己模拟用css写了一下 ...
- Java多线程之sleep方法阻塞线程-模拟时钟
package org.study2.javabase.ThreadsDemo.status; import java.text.SimpleDateFormat; import java.util. ...
- 模拟时钟(AnalogClock)
模拟时钟(AnalogClock) 显示一个带时钟和分针的表面 会随着时间的推移变化 常用属性: android:dial 可以为表面提供一个自定义的图片 下面我们直接看代码: 1.Activity ...
- 巧妙使用div+css模拟表格对角线
首先声明: 这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点.如果对此深以为然的朋友,请一笑过之... 有时在插入文档时,要用到表格对角线,常见 ...
随机推荐
- TF报错解决
一.import tensorflow #h5py/__init__.py:34: FutureWarning: Conversion of the second argument of issubd ...
- I/O模型之四:Java 浅析I/O模型(BIO、NIO、AIO、Reactor、Proactor)
目录: <I/O模型之一:Unix的五种I/O模型> <I/O模型之二:Linux IO模式及 select.poll.epoll详解> <I/O模型之三:两种高性能 I ...
- python 计算机发展史,线程Process使用 for循环创建 2种传参方式 jion方法 __main__的解释
########################总结################## #一 操作系统的作用: 1:隐藏丑陋复杂的硬件接口,提供良好的抽象接口 2:管理.调度进程,并且将多个进程对硬 ...
- SQL Server2012安装流程
今天手比较抽风,把原来的SQL Server给卸载了,卸载还卸了半天,真是…… 安装时找了好多教程,结果都不是很详细,然后准备自己摸索一下,把这个过程记录下来,供大家参考,如果有不当的地方,欢迎指正, ...
- SpringBoot常用注解使用
1.RequestBody和ResponseBody注解 @RequestMapping(“url”),这里的 url写的是请求路径的一部分,一般作用在 Controller的方法上,作为请求的映射地 ...
- luogu 2051 中国象棋
非常好的dp,锻炼思维 f[i][j][k] 前i行有j列放1,k列放2 #include<bits/stdc++.h> #define int long long #define rep ...
- oracle 任务备份
@echo offset hour=%time:~,2%if "%time:~,1%"==" " set hour=0%time:~1,1%set temp=% ...
- Java SE之I/O流:知识框架
- Coursera, Deep Learning 1, Neural Networks and Deep Learning - week4, Deep Neural Networks
Deep Neural Network Getting your matrix dimention right 选hyper-pamameter 完全是凭经验 补充阅读: cost 函数的计算公式: ...
- Python读取导入非安装文件库的方法
一.将文件库放到和.py文件同一目录下: 二..py文件头导入文件库的格式为(以导入CIFAR-10数据的类为例)[其实就在文件库前面加个.]: from .cifar10 import cifar1 ...