收藏本站 收藏本站
积木网首页 - 软件测试 - 常用手册 - 站长工具 - 技术社区
首页 > JavaScript > JavaScript技巧 > 正文

首页 - PHP - 数据库 - 操作系统 - 游戏开发 - JS - Android - MySql - Redis - MongoDB - Win8 - Shell编程 - DOS命令 - jQuery - CSS样式 - Python - Perl

Access - Oracle - DB2 - SQLServer - MsSql2008 - MsSql2005 - Sqlite - PostgreSQL - node.js - extjs - JavaScript vbs - Powershell - Ruby

JS+Canvas绘制动态时钟效果

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

<!DOCTYPE html> 
<html> 
 <head> 
  <meta charset="utf-8" /> 
  <title></title> 
  <style> 
   #mycanvas{ 
    position: absolute; 
    left:50%; 
    margin-left:-250px; 
    border:5px solid #fff; 
    box-shadow: 0 0 10px rgba(0,0,0,0.2); 
    background-color: rgb(58, 179, 255); 
   } 
  </style> 
 </head> 
 <body> 
  <!-- 
   canvas:html5新增的画布对象,可以在其中绘制任何的图形,以及线条效果,包括图片 
   注意canvas的尺寸应该通过元素的属性直接设置,而不是使用样式实现(失帧) 
  --> 
  <canvas id="mycanvas" width="500px" height="500px">您的浏览器太low了,请切换</canvas> 
  <script> 
   //获取画布对象 
   var mycanvas = document.getElementById('mycanvas'); 
   //获取一个2d绘图环境(拿到一支画笔) 
   var ctx = mycanvas.getContext('2d'); 
    
  function draw(){ 
  
   //获取系统时间 
   var nowTime = new Date(); 
   var hours = nowTime.getHours();//获取时 
   var minutes = nowTime.getMinutes();//获取分 
   var seconds = nowTime.getSeconds();//获取秒 
    
   //防止小时超过12 
   hours = hours > 12 ? hours-12 : hours; 
   //精准设置小时值 
   hours = hours + minutes/60; 
  
   //清除画布(防止覆盖) 
   ctx.clearRect(0,0,500,500); 
  
   //初始化画笔的样式 
   ctx.lineWidth = 5; //设置线条的宽度 
   ctx.strokeStyle = '#fff'; //设置线条颜色 
    
   ctx.beginPath();//开始新的绘图路径 
   //设置一个圆形路径 
   ctx.arc(250,250,150,0,360,false); 
   //绘制图形 
   ctx.stroke(); 
   ctx.closePath();//结束当前绘图路径 
    
   //绘制刻度(时刻度) 
   for(var i = 0;i < 12;i++){ 
    ctx.beginPath(); 
    ctx.lineWidth = 10; 
    //保存当前绘图环境 
    ctx.save(); 
    //重置绘制起始位置(将圆心位置重置为0,0) 
    ctx.translate(250,250); 
    //旋转画布到一定的弧度 弧度=角度*PI/180 
    ctx.rotate(i * 30 * Math.PI / 180); 
    //设置绘制线条的起始位置 
    ctx.moveTo(0,140); 
    //设置线条的结束位置 
    ctx.lineTo(0,150); 
    //绘制路径 
    ctx.stroke(); 
    //还原初始的绘图环境 
    ctx.restore(); 
    ctx.closePath(); 
   } 
    
   //绘制刻度(分刻度) 
   for(var i = 0;i < 60;i++){ 
    ctx.beginPath(); 
    ctx.lineWidth = 3; 
    //保存当前绘图环境 
    ctx.save(); 
    //重置绘制起始位置(将圆心位置重置为0,0) 
    ctx.translate(250,250); 
    //旋转画布到一定的弧度 弧度=角度*PI/180 
    ctx.rotate(i * 6 * Math.PI / 180); 
    //设置绘制线条的起始位置 
    ctx.moveTo(0,142); 
    //设置线条的结束位置 
    ctx.lineTo(0,146); 
    //绘制路径 
    ctx.stroke(); 
    //还原初始的绘图环境 
    ctx.restore(); 
    ctx.closePath(); 
   } 
    
   /*绘制时针*/ 
   ctx.beginPath(); 
   ctx.lineWidth = 5; 
   //保存当前绘图环境 
   ctx.save(); 
   //重置绘制起始位置(将圆心位置重置为0,0) 
   ctx.translate(250,250); 
   //旋转画布到一定的弧度 弧度=角度*PI/180 
   ctx.rotate(hours * 30 * Math.PI / 180); 
   //设置绘制线条的起始位置 
   ctx.moveTo(0,10); 
   //设置线条的结束位置 
   ctx.lineTo(0,-100); 
   //绘制路径 
   ctx.stroke(); 
   //还原初始的绘图环境 
   ctx.restore(); 
   ctx.closePath(); 
    
   /*绘制分针*/ 
   ctx.beginPath(); 
   ctx.lineWidth = 3; 
   //保存当前绘图环境 
   ctx.save(); 
   //重置绘制起始位置(将圆心位置重置为0,0) 
   ctx.translate(250,250); 
   //旋转画布到一定的弧度 弧度=角度*PI/180 
   ctx.rotate(minutes * 6 * Math.PI / 180); 
   //设置绘制线条的起始位置 
   ctx.moveTo(0,10); 
   //设置线条的结束位置 
   ctx.lineTo(0,-120); 
   //绘制路径 
   ctx.stroke(); 
   //还原初始的绘图环境 
   ctx.restore(); 
   ctx.closePath(); 
    
    
   /*绘制秒针*/ 
   ctx.beginPath(); 
   ctx.lineWidth = 1; 
   ctx.strokeStyle = '#f00'; 
   //保存当前绘图环境 
   ctx.save(); 
   //重置绘制起始位置(将圆心位置重置为0,0) 
   ctx.translate(250,250); 
   //旋转画布到一定的弧度 弧度=角度*PI/180 
   ctx.rotate(seconds * 6 * Math.PI / 180); 
   //设置绘制线条的起始位置 
   ctx.moveTo(0,10); 
   //设置线条的结束位置 
   ctx.lineTo(0,-135); 
   //绘制路径 
   ctx.stroke(); 
   //还原初始的绘图环境 
   ctx.restore(); 
   ctx.closePath(); 
  } 
   
  setInterval(draw,1000); 
   
  </script> 
 </body> 
</html> 

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

js+html获取系统当前时间
本文实例为大家分享了html获取系统当前时间的具体代码,供大家参考,具体内容如下htmlheadSTYLETD{FONT-SIZE:12px;COLOR:#ffffff;FONT-FAMILY:Verdana,Arial,Helvetica,sans-se

three.js加载obj模型的实例代码
three.js是一款webGL框架,由于其易用性被广泛应用。如果你要学习webGL,抛弃那些复杂的原生接口从这款框架入手是一个不错的选择。好了,下面通过一

Three.js加载外部模型的教程详解
1.首先我们要在官网:https://threejs.org/下载我们three.js压缩包,并将其中的build文件夹下的three.js通过script标签对的src属性导入到我们的页面中2.创建three.js核

本周排行

更新排行

强悍的草根IT技术社区,这里应该有您想要的!
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP备05050695号