使用html5制作loading图的示例


Posted in HTML / CSS onApril 14, 2014

复制代码
代码如下:

<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<canvas id = "canvas"></canvas></p> <p> <script>
var Loading = function (canvas, options) {
this.canvas = document.getElementById(canvas);
this.options = options;
};</p> <p> Loading.prototype = {
constructor: Loading,
show: function () {
var canvas = this.canvas,
begin = this.options.begin,
old = this.options.old,
lineWidth = this.options.lineWidth,
canvasCenter = {x: canvas.width / 2, y: canvas.height / 2},
ctx = canvas.getContext("2d"),
color = this.options.color,
num = this.options.num,
angle = 0,
lineCap = this.options.lineCap,
CONST_PI = Math.PI * (360 / num) / 180;
window.timer = setInterval(function () {
ctx.clearRect(0, 0, canvas.width, canvas.height);
for (var i = 0; i < num; i += 1) {
ctx.beginPath();
ctx.strokeStyle = color[num - 1 - i];
ctx.lineWidth = lineWidth;
ctx.lineCap= lineCap;
ctx.moveTo(canvasCenter.x + Math.cos(CONST_PI * i + angle) * begin, canvasCenter.y + Math.sin(CONST_PI * i + angle) * begin);
ctx.lineTo(canvasCenter.x + Math.cos(CONST_PI * i + angle) * old, canvasCenter.y + Math.sin(CONST_PI * i + angle) * old);
ctx.stroke();
ctx.closePath();
}
angle += CONST_PI;
console.log(angle)
},50);
},
hide: function () {
clearInterval(window.timer);
}
};</p> <p> (function () {
var options = {
num : 8,
begin: 20,
old: 40,
lineWidth: 10,
lineCap: "round",
color: ["rgb(0, 0, 0)", "rgb(20, 20, 20)","rgb(40, 40, 40)", "rgb(60, 60, 60)","rgb(80, 80, 80)", "rgb(100, 100, 100)", "rgb(120, 120, 120)", "rgb(140, 140, 140)"]
};
var loading = new Loading("canvas", options);
loading.show();
}());
</script>
</body>
</html>

效果图:

使用html5制作loading图的示例

HTML / CSS 相关文章推荐
CSS3属性选择符介绍
Oct 17 HTML / CSS
CSS3制作ajax loader icon实现思路及代码
Aug 25 HTML / CSS
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 HTML / CSS
详解CSS3原生支持div铺满浏览器的方法
Aug 30 HTML / CSS
CSS实现进度条和订单进度条的示例
Nov 05 HTML / CSS
css3实现平移效果(transfrom:translate)的示例
Nov 13 HTML / CSS
Html5新标签解释及用法
Feb 17 HTML / CSS
html5 迷宫游戏(碰撞检测)实例一
Jul 25 HTML / CSS
HTML5+CSS3应用详解
Feb 24 HTML / CSS
移动端解决悬浮层(悬浮header、footer)会遮挡住内容的3种方法
Mar 27 HTML / CSS
浅谈Html5多线程开发之WebWorkers
May 02 HTML / CSS
CSS实现五种常用的2D转换
Dec 06 HTML / CSS
html5的canvas元素使用方法介绍(画矩形、画折线、圆形)
Apr 14 #HTML / CSS
html5图片上传预览示例分享
Apr 14 #HTML / CSS
HTML5 Canvas锯齿图代码实例
Apr 10 #HTML / CSS
HTML5 Canvas旋转动画的2个代码例子(一个旋转的太极图效果)
Apr 10 #HTML / CSS
使用javascript和HTML5 Canvas画的四渐变色播放按钮效果
Apr 10 #HTML / CSS
HTML5的自定义属性data-*详细介绍和JS操作实例
Apr 10 #HTML / CSS
让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)
Apr 08 #HTML / CSS
You might like
PHP+MYSQL的文章管理系统(一)
2006/10/09 PHP
在PHP中使用X-SendFile头让文件下载更快
2014/06/01 PHP
PHP实现事件机制实例分析
2015/06/26 PHP
PHP分享图片的生成方法
2018/04/25 PHP
用JavaScript显示浏览器客户端信息的超相近教程
2015/06/18 Javascript
jQuery代码实现发展历程时间轴特效
2015/07/30 Javascript
浅谈JavaScript中的对象及Promise对象的实现
2015/11/15 Javascript
一起学写js Calender日历控件
2016/04/14 Javascript
JavaScript重载函数实例剖析
2016/05/13 Javascript
基于JavaScript代码实现自动生成表格
2016/06/15 Javascript
jQuery中Find选择器用法示例
2016/09/21 Javascript
浅谈javascript:两种注释,声明变量,定义函数
2016/09/29 Javascript
前端自动化开发之Node.js的环境搭建教程
2017/04/01 Javascript
微信小程序开发之数据存储 参数传递 数据缓存
2017/04/13 Javascript
详解webpack 多入口配置
2017/06/16 Javascript
jquery获取select选中值的文本,并赋值给另一个输入框的方法
2018/08/21 jQuery
解决axios会发送两次请求,有个OPTIONS请求的问题
2018/10/25 Javascript
原生JS实现的跳一跳小游戏完整实例
2019/01/27 Javascript
微信小程序-可移动菜单的实现过程详解
2019/06/24 Javascript
VUE 实现element upload上传图片到阿里云
2020/08/12 Javascript
探索浏览器页面关闭window.close()的使用详解
2020/08/21 Javascript
vue组件讲解(is属性的用法)模板标签替换操作
2020/09/04 Javascript
js实现右键弹出自定义菜单
2020/09/08 Javascript
[54:27]TNC vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
[49:56]VG vs Optic 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python中实例化class的执行顺序示例详解
2018/10/14 Python
Python实现K折交叉验证法的方法步骤
2019/07/11 Python
python禁用键鼠与提权代码实例
2019/08/16 Python
python 实现查询Neo4j多节点的多层关系
2019/12/23 Python
Python django框架开发发布会签到系统(web开发)
2020/02/12 Python
利用canvas实现图片下载功能来实现浏览器兼容问题
2019/05/31 HTML / CSS
公司员工检讨书
2014/02/08 职场文书
一年级小学生评语大全
2014/12/25 职场文书
学生病假条范文
2015/08/17 职场文书
教你如何用python开发一款数字推盘小游戏
2021/04/14 Python
MySQL 可扩展设计的基本原则
2021/05/14 MySQL