昨天,有一天招,宽带到底没装上。相当恼火,不过包了一天租新房,有很多想法下来,其中,率先实现了--动态时钟(它已上载的资源,一些粗略的全貌。汗...)

这里记录。这个看似简单的功能,以达到良好的,我在的实施过程中遇到了哪些问题。代码,仅仅是依据自己现阶段的学习来做的,可能会有些麻烦。有些粗糙,可是终归是实现了这个效果,心里还是小开心了下。

先来张终于实现的效果图(静态图片);

首先准备素材,我从网上搜到了一个时钟的素材,谁让我的ps还菜的菜呢。然后我有了表盘、时针、分针和秒针。这样组成一个闹钟的基本元素就全了。

然后就是对素材的放置。这里是解决的第一个问题,尽管是自找的问题,(我将它放在了页面中间)

**********css实现居中*******

来看一下实现的代码;

html部分

 <div id="back">
<img src="back.jpg" width="600px" height="600px">
</div>

然后是对样式的设置:

 #back{
top:50%;
left:50%;
margin-left:-300px;
margin-top:-300px;
position:absolute;
z-index:1;
}

这里是设置固定位置,这时候设定的left和top是相比較左上角的点来进行描写叙述的,之后将margin-left和margin-top分别设置成该div(这里表现为back的div)的长、宽的一半就可以

之后进行的是分针秒针和时针的放置。这里须要考虑两个问题:1、三个针都设为固定位置,而且转动的点要确定,分层层级要明显。2、实现绕固定点的转动(这个是比較纠结的地方)

*******************绕固定点转动

提及转动,在前面我们曾实现过仅仅要css要div动起来,这里实现的基本原理也是一样。这样我们就能够用transform:rotate(---deg)。于是我就用这个进行转动,结果我发现我无法让图片在固定点上转动,它仅仅能以div自身的中心进行转动。那这该怎样办,困惑好久之后,终于我想了一个办法,既然中心是固定的,那我就把想要绕之转动的那个固定点放在中心上。不就能够生成绕固定点转动的假象了么,至于还有一半的部分。我将底色该为与表盘颜色同样,而且设置透明度opacity为最大值。实现全然透明,于是就有了以下的编码:

html部分:

<div id="miao" style="height:320px;background:#fff;width:20px;-moz-opacity:1;">
<div style="height:30px;width:20px;opacity:1;"></div>
<div>
<img src="miao320.jpg" height="180px">
</div>
</div>
<div id="fen" style="height:320px;background:#fff;width:20px;-moz-opacity:1;">
<div style="height:20px;width:20px;"></div>
<img src="fen32035.jpg" height="180px">
</div>
<div id="shi" style="height:320px;background:#fff;width:20px;-moz-opacity:1;">
<div style="height:30px;width:20px;"></div>
<img src="shi32035.jpg" height="175px">
</div>

这里由于图片改的有些粗糙,所以设定的距离不同,看css的样式设置:

  #miao{
top:50%;
left:50%;
margin-top:-140px;
margin-left:-10px;
position:absolute;
z-index:2;
}
#fen{
top:50%;
left:50%;
margin-top:-140px;
margin-left:-5px;
position:absolute;
z-index:3;
}
#shi{
top:50%;
left:50%;
margin-top:-140px;
margin-left:-5px;
position:absolute;
z-index:4;

最后就是利用js动态改变旋转的角度,来看以下的实现方法:

<script type="text/javascript">
window.onload=function(){
var miao=document.getElementById("miao");
var fen=document.getElementById("fen");
var shi=document.getElementById("shi");
var hour;//当前时
var minute;//当前分
var second;//当前秒
var circleHour;//时针转动的角度
var circleMinute;//分针转动的角度
var circleSecond;//秒针转动的角度 var cycle=setInterval(function(){
var nowDate=new Date();//每次读取当前时间
hour=nowDate.getHours();
circleHour=(parseInt(hour)%12)*30;
shi.style.transform="rotate("+circleHour+"deg)";//读取到的时间为24小时制,转换为12小时
minute=nowDate.getMinutes();
fen.style.transform="rotate("+parseInt(minute)*6+"deg)";
second=nowDate.getSeconds();
miao.style.transform="rotate("+parseInt(second)*6+"deg)";
},1000);//每1000毫秒调用一次方法
}
</script>

这样来看,效果就出来了。尽管有些粗糙,可是还是让我开心不已,至于角度的获取都是些基础的思路了,就不多赘述了。

这样感觉起来,确实东西没用多少,为什么刚開始在做的时候柑感觉那么难的..........

版权声明:本文博客原创文章,博客,未经同意,不得转载。

