今天,带来的是使用HTML5中Canvas标签实现的动态时钟效果。

  话不多说,先看效果:亲,请点击这里

  众所周知,Canvas标签是HTML5中的灵魂,HTML5 Canvas是屏幕上的一个由JavaScript控制的即时模式位图区域。即时模式是指在画布上呈现像素的方式,

  HTML5 Canvas通过JavaScript调用CanvasAPI,在每一帧完全重绘屏幕上的位图。详细将在下面代码进行说明。

  HTML结构代码:

     <canvas id="canvas" width="500" height="500">
您的浏览器不支持Canavas标签,请升级浏览器再查看此页面!
</canvas>

  CSS样式代码:

     <style type="text/css">
*{margin:0px;padding:0px;}
.canvasbox{margin:50px auto;background:#dadada;width:500px;}
</style>

  JS脚本代码:

 <script type="text/javascript">
var canvas = document.getElementById("canvas");
//获取Canvas的2d上下文对象
var context = canvas.getContext("2d"); //定义一个初始化函数
function init(){
//先清除画布上的所有图像
context.clearRect(0,0,500,500); //获取系统时间
var date = new Date();
var hours = date.getHours();
//因为钟表是12小时制,所以必须对时刻度进行控制
hours = hours > 12 ? hours-12 : hours;
var minutes = date.getMinutes();
var seconds = date.getSeconds(); //开始画表盘
context.beginPath();
//在画布中心250,250点上画一个圆
context.arc(250,250,200,0,360,false);
//定义画笔的宽度
context.lineWidth = 10;
//定义画笔颜色
context.strokeStyle = "#000";
//关闭绘画路径
context.closePath();
//上色
context.stroke(); //开始画刻度
//时刻度
for(var h = 0;h < 12;h++){
//先将图像进行保存
context.save();
context.lineWidth = 8;
context.strokeStyle = "#f00";
//定义旋转中心点
context.translate(250,250);
//定义旋转角度
context.rotate(h*30*Math.PI/180);
context.beginPath();
context.moveTo(0,190);
context.lineTo(0,170);
context.closePath();
context.stroke();
//将之前的保存的图像显示,形成新的图像
context.restore();
}
//分刻度
for(var m = 0;m < 60;m++){
context.save();
context.lineWidth = 4;
context.strokeStyle = "red";
context.translate(250, 250);
context.rotate(m*6*Math.PI/180);
context.beginPath();
context.moveTo(0, 190);
context.lineTo(0, 180);
context.closePath();
context.stroke();
context.restore();
} //画时针
context.save();
context.lineWidth = 8;
context.strokeStyle = "#000";
context.translate(250,250);
context.rotate(hours*30*Math.PI/180);
context.beginPath();
context.moveTo(0,10);
context.lineTo(0,-100);
context.closePath();
context.stroke();
context.restore(); //画分针
context.save();
context.lineWidth = 4;
context.strokeStyle = "#000";
context.translate(250,250);
context.rotate(minutes*6*Math.PI/180);
context.beginPath();
context.moveTo(0,10);
context.lineTo(0,-140);
context.closePath();
context.stroke();
context.restore(); //画秒针
context.save();
context.lineWidth = 2;
context.strokeStyle = "blue";
context.translate(250,250);
context.rotate(seconds*6*Math.PI/180);
context.beginPath();
context.moveTo(0,10);
context.lineTo(0,-170);
context.closePath();
context.stroke();
context.restore();
}
//调用定时器,在每秒刷新重绘新图像
setInterval(init,1000);
</script>

  其中,蕴含着一个小BUG。在绘画时刻度和分刻度时,若颜色不一时,会出现重叠现象,因为在绘画时刻度后,再进行绘画分刻度,故小编将两刻度颜色设置为一致,避免该现象产生。当然,也可以通过判断去进行处理,小编就不在此进行处理。

  在浏览该效果时,请使用支持HTML5的浏览器,以免影响浏览效果。

  享受代码,享受生活,网页效果,每日一更。

HTML5之Canvas时钟(网页效果--每日一更)的更多相关文章

  1. CSS3之图片3D翻转效果(网页效果--每日一更)

    今天,带来的是纯CSS3的效果--图片3D翻转. 请看效果:亲,请点击这里 这个效果主要还是运用了CSS3的transform变形属性,与上个效果不同的是,这次并不是动画,所以没有采用animatio ...

  2. CSS3之绽放的花朵(网页效果--每日一更)

    今天,带来的是纯CSS3打造的效果--绽放的花朵. 先来看效果吧:亲,请点击这里 这是纯CSS3样式打造的效果,关键是采用了animation属性和transform属性.详细请看下面代码. HTML ...

  3. JQuery图片轮播滚动效果(网页效果--每日一更)

    今天,带来的是一个图片的轮播滚动效果! 先来看一下效果展示:亲,请点击这里 原理很简单,设置一个定时器,使图片列表在每隔一段时间后滚动一次.而循环效果,就是在每一滚动的时候,将第一张图片放到最后一张的 ...

  4. 【HTML5】Canvas 实现放大镜效果

    图片放大镜 效果 在线演示    源码 原理 首先选择图片的一块区域,然后将这块区域放大,然后再绘制到原先的图片上,保证两块区域的中心点一致, 如下图所示: 初始化 <canvas id=&qu ...

  5. 用户从手机的浏览器访问www.baidu.com,看到的可能跟桌面PC电脑,是不太一样的网页效果,会更适合移动设备使用。请简要分析一下,实现这种网页区分显示的原因及技术原理。

    手机的网速问题.屏幕大小.内存.CPU等.通过不同设备的特征,实现不同的网页展现或输出效果.根据useragent.屏幕大小信息.IP.网速.css media Query等原理,实现前端或后端的特征 ...

  6. HTML5在canvas中绘制复杂形状附效果截图

    HTML5在canvas中绘制复杂形状附效果截图 一.绘制复杂形状或路径 在简单的矩形不能满足需求的情况下,绘图环境提供了如下方法来绘制复杂的形状或路径. beginPath() : 开始绘制一个新路 ...

  7. 基于HTML5 Canvas的网页画板实现教程

    HTML5的功能非常强大,尤其是Canvas的应用更加广泛,Canvas画布上面不仅可以绘制任意的图形,而且可以实现多种多样的动画,甚至是一些交互式的应用,比如网页网版.这次我们要来看的就是一款基于H ...

  8. 那些不错的 [ Html5 + CSS3 + Canvas ] 效果!

    apng制作工具:http://isparta.github.io/how.html apng制作文章:http://isux.tencent.com/introduction-of-apng.htm ...

  9. HTML5应用之时钟

    利用HTML5的Canvas API可以完成我们以前意想不到的动画效果,以前我们想在网页上放置一个时钟,需要先用flash工具制作一个钟表,并写上复杂的JavaScript代码,然后载入到页面中.而H ...

随机推荐

  1. MVC5+EF6 简易版CMS(非接口) 第四章:使用业务层方法,以及关联表解决方案

    目录 简易版CMS后台管理系统开发流程 MVC5+EF6 简易版CMS(非接口) 第一章:新建项目 MVC5+EF6 简易版CMS(非接口) 第二章:建数据模型 MVC5+EF6 简易版CMS(非接口 ...

  2. codeforces 446C DZY Loves Fibonacci Numbers 线段树

    假如F[1] = a, F[2] = B, F[n] = F[n - 1] + F[n - 2]. 写成矩阵表示形式可以很快发现F[n] = f[n - 1] * b + f[n - 2] * a. ...

  3. iOS动画实现改变frme和contenOffset

    [UIView beginAnimations:nil context:nil];    [UIView setAnimationDuration:0.4];    [UIView setAnimat ...

  4. Neutron Kilo-Liberty-Mitaka各版本区别

    http://blog.csdn.net/bc_vnetwork/article/details/51848623

  5. 新手看Mockplus

    如今是一个快节奏的社会,每一天都会有无数的软件发布,每一款软件的制作过程不可避免的需要使用原型设计工具.而Mockplus就是一款原型设计软件,可以用于移动端,PC端以及WEB的原型设计.它也符合如今 ...

  6. mysql Statement violates GTID consistency 的坑

    今天项目迁移,重新换了一个数据库版本,然后问题来了,原本运行正常的程序迁移过来之后就是不能正常运行,后台报错如下: update tbl_user_info set -- 强制下架 mv_count ...

  7. 手动获取酷我Mp3外链

    素材→http://player.kuwo.cn/webmusic/st/getNewMuiseByRid?rid=MUSIC_随便找一首歌http://www.kuwo.cn/yinyue/1034 ...

  8. python subprocess 自动运行实验室程序

    import threading, os, subprocess, time exec_path = "/home/xhz/gems/ruby/amd...../bin/tester.exe ...

  9. kinect driver install (ubuntu 14.04 & ros-indigo)

    kinect driver 安装过程: 1.在ubuntu上安装kinect驱动比较繁琐,需要安装以下3个驱动包, OpenNI-Bin-Dev-Linux-x64-v1.5.7.10 NITE-Bi ...

  10. vuejs 和 element 搭建的一个后台管理界面

    介绍: 这是一个用vuejs2.0和element搭建的后台管理界面. 相关技术: vuejs2.0:渐进式JavaScript框架,易用.灵活.高效,似乎任何规模的应用都适用. element:基于 ...