<!DOCTYPE html>
 <html>
 <head lang="en">
     <meta charset="UTF-8">
     <title>炫彩时钟</title>

     <style>
         body{ background:#000;}
         canvas{ background:#fff; }
     </style>

     <script src="countdown.js"></script>
     <script src="digit.js"></script>
 </head>
 <body>
     <canvas id="canvas1"></canvas>
 </body>
 </html>
 digit =
     [
         [
             [0,0,1,1,1,0,0],
             [0,1,1,0,1,1,0],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,0,1,1,0],
             [0,0,1,1,1,0,0]
         ],
         [
             [0,0,0,1,1,0,0],
             [0,1,1,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [1,1,1,1,1,1,1]
         ],
         [
             [0,1,1,1,1,1,0],
             [1,1,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,0,0],
             [0,0,1,1,0,0,0],
             [0,1,1,0,0,0,0],
             [1,1,0,0,0,0,0],
             [1,1,0,0,0,1,1],
             [1,1,1,1,1,1,1]
         ],
         [
             [1,1,1,1,1,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,0,0],
             [0,0,1,1,1,0,0],
             [0,0,0,0,1,1,0],
             [0,0,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,1,1,0]
         ],
         [
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,1,0],
             [0,0,1,1,1,1,0],
             [0,1,1,0,1,1,0],
             [1,1,0,0,1,1,0],
             [1,1,1,1,1,1,1],
             [0,0,0,0,1,1,0],
             [0,0,0,0,1,1,0],
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,1,1]
         ],
         [
             [1,1,1,1,1,1,1],
             [1,1,0,0,0,0,0],
             [1,1,0,0,0,0,0],
             [1,1,1,1,1,1,0],
             [0,0,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,1,1,0]
         ],
         [
             [0,0,0,0,1,1,0],
             [0,0,1,1,0,0,0],
             [0,1,1,0,0,0,0],
             [1,1,0,0,0,0,0],
             [1,1,0,1,1,1,0],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,1,1,0]
         ],
         [
             [1,1,1,1,1,1,1],
             [1,1,0,0,0,1,1],
             [0,0,0,0,1,1,0],
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,0,0],
             [0,0,0,1,1,0,0],
             [0,0,1,1,0,0,0],
             [0,0,1,1,0,0,0],
             [0,0,1,1,0,0,0],
             [0,0,1,1,0,0,0]
         ],
         [
             [0,1,1,1,1,1,0],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,1,1,0],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,1,1,0]
         ],
         [
             [0,1,1,1,1,1,0],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [1,1,0,0,0,1,1],
             [0,1,1,1,0,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,0,1,1],
             [0,0,0,0,1,1,0],
             [0,0,0,1,1,0,0],
             [0,1,1,0,0,0,0]
         ],
         [
             [0,0,0,0],
             [0,0,0,0],
             [0,1,1,0],
             [0,1,1,0],
             [0,0,0,0],
             [0,0,0,0],
             [0,1,1,0],
             [0,1,1,0],
             [0,0,0,0],
             [0,0,0,0]
         ]//:
     ];
 /**
  * Created by dell on 2016/1/29.
  */
 window.onload = function(){
     var CVS_WIDTH = document.body.clientWidth * 4/5;
     var CVS_HEIGHT = document.body.clientHeight * 4/5;
     var MARGIN_LEFT = document.body.clientWidth * 1/10;
     var MARGIN_TOP = document.body.clientHeight * 1/10;
     var RADIUS = (CVS_WIDTH*4/5)/108 - 1;
     var PADDINGLEFT = (CVS_WIDTH - 108*(RADIUS+1))/2;
     var color = '#00688B';//数字颜色
     var curShowTime = getCurShowTime();//当前剩余时间
     var colors = ['#FF3030','#7CCD7C','#0000EE','#EE9A49','#EEEE00','#FF00FF','#96CDCD','#D15FEE','#EEAEEE','#EEDC82'];//彩球颜色集合
     var balls = [];

     var oCvs = document.getElementById('canvas1');
     var oCxt = oCvs.getContext('2d');

     //设置画布大小
     oCvs.width = CVS_WIDTH;
     oCvs.height = CVS_HEIGHT;
     oCvs.style.marginLeft = MARGIN_LEFT + 'px';
     oCvs.style.marginTop = MARGIN_TOP + 'px';

     setInterval(function () {
         render(oCxt);
         update();
     },50);

 function update(){
     var nextShowTime = getCurShowTime();

     var nextHour = parseInt(nextShowTime/3600);
     var nextMin = parseInt((nextShowTime - nextHour*3600)/60);
     var nextSec = parseInt(nextShowTime%60);

     var curHour = parseInt(curShowTime/3600);
     var curMin = parseInt((curShowTime - curHour*3600)/60);
     var curSec = parseInt(curShowTime%60);

     if(nextSec != curSec){
         curShowTime = nextShowTime;

         if(parseInt(nextHour/10) != parseInt(curHour/10)){
             addBalls(PADDINGLEFT,MARGIN_TOP,parseInt(nextSec/10));
         }
         if(parseInt(nextHour%10) != parseInt(curHour%10)){
             addBalls(PADDINGLEFT+15*(RADIUS+1),MARGIN_TOP,parseInt(nextSec%10));
         }
         if(parseInt(nextMin/10) != parseInt(curMin/10)){
             addBalls(PADDINGLEFT+40*(RADIUS+1),MARGIN_TOP,parseInt(nextSec/10));
         }
         if(parseInt(nextMin%10) != parseInt(curMin%10)){
             addBalls(PADDINGLEFT+55*(RADIUS+1),MARGIN_TOP,parseInt(nextSec%10));
         }
         if(parseInt(nextSec/10) != parseInt(curSec/10)){
             addBalls(PADDINGLEFT+79*(RADIUS+1),MARGIN_TOP,parseInt(nextSec/10));
         }
         if(parseInt(nextSec%10) != parseInt(curSec%10)){
             addBalls(PADDINGLEFT+94*(RADIUS+1),MARGIN_TOP,parseInt(nextSec%10));
         }
         //console.info(balls)
     }
     updateBalls();
     //console.info(balls.length)
 }

 function updateBalls(){
     for(var i=0;i<balls.length;i++) {
         balls[i].x += balls[i].xv;
         balls[i].y += balls[i].yv;
         balls[i].yv += balls[i].g;

         if(balls[i].y >= CVS_HEIGHT-RADIUS){
             balls[i].y = CVS_HEIGHT - RADIUS;
             balls[i].yv = -balls[i].yv*0.75;
         }
     }
     var num = 0;
     for(var j=0;j<balls.length;j++){
         if(balls[j].x+RADIUS>0 && balls[j].x-RADIUS<CVS_WIDTH){
             balls[num++] = balls[j];
         }
     }

     balls = balls.slice(0,Math.min(500,num));

 }

 function addBalls(x,y,num){
     for(var i=0;i<digit[num].length;i++){
         for(var j=0;j<digit[num][i].length;j++){
             if(digit[num][i][j] == 1){
                 var ball = {
                     x:x+j*2*(RADIUS+1)+(RADIUS+1),
                     y:y+i*2*(RADIUS+1)+(RADIUS+1),
                     color:colors[Math.floor(Math.random()*colors.length)],
                     g:1.5+Math.random(),
                     xv:Math.pow(-1,Math.ceil(Math.random()*1000))*4,
                     yv:-10
                 };
                 balls.push(ball);
             }
         }
     }
 }

 function getCurShowTime(){
     var date = new Date();
     var ret = date.getHours()*3600 + date.getMinutes()*60 + date.getSeconds();

     return ret;

 }

 function render(cxt){
     var hour = parseInt(curShowTime/3600);
     var min = parseInt((curShowTime - hour*3600)/60);
     var sec = parseInt(curShowTime%60);

     cxt.clearRect(0,0,CVS_WIDTH,CVS_HEIGHT);
     renderDigit(cxt,PADDINGLEFT,MARGIN_TOP,parseInt(hour/10));
     renderDigit(cxt,PADDINGLEFT+15*(RADIUS+1),MARGIN_TOP,parseInt(hour%10));
     renderDigit(cxt,PADDINGLEFT+31*(RADIUS+1),MARGIN_TOP,10);
     renderDigit(cxt,PADDINGLEFT+40*(RADIUS+1),MARGIN_TOP,parseInt(min/10));
     renderDigit(cxt,PADDINGLEFT+55*(RADIUS+1),MARGIN_TOP,parseInt(min%10));
     renderDigit(cxt,PADDINGLEFT+70*(RADIUS+1),MARGIN_TOP,10);
     renderDigit(cxt,PADDINGLEFT+79*(RADIUS+1),MARGIN_TOP,parseInt(sec/10));
     renderDigit(cxt,PADDINGLEFT+94*(RADIUS+1),MARGIN_TOP,parseInt(sec%10));

     for(var i=0;i<balls.length;i++){
         cxt.fillStyle = balls[i].color;
         cxt.beginPath();
         cxt.arc(balls[i].x,balls[i].y,RADIUS,0,2*Math.PI);
         cxt.closePath();
         cxt.fill();
     }
 }

 function renderDigit(cxt,x,y,num){
     cxt.fillStyle = color;
     for(var i=0;i<digit[num].length;i++){
         for(var j=0;j<digit[num][i].length;j++){
             if(digit[num][i][j] == 1){
                 cxt.beginPath();
                 cxt.arc(x+j*2*(RADIUS+1)+(RADIUS+1),y+i*2*(RADIUS+1)+(RADIUS+1),RADIUS,0,2*Math.PI);
                 cxt.closePath();
                 cxt.fill();
             }
         }
     }

 }

 }

