Canvas基础学习(一)——实现简单时钟显示
HTML5最受欢迎的功能就是<canvas>元素。这个元素负责在页面中设定一个区域,然后就可以通过JavaScript动态地在这个区域中绘制图形。关于<canvas>元素的一些基本用法可以参考w3school。
花了一下午时间熟悉了下常用的API,也参考了下网上的一些demo,实现了一个简单的时钟显示,代码记录如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>canvas-clock</title>
<style type="text/css">
/* canvas drawing */
.clock {
width: 300px;
margin: 0 auto;
}
#clock {
width: 300px;
height: 300px;
}
</style>
<script type="text/javascript">
var clockDraw = function(context) {
var now = new Date();
context.save();
context.clearRect(0, 0, 300, 300);
context.scale(1, 0.5);
context.translate(150, 150); // init hours
context.save();
for (var i = 0; i < 12; i++ ) {
context.beginPath();
context.rotate(Math.PI / 6);
context.moveTo(0, -123);
context.lineWidth = 5;
context.lineTo(0, -110);
context.stroke();
}
context.restore(); // init minutes
context.save();
context.lineWidth = 5;
for (i = 0; i < 60; i++) {
if (i % 5 != 0) {
context.beginPath();
context.moveTo(0, 118);
context.lineWidth = 2;
context.lineTo(0, 115);
context.stroke();
}
context.rotate(Math.PI / 30);
}
context.restore(); var sec = now.getSeconds();
var min = now.getMinutes();
var hr = now.getHours();
hr = hr >= 12 ? hr - 12 : hr; context.fillStyle = "black"; // draw hour
context.save();
context.rotate(hr * (Math.PI / 6) + (Math.PI / 360) * min + (Math.PI / 21600) * sec);
context.lineWidth = 7;
context.beginPath();
context.moveTo(0, 10);
context.lineTo(0, -80);
context.stroke();
context.restore(); // draw minute
context.save();
context.rotate((Math.PI / 30) * min + (Math.PI / 1800) * sec);
context.lineWidth = 5;
context.beginPath();
context.moveTo(0, 20);
context.lineTo(0, -100);
context.stroke();
context.restore(); // draw second
context.save();
context.rotate(sec * Math.PI / 30);
context.strokeStyle = "#D40000";
context.fillStyle = "#D40000";
context.lineWidth = 4;
context.beginPath();
context.moveTo(0, 30);
context.lineTo(0, -113);
context.stroke();
context.beginPath();
context.arc(0, 0, 5, 0, Math.PI * 2, false);
context.fill();
context.restore(); context.beginPath();
context.arc(0, 0, 125, 0, Math.PI * 2, false);
context.lineWidth = 5;
context.strokeStyle = '#325FA2';
context.stroke(); context.restore();
}; var initClock = function() {
var clock = document.getElementById("clock");
if (clock.getContext) {
var context = clock.getContext("2d");
clockDraw(context);
setInterval((function() {
return function() {
clockDraw(context);
}
})(context), 1000);
};
}; window.onload = function() {
//canvas drawing
initClock();
};
</script>
</head>
<body>
<div class="clock">
<canvas id="clock">A drawing of clock.</canvas>
</div>
</body>
</html>
Canvas基础学习(一)——实现简单时钟显示的更多相关文章
- Java基础学习-- 继承 的简单总结
代码参考:Java基础学习小记--多态 为什么要引入继承? 还是做一个媒体库,里面可以放CD,可以放DVD.如果把CD和DVD做成两个没有联系的类的话,那么在管理这个媒体库的时候,要单独做一个添加CD ...
- canvas基础学习
/** * Created by ty on 2016/7/11. * canvas 基础 */ window.onload = function() { var canvas = document. ...
- HTML5 <canvas> 基础学习
HTML5 <canvas> 元素用于图形的绘制,通过脚本 (通常是JavaScript)来完成. <canvas> 标签只是图形容器,您必须使用脚本来绘制图形 创建一个画布( ...
- canvas一周一练 -- canvas基础学习
从上个星期开始,耳朵就一直在生病,里面长了个疙瘩,肿的一碰就疼,不能吃饭不能嗨 (┳_┳)……在此提醒各位小伙伴,最近天气炎热,一定要注意防暑上火,病来如山倒呀~ 接下来我正在喝着5块一颗的药学习ca ...
- canvas基础学习(二)
一.图像绘制 canvas绘制图像的方法是ctx.drawImage();该方法有三种使用方式 1.ctx.drawImage(img,x,y); img是指图像对象,x和y分别是这个图像左上角在ca ...
- 【jQuery基础学习】10 简单了解jQuery Mobile及jQuery各个级别版本的变化
关于 jQuery Mobile jQuery Mobile是为了填补jQuery在移动设备应用上的一个新项目.它应用了HTML5和CSS3. 主要特性 基于jQuery构建. 采用与jQuery一致 ...
- salesforce lightning零基础学习(一) lightning简单介绍以及org开启lightning
lightning对于开发salesforce人员来说并不陌生,即使没有做过lightning开发,这个名字肯定也是耳熟能详.原来的博客基本都是基于classic基于配置以及开发,后期博客会以ligh ...
- canvas基础学习笔记
canvas基本用法 1.什么是canvas(画布) <canvas> 是 HTML5 新增的元素,可用于通过使用JavaScript中的脚本来绘制图形,例如,它可以用于绘制图形,创建动 ...
- canvas基础学习(四)
今天逛天猫时,看见优衣库店铺首页有个这个飘雪效果,顿时觉得好酷炫,立马从里面copy代码进行学习. 之前我也做过一些canvas特效,往往在canvas全屏时,canvas下层的div就无法进行dom ...
随机推荐
- (原)使用vectot的.end()报错:iterators incompatible
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5070672.html 参考网址: http://blog.csdn.net/yxnyxnyxnyxny ...
- ORACLE11G常用函数
1 单值函数 1.1 日期函数 1.1.1 Round [舍入到最接近的日期](day:舍入到最接近的星期日) select sysdate S1, round(sysdate) S2 , round ...
- JDK,TomCat安装配置
JDK.Tomcat.myEclipse安装配置 准备安装包 JAVA运行环境包 JDK1.7下载地址: http://www.veryhuo.com/down/html/43205.html Jsp ...
- XMLHttpRequest基础知识
XMLHttpRequest 发送请求的两个重要方法:open(method,url,async)——参数:请求方式.请求地址.请求同步/异步:send(string)——参数:使用POST方式时,填 ...
- postgresql赋予/撤消 用户权限
(1)给予权限:grant grant select on 表名 to 用户名: (2)撤消权限:revoke revoke select on 表名 from ...
- JS+html实现简单的飞机大战
摘要:通过原生的js+html实现简单的飞机大战小游戏效果,如图所示: 实现代码如下: 1.自己的飞机实现 飞机html: <!DOCTYPE html> <html lang=&q ...
- 将vim作为QT开发的IDE
转载请注明链接与作者huihui1988 用了一段时间的vim,喜欢上了这种简洁高效的编辑器.恰逢正在学习QT中,于是将vim变成了开发QT的工具.以下是具体配置. 一.语法高亮支持: 1.打开VIM ...
- jQuery插件之artDialog
artDialog是一个非常强大的弹出框插件.默认有两个版本,一个是jQuery版,一个是javascript版.功能非常多,而且使用非常简单.不写了,直接贴上官网的预览运行地址,以后用得着的时候去那 ...
- VC使用#定义方便控制版本号的宏
一个 VC Project 中,可能有很多地方需要用到版本号,比如 About 对话框.版本资源等.如果每次版本更改都一一去改变这些值,不但非常麻烦,而且有悖唯一原则. 巧妙地使用宏定义,可以很好地解 ...
- MAC上python环境搭建
mac自带的有python,如果你需要查看版本,打开terminal输入以下命令: python --version 如果你需要安装新的python版本,有几种方法可以安装,一是去python官网下载 ...