使用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 translate导致字体模糊的实例代码
Aug 30 HTML / CSS
CSS3教程(9):设置RGB颜色
Apr 02 HTML / CSS
基于CSS3的CSS 多栏(Multi-column)实现瀑布流源码分享
Jun 11 HTML / CSS
CSS3实现文字波浪线效果示例代码
Nov 20 HTML / CSS
10分钟理解CSS3 Grid布局
Dec 20 HTML / CSS
css3实现可拖动的魔方3d效果
May 07 HTML / CSS
CSS3 实现footer 固定在底部(无论页面多高始终在底部)
Oct 15 HTML / CSS
css3 transform导致子元素固定定位变成绝对定位的方法
Mar 06 HTML / CSS
HTML5中FileReader接口使用方法实例详解
Aug 26 HTML / CSS
HTML5探秘:用requestAnimationFrame优化Web动画
Jun 03 HTML / CSS
HTMl5的存储方式sessionStorage和localStorage详解
Mar 18 HTML / CSS
AmazeUI的下载配置与Helloworld的实现
Aug 19 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函数(ignore_user_abort)
2012/08/01 PHP
ThinkPHP框架表单验证操作方法
2017/07/19 PHP
PHP操作Redis数据库常用方法示例
2018/08/25 PHP
javascript  Error 对象 错误处理
2008/05/18 Javascript
javascript Array.remove() 数组删除
2009/08/06 Javascript
jQuery AJAX 调用WebService实现代码
2010/03/24 Javascript
JS简单循环遍历json数组的方法
2016/04/22 Javascript
详解node-ccap模块生成captcha验证码
2017/07/01 Javascript
Vue-cli中为单独页面设置背景色的实现方法
2018/02/11 Javascript
解决layui 三级联动下拉框更新时回显的问题
2019/09/03 Javascript
Vue组件间的通信pubsub-js实现步骤解析
2020/03/11 Javascript
你准备好迎接vue3.0了吗
2020/04/28 Javascript
[02:07]2017国际邀请赛中国区预选赛直邀战队前瞻
2017/06/23 DOTA
Python查看多台服务器进程的脚本分享
2014/06/11 Python
Python内置函数的用法实例教程
2014/09/08 Python
详解Python中dict与set的使用
2015/08/10 Python
Python简单操作sqlite3的方法示例
2017/03/22 Python
Python实现读写sqlite3数据库并将统计数据写入Excel的方法示例
2017/08/07 Python
pygame实现俄罗斯方块游戏
2018/06/26 Python
pandas dataframe添加表格框线输出的方法
2019/02/08 Python
详解python3安装pillow后报错没有pillow模块以及没有PIL模块问题解决
2019/04/17 Python
pytorch torch.nn.AdaptiveAvgPool2d()自适应平均池化函数详解
2020/01/03 Python
Python如何实现FTP功能
2020/05/28 Python
美国最大点评网站:Yelp
2018/02/14 全球购物
法国大使拉杆箱官网:DELSEY Paris
2018/03/20 全球购物
什么是三层交换,说说和路由的区别在那里
2014/09/01 面试题
金融行业务员的自我评价
2013/12/13 职场文书
建筑文秘专业个人求职信范文
2013/12/28 职场文书
一份报关员的职业规划范文
2014/01/08 职场文书
护理工作感言
2014/01/16 职场文书
商场消防安全责任书
2014/07/29 职场文书
家庭财产分割协议书范本
2014/11/24 职场文书
活动总结书怎么写
2015/05/11 职场文书
关于国庆节的广播稿
2015/08/19 职场文书
2016年优秀少先队员事迹材料
2016/02/26 职场文书
戴尔Win11系统no bootable devices found解决教程
2022/09/23 数码科技