js+SVG实现动态时钟效果


Posted in Javascript onJuly 14, 2018

本文实例为大家分享了js+SVG实现动态时钟效果展示的具体代码,供大家参考,具体内容如下

js+SVG实现动态时钟效果

<!DOCTYPE HTML>
<html>
<meta charset="utf-8">
<head>
<title>Analog Clock</title>
<script>
function updateTime() { 
 var now = new Date();      // 当前时间
 var min = now.getMinutes();     // 分钟
 var hour = (now.getHours() % 12) + min/60; // 转行成可以在时钟上表示的时间
 var seconds = now.getSeconds();    //秒钟
 var minangle = min*6;      // 6度表示一分钟
 var hourangle = hour*30;     // 30 表示一小时
 var secrangel = seconds * 6;    // 6度表示一秒钟
 // 获取表示时钟时针的SVG元素
 var minhand = document.getElementById("minutehand");
 var hourhand = document.getElementById("hourhand");
 var secondhand = document.getElementById("secondhand");

 // 设置这些元素的SVG属性,将它们移动到钟面上
 minhand.setAttribute("transform", "rotate(" + minangle + ",50,50)");
 hourhand.setAttribute("transform", "rotate(" + hourangle + ",50,50)");
 secondhand.setAttribute("transform", "rotate(" + secrangel + ",50,50)");
 // 每秒钟更新下时钟显示时间
 setTimeout(updateTime, 1000);
}
</script>
<style>

#clock {       
 stroke: black;     
 stroke-linecap: round;   
 fill: #eef;     
}
#face { stroke-width: 2px;}  
#ticks { stroke-width: 2px; }  
#hourhand {stroke-width: 3px;} 
#minutehand {stroke-width: 2px;} 
#secondhand{stroke-width: 1px;}
#numbers {      
 font-family: sans-serif; font-size: 7pt; font-weight: bold; 
 text-anchor: middle; stroke: none; fill: black;
}
</style>
</head>
<body onload="updateTime()">
 <!-- viewBox是坐标系,width和height是指屏幕大小 -->
 <svg id="clock" viewBox="0 0 100 100" width="500" height="500"> 
 <defs> <!-- 定义下拉阴影的滤镜 -->
  <filter id="shadow" x="-50%" y="-50%" width="200%" height="200%">
  <feGaussianBlur in="SourceAlpha" stdDeviation="1" result="blur" />
  <feOffset in="blur" dx="1" dy="1" result="shadow" />
  <feMerge>
   <feMergeNode in="SourceGraphic"/><feMergeNode in="shadow"/>
  </feMerge>
  </filter>
 </defs>
 <circle id="face" cx="50" cy="50" r="45"/> <!-- 钟缅 -->
 <g id="ticks">        <!-- 12小时的刻度 -->
  <line x1='50' y1='5.000' x2='50.00' y2='10.00'/>
  <line x1='72.50' y1='11.03' x2='70.00' y2='15.36'/>
  <line x1='88.97' y1='27.50' x2='84.64' y2='30.00'/>
  <line x1='95.00' y1='50.00' x2='90.00' y2='50.00'/>
  <line x1='88.97' y1='72.50' x2='84.64' y2='70.00'/>
  <line x1='72.50' y1='88.97' x2='70.00' y2='84.64'/>
  <line x1='50.00' y1='95.00' x2='50.00' y2='90.00'/>
  <line x1='27.50' y1='88.97' x2='30.00' y2='84.64'/>
  <line x1='11.03' y1='72.50' x2='15.36' y2='70.00'/>
  <line x1='5.000' y1='50.00' x2='10.00' y2='50.00'/>
  <line x1='11.03' y1='27.50' x2='15.36' y2='30.00'/>
  <line x1='27.50' y1='11.03' x2='30.00' y2='15.36'/>
 </g>
 <g id="numbers">      <!-- 标记重要的几个刻度值-->
  <text x="50" y="18">12</text><text x="85" y="53">3</text>
  <text x="50" y="88">6</text><text x="15" y="53">9</text>
 </g>
 <!-- 初始绘制成竖直的指针,之后通过js来做旋转 -->
 <g id="hands" filter="url(#shadow)"> <!-- 给指针添加阴影 -->
  <line id="hourhand" x1="50" y1="50" x2="50" y2="25"/>
  <line id="minutehand" x1="50" y1="50" x2="50" y2="18"/>
  <line id="secondhand" x1="50" y1="50" x2="50" y2="11"/>
 </g>
 </svg>