js+css3动态时钟-------Day66的更多相关文章

  1. 史上最简单的js+css3实现时钟效果

    今天我看到百度搜索的时间那个效果不错,于是就产生了模仿一下的效果,不过为了节省时间,就随便布了下局,废话不多说,先看看效果吧,顺便把百度的效果也拿过来. 对比样子差了好多啊,但是基本功能都是实现了的, ...

  2. 用js写动态时钟 2017-03-23

    45每隔1秒变一次: 代码如下: <body onLoad="show()" >   ------------表示当页面载入时执行该事件,可以没有 <div id ...

  3. 原生JS实现动态时钟(优化)

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  4. 环形进度条的实现方法总结和动态时钟绘制(CSS3、SVG、Canvas)

    缘由: 在某一个游戏公司的笔试中,最后一道大题是,“用CSS3实现根据动态显示时间和环形进度[效果如下图所示],且每个圆环的颜色不一样,不需要考虑IE6~8的兼容性”.当时第一想法是用SVG,因为SV ...

  5. js 动态时钟

    js 动态时钟 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ...

  6. CSS3_过渡_2D 变换_瓶体旋转_动态时钟

    1. 过渡 transition 允许 CSS 的属性值在一定时间内平滑的过渡, 在鼠标点击,鼠标滑过或对属性改变中触发,并圆滑的改变 CSS 的属性值 简写属性: #box { width: 300 ...

  7. 基于CSS3动态背景登录框代码

    基于CSS3动态背景登录框代码.这是一款基于jQuery+CSS3实现的带有动画效果的动态背景登陆框特效.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class ...

  8. JS框架_(JQbar.js)柱状图动态百分比进度条特效

    百度云盘 传送门 密码:q6rt 柱状图动态百分比进度条效果 <html> <head> <title>jqbar.js柱状图动态百分比进度条特效</titl ...

  9. 从零开始手把手教你使用原生JS+CSS3实现幸运水果机游戏

    项目体验地址 免费视频教程 游戏介绍 幸运水果机是一款街机游戏,游戏界面由24个方格拼接成一个正方形,每个方格中都有一个不同的水果图形,方格下都有一个小灯.玩家使用游戏币选择希望押注的目标,按下开始后 ...

随机推荐

  1. MVC常用特性

    MVC常用特性使用   简介 在以前的文章中,我和大家讨论如何用SingalR和数据库通知来完成一个消息监控应用. 在上一篇文章中,我介绍了如何在MVC中对MongoDB进行CRUD操作. 今天,我将 ...

  2. Codeforces 338D GCD Table 中国剩余定理

    主题链接:点击打开链接 特定n*m矩阵,[i,j]分值为gcd(i,j) 给定一个k长的序列,问能否匹配上 矩阵的某一行的连续k个元素 思路: 我们要求出一个解(i,j) 使得 i<=n &am ...

  3. java假设去请求一个网页的数据

    我们能够通过在java程序中模拟浏览器一样,把数据抓下来,详细方法是在java程序中set header和cookie,以下是一个样例: public class NetConnection { pu ...

  4. ftk学习记录(形成全屏幕套件)

    [声明:版权全部.欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 好久不写博客了.今天续上. 可是,我们还是看一下上一期的执行结果, watermark/2/te ...

  5. Atitit。团队建设--管理最佳实践--如何留住关键人才,防止人才外流 ??

    Atitit.团队建设--管理最佳实践--怎样留住核心人才,防止人才流失 ?? 1. 1.人才流失后果 1 1. 1.员工的离职带走商业技术秘密和客户等资源 1 2. 2.影响在职员工的情绪.极大挫伤 ...

  6. [linux]scp指令(转)

    Linux scp命令用于Linux之间复制文件和目录,具体如何使用这里好好介绍一下,从本地复制到远程.从远程复制到本地是两种使用方式.这里有具体举例: ================== Linu ...

  7. socket-详细分析No buffer space available(转)

    新年上班第一天,突然遇到一个socket连接No buffer space available的问题,导致接口大面积调用(webservice,httpclient)失败的问题,重启服务器后又恢复了正 ...

  8. FastJson基本使用

    在发展中Android的过程中.假设我们常与server联系,更新数据等,然后,json它必须是一个良好的数据格公式,但随着json.使用原生的解析也能够,可是非常不高效,所以这里介绍两种json数据 ...

  9. CSDN markdown 编辑 第五章 UML

    这里大概只能产生两种类型的图: 序列图 框图 序列图 ```sequence A->B: 一句话证明你非常寂寞. Note right of B: thinking B->B: count ...

  10. adb这点小事——远程adb调试

    欢迎转载.转载请注明:http://blog.csdn.net/zhgxhuaa 1.   前言 1.1.  写在前面的话 在之前的一篇文章<360电视助手实现研究>中介绍了在局域网内直接 ...