实例出处:慕课网http://www.imooc.com/,喜欢的朋友可以到慕课网搜索学习哦~

HTML5自学笔记[ 19 ]canvas绘图实例之炫彩时钟的更多相关文章

  1. HTML5自学笔记[ 15 ]canvas绘图实例之钟表

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

  2. HTML5自学笔记[ 21 ]canvas绘图实例之马赛克

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  3. HTML5自学笔记[ 20 ]canvas绘图实例之绘制倒影

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  4. HTML5自学笔记[ 13 ]canvas绘图小实例之方块移动

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

  5. HTML5自学笔记[ 12 ]canvas绘图小示例之鼠标画线

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

  6. HTML5自学笔记[ 11 ]canvas绘图基础1

    html5新增<canvas>标签用于绘制图像,默认宽高是300*150,canvas的宽高需要在这里设置,在css中设置会有问题:设置的形状,如矩形,会等比缩放,而非设置的宽高. 在不支 ...

  7. HTML5自学笔记[ 24 ]canvas绘图之星空草地

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  8. HTML5自学笔记[ 17 ]canvas绘图基础4

    绘制图像: drawImage(oImg,x,y),oImg是一个Image对象,(x,y)为绘制起点,绘制的图像大小和源图大小一样. drawImage(oImg,x,y,w,h),后两个参数设置绘 ...

  9. HTML5自学笔记[ 16 ]canvas绘图基础3

    canvas还提供提供了一些动态方法,使图像可以旋转.缩放和移动,与css3中的方法一样. 移动:translate(x,y),x和y为横竖方向的偏移量 旋转:rotate(弧度),弧度=角度*Mat ...

