HTML5 Canvas时间效果
Canvas 时间效果:
function clockTest() {
var canvas = document.getElementById('canvas');
if (!(canvas && canvas.getContext)) {
return;
}
var ct = canvas.getContext('2d');
var w = canvas.width = 500;
var h = canvas.height = 300;
var r1 = 95;
var c3 = ct.createLinearGradient(0, 0, 0, h);
c3.addColorStop(0, '#FFF');
c3.addColorStop(0.2, '#dad9e0');
c3.addColorStop(0.4, '#adb0b6');
c3.addColorStop(0.6, '#8f8f99');
c3.addColorStop(0.8, '#86878b');
c3.addColorStop(1, '#88898e');
var c4 = ct.createRadialGradient(w / 2, h / 2, w, w, w, w);
c4.addColorStop(0, 'rgba(0,0,0,1)');
c4.addColorStop(0.2, 'rgba(0,0,0,0.8)');
c4.addColorStop(0.3, 'rgba(0,0,0,0)');
c4.addColorStop(0, 'rgba(0,0,0,0)');
function clock() {
var d = new Date();
var dH = d.getHours();
var dM = d.getMinutes();
var dS = d.getSeconds();
//return;
ct.clearRect(0, 0, w, h);
ct.save();
ct.beginPath();
ct.strokeStyle = 'rgba(0,0,0,0.1)';
ct.fillStyle = c3;
ct.arc(w / 2, h / 2, 135, 0, Math.PI * 2, true);
ct.closePath();
ct.fill();
ct.stroke();
ct.restore();
ct.save();
ct.beginPath();
ct.strokeStyle = 'rgba(0,0,0,0.1)';
ct.fillStyle = '#E2E9F1';
ct.arc(w / 2, h / 2, 120, 0, Math.PI * 2, true);
ct.closePath();
ct.fill();
ct.stroke();
ct.restore();
for (var i = 0; i < 60; i++) {
ct.save();
ct.lineCap = 'square';
ct.beginPath();
if (i % 5 === 0) {
ct.lineWidth = 5;
ct.strokeStyle = '#333';
} else {
ct.lineWidth = 2;
ct.strokeStyle = '#333';
}
ct.translate(w / 2, h / 2);
ct.rotate(i * 6 * Math.PI / 180);
ct.moveTo(0, -120);
if (i % 5 === 0) {
ct.lineTo(0, -105);
} else {
ct.lineTo(0, -110);
}
ct.closePath();
ct.stroke();
ct.restore();
}
ct.save();
ct.translate(w / 2, h / 2);
ct.fillColor = '#369';
ct.textAlign = 'center';
ct.textBaseline = 'middle';
ct.font = '25px times new roman';
ct.fillText(12, 0, -r1);
ct.fillText(3, r1, -0);
ct.fillText(6, 0, r1);
ct.fillText(9, -r1, -0);
ct.fillStyle = '#333';
ct.font = '16px verdara';
ct.fillText('KINGWELL', 0, 50);
ct.restore();
ct.save();
ct.beginPath();
ct.translate(w / 2, h / 2);
ct.rotate((dH + dM / 60) * 30 * Math.PI / 180);
ct.lineWidth = 10;
ct.strokeStyle = '#222';
ct.moveTo(0, 15);
ct.lineTo(0, -70);
ct.closePath();
ct.stroke();
ct.restore();
ct.save();
ct.beginPath();
ct.translate(w / 2, h / 2);
ct.rotate((dM + dS / 60) * 6 * Math.PI / 180);
ct.lineWidth = 6;
ct.strokeStyle = '#333';
ct.moveTo(0, 20);
ct.lineTo(0, -90);
ct.closePath();
ct.stroke();
ct.restore();
ct.save();
ct.beginPath();
ct.translate(w / 2, h / 2);
ct.rotate(dS * 6 * Math.PI / 180);
ct.lineWidth = 2;
ct.strokeStyle = '#C00';
ct.moveTo(0, 25);
ct.lineTo(0, -100);
ct.closePath();
ct.stroke();
ct.restore();
ct.save();
ct.beginPath();
ct.translate(w / 2, h / 2);
ct.arc(0, 0, 6, 0, Math.PI * 2, true);
ct.fillStyle = '#C00';
ct.closePath();
ct.fill();
ct.restore();
setTimeout(clock, 1000);
}
clock();
}
clockTest();
HTML5 Canvas时间效果的更多相关文章
- HTML5 Canvas动画效果演示
HTML5 Canvas动画效果演示 主要思想: 首先要准备一张有连续帧的图片,然后利用HTML5 Canvas的draw方法在不同的时间 间隔绘制不同的帧,这样看起来就像动画在播放. 关键技术点: ...
- HTML5 Canvas动画效果实现原理
在线演示 使用HTML5画布可以帮助我们高速实现简单的动画效果.基本原理例如以下: 每隔一定时间绘制图形而且清除图形,用来模拟出一个动画过程,能够使用context.clearRect(0, 0, x ...
- HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET
HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET HTML5 Canvas动画效果演示
- 7个惊艳的HTML5 Canvas动画效果及源码
HTML5非常强大,尤其是现在大部分浏览器都支持HTML5和CSS3,用HTML5制作的动画也多了起来.另外,Canvas上绘制图形非常简单,本文就分享了一些强大的HTML5 Cnavas动画,一起来 ...
- 基于HTML5 Canvas粒子效果文字动画特效
之前我们分享过很多超酷的文字特效,其中也有利用HTML5和CSS3的.今天我们要来分享一款基于HTML5 Canvas的文字特效,输入框中输入想要展示的文字,回车后即可在canvas上绘制出粒子效果的 ...
- HTML5 canvas流体力学效果
某人用Java搞了一个流体力学的演示:http://grantkot.com/MPM/Liquid.html. 下面是 HTML 5版的流体力学演示(推荐使用Chrome浏览器浏览): 效果演示 &l ...
- HTML5 Canvas 超炫酷烟花绽放动画教程
这是一个很酷的HTML5 Canvas动画,它将模拟的是我们现实生活中烟花绽放的动画特效,效果非常逼真,但是毕竟是电脑模拟,带女朋友看就算了,效果还是差了点,呵呵.这个HTML5 Canvas动画有一 ...
- html5 canvas首屏自适应背景动画循环效果代码
模板描述:html5 canvas首屏自适应背景动画循环效果代码 由于动态图太大,怕以后服务器受不了,所以现在都改为静态图了,大家点击演示地址一样的,希望大家喜欢,你们的支持就是小海的动力!! 欢迎大 ...
- HTML5 Canvas 实现的9个 Loading 效果
Sonic.js 是一个很小的 JavaScript 类,用于创建基于 HTML5 画布的加载图像.更强大的是 Sonic.js 还提供了基于现成的例子的创建工具,可以帮助你实现更多自定义的(Load ...
随机推荐
- css滤镜让图片模糊
.mhblur { filter: url(blur.svg#blur); /* FireFox, Chrome, Opera */ -webkit-filter: blur(53px); /* Ch ...
- pycharm开启代码智能提示和报错提示
天呐,经历了一大波周折,终于把提示给弄好了,加入没有提示的话,pycharm就是一个空格了,没有什么作用,对我来说,真的是很困难的事情,所以无论如何都要去把这个智能提示给搞好了. 先讲讲我的经历吧.我 ...
- Unity3d学习日记(五)
之前用3dsmax将模型转成FBX怎么也没有办法自动导入材质到Unity3d中(试过勾选了导出嵌入媒体,没用).索性试了试c4d,发现是可行的,看来像我这种菜鸡还是更加适合用c4d. 拿zoe ...
- 【Linux】- Ubuntu安装nginx
安装 执行命令: sudo apt-get install nginx 执行如图: 防火墙设置 查看防火墙状态: sudo ufw status 查看可以穿过防火墙的应用列表: sudo ufw ap ...
- php 生成短网址 代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- Maven 3-Maven依赖版本冲突的分析及解决小结 (阿里,美团,京东面试)
举例A依赖于B及C,而B又依赖于X.Y,而C依赖于X.M,则A除引B及C的依赖包下,还会引入X,Y,M的依赖包(一般情况下了,Maven可通过<scope>等若干种方式控制传递依赖).这里 ...
- 第28天:js-Tab栏切换封装函数
一.input.value所有值都是string 二.变量和属性var index=10;//变量var arr=[];//数组arr.index=20;//index为自定义属性,只能在arr下使用 ...
- 【.Net】C# 反编译工具之dnSpy
下载地址:https://github.com/0xd4d/dnSpy/releases无需安装,和 ILSPY同门,感觉比ILSPY还强大 直接把dll拖拽到程序集资源管理器里面就可以啦
- Activiti5工作流笔记一
介绍工作流 网上工作流的定义一大堆,这里就不去复制了,通俗的理解,工作流就是类似OA系统中请假审批.报销审批等一系列流程,下级提交的申请只有直系领导才能审批,其他人是没有权限的,而只有直系领导审批通过 ...
- Go语言【第九篇】:Go数据结构之:数组
Go语言数组 Go语言提供了数组类型的数据结构.数组时具有相同唯一类型的一组已编号且长度固定的数据项序列,中类型可以是任意的原始类型如整形.字符串或者自定义类型. 相对于声明number0,numbe ...