</body>
</html>

更多JavaScript时钟特效点击查看:JavaScript时钟特效专题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
prototype1.4中文手册
Sep 22 Javascript
javascript中利用数组实现的循环队列代码
Jan 24 Javascript
iframe的父子窗口之间的对象相互调用基本用法
Sep 03 Javascript
javascript写的异步加载js文件函数(支持数组传参)
Jun 07 Javascript
c#+jquery实现获取radio和checkbox的值
Sep 12 Javascript
JS+CSS实现的拖动分页效果实例
May 11 Javascript
jquery mobile开发常见问题分析
Jan 21 Javascript
JS调用打印机功能简单示例
Nov 28 Javascript
关于vuejs中v-if和v-show的区别及v-show不起作用问题
Mar 26 Javascript
JS Generator 函数的含义与用法实例总结
Apr 08 Javascript
js实现时间日期校验
May 26 Javascript
微前端qiankun改造日渐庞大的项目教程
Jun 21 Javascript
vue实现通讯录功能
Jul 14 #Javascript
微信小程序自定义组件实现tabs选项卡功能
Jul 14 #Javascript
微信小程序scroll-view仿拼多多横向滑动滚动条
Apr 21 #Javascript
微信小程序实现自上而下字幕滚动
Jul 14 #Javascript
微信小程序scroll-view实现字幕滚动
Jul 14 #Javascript
微信小程序仿RadioGroup改变样式的处理方案
Jul 13 #Javascript
通过封装scroll.js 获取滚动条的值
Jul 13 #Javascript
You might like
php数组添加元素方法小结
2014/12/20 PHP
基于GD2图形库的PHP生成图片缩略图类代码分享
2015/02/08 PHP
PHP获取数组的键与值方法小结
2015/06/13 PHP
PHP使用观察者模式处理异常信息的方法详解
2019/09/24 PHP
jQuery 选择器理解
2010/03/16 Javascript
Function.prototype.bind用法示例
2013/09/16 Javascript
jquery实现可旋转可拖拽的文字效果代码
2016/01/27 Javascript
jquery获取复选框checkbox的值的简单实现方法
2016/05/26 Javascript
jQuery Ajax页面局部加载方法汇总
2016/06/02 Javascript
Angular Module声明和获取重载实例代码
2016/09/14 Javascript
js实现打地鼠小游戏
2017/02/13 Javascript
教你用十行node.js代码读取docx的文本
2017/03/08 Javascript
Bootstrap警告框(Alert)插件使用方法
2017/03/21 Javascript
angular内置provider之$compileProvider详解
2017/09/27 Javascript
react native 文字轮播的实现示例
2018/07/27 Javascript
JavaScript Array对象使用方法解析
2019/09/24 Javascript
浅谈Node新版本13.2.0正式支持ES Modules特性
2019/11/25 Javascript
python使用RNN实现文本分类
2018/05/24 Python
python 将json数据提取转化为txt的方法
2018/10/26 Python
Python实现的特征提取操作示例
2018/12/03 Python
python计算波峰波谷值的方法(极值点)
2020/02/18 Python
Python os模块常用方法和属性总结
2020/02/20 Python
解决 jupyter notebook 回车换两行问题
2020/04/15 Python
keras 读取多标签图像数据方式
2020/06/12 Python
python hmac模块验证客户端的合法性
2020/11/07 Python
python中if嵌套命令实例讲解
2021/02/25 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
欧舒丹美国官网:L’Occitane美国
2018/02/23 全球购物
夏洛特和乔治婴儿和儿童时装精品店:Charlotte and George
2018/06/06 全球购物
Linux上比较文件的命令都有哪些
2013/09/28 面试题
小学门卫岗位职责
2013/12/17 职场文书
小饰品店的创业计划书范文
2013/12/28 职场文书
师范学院美术系毕业生自我鉴定
2014/01/29 职场文书
党的群众路线教育实践方案
2014/05/11 职场文书
导游词之峨眉山
2019/12/16 职场文书
python自动化操作之动态验证码、滑动验证码的降噪和识别
2021/08/30 Python