随机推荐

  1. linux的计划任务crontab

    crontab(全称cron table计划任务列表)是一个用于周期性被执行的任的工具. 相关指令: usage: crontab [-u user] file   crontab [ -u user ...

  2. Windows Internals学习笔记(三)Procdump的使用

    参考资料: 1. 下载地址 2. 使用示例

  3. data-*属性——使用自定义属性的方式存储数据

    HTML5提供了data-*属性能存储页面或应用程序的私有自定义数据.只需在属性前加上data-前缀即可,值可以是任意字符串. 存储的(自定义)数据能够被页面的 JavaScript 中利用,以创建更 ...

  4. 一致性 hash 算法( consistent hashing )

    consistent hashing 算法早在 1997 年就在论文 Consistent hashing and random trees 中被提出,目前在cache 系统中应用越来越广泛: 1 基 ...

  5. spring的下载地址(转)

    http://hi.baidu.com/jaimy_jie/item/d699cecdc5d3a354bdef6990 SPRING官方网站改版后,建议都是通过 Maven和Gradle下载,对不使用 ...

  6. iOS - UIWindow

    前言 NS_CLASS_AVAILABLE_IOS(2_0) @interface UIWindow : UIView @available(iOS 2.0, *) public class UIWi ...

  7. c 函数调用产生的汇编指令和数据在内存情况(2)

    c 函数调用产生的汇编指令和数据在内存情况(1) 一直对函数调用的具体汇编指令和各种变量在内存的具体分配,一知半解.各种资料都很详细,但是不实践,不亲自查看下内存总不能笃定.那就自己做下. 两个目的: ...

  8. JAVA 调用命令并输出

    public class test10 { /** * @param args */ public static void main(String[] args) throws Exception { ...

  9. maven使用实例记录

    Maven入门指南① :Maven 快速入门及简单使用Maven入门指南② :Maven 常用命令,手动创建第一个 Maven 项目Maven入门指南③:坐标和依赖Maven入门指南④:仓库 Mave ...

  10. jQuery扩展插件和拓展函数的写法

    <script type="text/JavaScript">            //jQuery插件的写法(需要传入操作对象)        ;(function ...