HTML5自学笔记[ 15 ]canvas绘图实例之钟表
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>canvas绘图小实例之方块移动</title>
<style>
body{ background:#000;}
#canvas1{ margin:100px 500px; background:#fff;}
#canvas1 span{ color:#fff;}
</style>
<script>
window.onload = function(){
var oCanvas = document.getElementById('canvas1');
var oContext = oCanvas.getContext('2d'); //获取绘图的2d环境
function tick(){
oContext.clearRect(0,0,oCanvas.width,oCanvas.height);
//画表盘
oContext.beginPath();
for(var i=0;i<60;i++){
oContext.moveTo(300,300);
oContext.arc(300,300,200,i*6*Math.PI/180,(i+1)*6*Math.PI/180,false);
}
oContext.stroke();
oContext.beginPath();
oContext.arc(300,300,200*0.9,0,360*Math.PI/180,false);
oContext.fillStyle= "white";
oContext.fill();
oContext.beginPath();
for(var i=0;i<12;i++){
oContext.moveTo(300,300);
oContext.arc(300,300,200,i*30*Math.PI/180,(i+1)*30*Math.PI/180,false);
}
oContext.lineWidth = 3;
oContext.stroke();
oContext.beginPath();
oContext.arc(300,300,200*0.87,0,360*Math.PI/180,false);
oContext.fill();
//获取时间
var oDate = new Date();
var oHour = oDate.getHours();
var oMin = oDate.getMinutes();
var oSec = oDate.getSeconds();
var degHour = (-90+oHour*30+oMin/2)*Math.PI/180;
var degMin = (-90+oMin*6)*Math.PI/180;
var degSec = (-90+oSec*6)*Math.PI/180;
//画时针
oContext.beginPath();
oContext.moveTo(300,300);
oContext.arc(300,300,200*0.5,degHour,degHour,false);
oContext.lineWidth = 5;
oContext.stroke();
//画分针
oContext.beginPath();
oContext.moveTo(300,300);
oContext.arc(300,300,200*0.7,degMin,degMin,false);
oContext.lineWidth = 3;
oContext.stroke();
//画秒针
oContext.beginPath();
oContext.moveTo(300,300);
oContext.arc(300,300,200*0.8,degSec,degSec,false);
oContext.lineWidth = 1;
oContext.stroke();
}
tick();
setInterval(tick,1000);
}
</script>
</head>
<body>
<canvas id="canvas1" width="600" height="600">
<span>该浏览器不支持canvas</span>
</canvas>
</body>
</html>
HTML5自学笔记[ 15 ]canvas绘图实例之钟表的更多相关文章
- HTML5自学笔记[ 19 ]canvas绘图实例之炫彩时钟
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- HTML5自学笔记[ 21 ]canvas绘图实例之马赛克
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- HTML5自学笔记[ 20 ]canvas绘图实例之绘制倒影
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- HTML5自学笔记[ 15 ]canvas绘图基础6
关于线条的一些属性: lineCap,这个属性表示的是线条两端的样式,值有butt(默认)/round/square. lineJoin,这个属性表示线条相交的方式,值有miter(默认)/bevel ...
- HTML5自学笔记[ 13 ]canvas绘图小实例之方块移动
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- HTML5自学笔记[ 12 ]canvas绘图小示例之鼠标画线
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- HTML5自学笔记[ 11 ]canvas绘图基础1
html5新增<canvas>标签用于绘制图像,默认宽高是300*150,canvas的宽高需要在这里设置,在css中设置会有问题:设置的形状,如矩形,会等比缩放,而非设置的宽高. 在不支 ...
- HTML5自学笔记[ 24 ]canvas绘图之星空草地
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- HTML5自学笔记[ 17 ]canvas绘图基础4
绘制图像: drawImage(oImg,x,y),oImg是一个Image对象,(x,y)为绘制起点,绘制的图像大小和源图大小一样. drawImage(oImg,x,y,w,h),后两个参数设置绘 ...
随机推荐
- 我的android学习经历23
学习fragment时遇到的问题 这几天学习fragment静态加载时遇到这样的问题: java.lang.RuntimeException: Unable to start activity Com ...
- 滤镜模糊效果,利用了文字阴影和透明。其实是抄的iSlider官网的
<!DOCTYPE html> <html> <meta charset="UTF-8"> <meta name="viewpo ...
- MySQL(四) —— 操作数据表中的记录
插入记录 INSERT [INTO] tbl_name [(col_name,...)] {VALUES | VALUE} ({expr | DEFAULT},...),(...),... //法二: ...
- 用Jenkins+Gradle+Jetty实现持续集成、测试、部署
自动集成有很多种方案,本例用到的工具是Jenkins(前身Hudson)+Gradle+Jetty,关于Gradle可参考上一篇,Gradle常见问题. 本例项目名称: WAP Jetty 安装Jen ...
- css样式 浏览器的读取顺序
css样式 浏览器的读取顺序 例: tbody tr td{} 浏览器是先查找td,然后去找td tr,然后去找td tr tbody div p{}和div>p{}的区别 .div p{} 是 ...
- PHP面向对象(OOP)编程入门教程————如何实例化对象?
我们上面说过面向对象程序的单位就是对象,但对象又是通过类的实例化出来的,既然我们类会声明了,下一步就是实例化对象了. 当定义好类后,我们使用new关键字来生成一个对象. $对象名称 = new 类名称 ...
- spring常用的工具类
spring给我们提供了很多的工具类, 应该在我们的日常工作中很好的利用起来. 它可以大大的减轻我们的平时编写代码的长度. 因我们只想用spring的工具类, 而不想把一个大大的spring工程给引入 ...
- jquery使用技巧
1. 禁用右键点击(Disable right-click) <!DOCTYPE html> <html> <head> <meta charset=&quo ...
- [转载] Codis作者黄东旭细说分布式Redis架构设计和踩过的那些坑们
原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=208733458&idx=1&sn=691bfde670fb ...
- CSS规范之BFC & IFC
元素是文档结构的基础,在CSS中,每个元素生成了一个包含了元素内容的框(box,也译为"盒子").但是不同的元素显示的方式会有所不同,例如<div>和<span& ...