canvas之动态时间

<!DOCTYPE HTML>
<html>
<head>
 <title>Html5 Canvas Animations 3</title>
</head>
<body οnlοad="init()" >
<canvas id="c" width="400" height="200"></canvas>
<script type="text/javascript">
    var ctx;

 function init(){
     ctx = document.getElementById('c').getContext('2d');
  setInterval(draw,1000);
 }

 function draw(){
 ctx.clearRect(0,0,400,200);
  var now = new Date();
  var sec = now.getSeconds();
  var min = now.getMinutes();
  var hr  = now.getHours();

  sec = sec < 10 ? '0'+sec : sec;
  min = min < 10 ? '0'+min : min;
  hr = hr < 10 ? '0'+hr : hr;
       
  sec = new String(sec);
  min = new String(min);
  hr = new String(hr);
  
  //hr
   showNumber(hr.substr(0,1),50,50);
   showNumber(hr.substr(1,1),100,50);
   showNumber('.',160,70);
   showNumber('.',160,90);
  //min
   showNumber(min.substr(0,1),170,50); 
   showNumber(min.substr(1,1),220,50); 
   showNumber('.',280,70);
   showNumber('.',280,90);
  //sec
   showNumber(sec.substr(0,1),290,50); 
   showNumber(sec.substr(1,1),340,50); 
 }

 function showNumber(n,x,y){
  var img = new Image(); 
  img.src = 'images/numbers.jpg';

  switch (n)
  {
  case '.':
   ctx.drawImage(img,69,54,10,10,x,y,10,10);
   break;
  case '1':
   ctx.drawImage(img,0,0,110,174,x,y,50,60);
   break;
  case '2':
   ctx.drawImage(img,110,0,110,174,x,y,50,60);
   break;
        case '3':
   ctx.drawImage(img,220,0,110,174,x,y,50,60);
   break;
  case '4':
   ctx.drawImage(img,330,0,110,174,x,y,50,60);
   break;
  case '5':
   ctx.drawImage(img,450,0,110,174,x,y,50,60);
   break;
        case '6':
   ctx.drawImage(img,0,174,120,174,x,y,50,60);
   break;
        case '7':
   ctx.drawImage(img,120,174,110,174,x,y,50,60);
   break;
        case '8':
   ctx.drawImage(img,230,174,110,174,x,y,50,60);
   break;
  case '9':
   ctx.drawImage(img,340,174,110,174,x,y,50,60);
   break;
     default:
     ctx.drawImage(img,460,174,120,174,x,y,59,60);
  }
 }
</script>
</body>
</html>

转载于:https://www.cnblogs.com/mengyusunfang/archive/2011/12/07/2279183.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值