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模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点.如果对此深以为然的朋友,请一笑过之... 有时在插入文档时,要用到表格对角线,常见 ...
随机推荐
- Java基础方法整理
方法 9.1方法概述 方法就是用来完成解决某件事情或实现某个功能的办法 可以通过在程序代码中引用方法名称和所需的参数,实现在该程序中执行(或称调用)该方法.方法,一般都有一个返回值,用来作为事情的处理 ...
- Kubernetes 集群ca验证
创建集群时跳过ca验证 # vim /etc/kubernetes/apiserver 去除KUBE_ADMISSION_CONTROL中的 SecurityContextDeny,ServiceAc ...
- ELK 安装与基本配置(一)
对于日志来说,最常见的需求就是收集.存储.查询.展示,开源社区正好有相对应的开源项目:logstash(收集).elasticsearch(存储+搜索).kibana(展示),我们将这三个组合起来的技 ...
- java-Array数组常用操作例子(基础必备)
package com.net.xinfang.reflect; import java.util.ArrayList; import java.util.Arrays; import java.ut ...
- WebAPI性能优化之压缩解压
有时候为了提升WebAPI的性能,减少响应时间,我们会使用压缩和解压,而现在大多数客户端浏览器都提供了内置的解压支持.在WebAPI请求的资源越大时,使用压缩对性能提升的效果越明显,而当请求的资源很小 ...
- 阿里云部署Web项目
1.首先最基本的购买服务器和域名(学生党可以享受每月9块钱的优惠,不知道为什么,pc端不能购买,只能下载阿里云APP购买) 下载APP后打开:学生专区-学生特权-购买(我选择的是ubuntu,这个随 ...
- 属性集合java.util.Properties
属性集合java.util.Properties java.util.Properties集合 extends Hashtable<k, v> implements Map<k, v ...
- EFCodeFirst示例
1.定义一个基础模板类 namespace WebApplication1.Models { /// <summary> /// 可持久到数据库的领域模型的基类. /// </sum ...
- php与java通用AES加密解密算法
AES指高级加密标准(Advanced Encryption Standard),是当前最流行的一种密码算法,在web应用开发,特别是对外提供接口时经常会用到,下面是我整理的一套php与java通用的 ...
- Kali Linux之使用SET快捷生成钓鱼网站方法
SET (Social Engineering Tools) 1.使用命令:setoolkit 会显示工具菜单 2.输入1 ,选择菜单中的Social-Engineering Attacks (社会工 ...