使用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 相关文章推荐
CSS实现圆形放大镜狙击镜效果 只有圆圈里的放大
Dec 10 HTML / CSS
css3实现可滑动跳转的分页插件示例
May 08 HTML / CSS
CSS3提交意见输入框样式代码
Oct 30 HTML / CSS
Css3新特性应用之视觉效果实例
Dec 12 HTML / CSS
CSS3中新增的对文本和字体的设置
Feb 03 HTML / CSS
CSS3实现线性渐变用法示例代码详解
Aug 07 HTML / CSS
css3中仿放大镜效果的几种方式原理解析
Dec 03 HTML / CSS
使用HTML5的File实现base64和图片的互转
Aug 01 HTML / CSS
HTML5 canvas基本绘图之填充样式实现
Jun 27 HTML / CSS
Canvas globalCompositeOperation
Dec 18 HTML / CSS
通过canvas转换颜色为RGBA格式及性能问题的解决
Nov 22 HTML / CSS
h5页面唤起app如果没安装就跳转下载(iOS和Android)
Jun 03 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
Classes and Objects in PHP5-面向对象编程 [1]
2006/10/09 PHP
php结合表单实现一些简单功能的例子
2011/06/04 PHP
json的键名为数字时的调用方式(示例代码)
2013/11/15 PHP
PHP中对各种加密算法、Hash算法的速度测试对比代码
2014/07/08 PHP
php延迟静态绑定实例分析
2015/02/08 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
2019/11/26 PHP
js的闭包的一个示例说明
2008/11/18 Javascript
jQuery图片播放8款精美插件分享
2013/02/17 Javascript
javascript如何操作HTML下拉列表标签
2015/08/20 Javascript
jquery插件uploadify实现带进度条的文件批量上传
2015/12/13 Javascript
vue+vux实现移动端文件上传样式
2017/07/28 Javascript
bootstrap-table.js扩展分页工具栏(增加跳转到xx页)功能
2017/12/28 Javascript
nodejs acl的用户权限管理详解
2018/03/14 NodeJs
Bootstrap4 gulp 配置详解
2019/01/06 Javascript
Angular封装搜索框组件操作示例
2019/04/25 Javascript
Vue 打包体积优化方案小结
2020/05/20 Javascript
Vue组件跨层级获取组件操作
2020/07/27 Javascript
wxpython 最小化到托盘与欢迎图片的实现方法
2014/06/09 Python
Python编程判断一个正整数是否为素数的方法
2017/04/14 Python
python实现雨滴下落到地面效果
2018/06/21 Python
Python中作用域的深入讲解
2018/12/10 Python
Django用户认证系统 User对象解析
2019/08/02 Python
Python数据处理篇之Sympy系列(五)---解方程
2019/10/12 Python
快速解决jupyter notebook启动需要密码的问题
2020/04/21 Python
html5 利用重力感应实现摇一摇换颜色可用来做抽奖等等
2014/05/07 HTML / CSS
世界上最大的在线学习和教学市场:Udemy
2017/11/08 全球购物
学生发电厂实习自我鉴定
2013/09/22 职场文书
迟到检讨书400字
2014/01/13 职场文书
趣味体育活动方案
2014/02/08 职场文书
小区消防演习方案
2014/02/21 职场文书
舞蹈毕业生的自我评价
2014/03/05 职场文书
办公室主任个人总结
2015/02/28 职场文书
新郎父母婚礼致辞
2015/07/27 职场文书
小学英语教学随笔
2015/08/14 职场文书
MySQL对数据表已有表进行分区表的实现
2021/11/01 MySQL
Redis 异步机制
2022/05/15 Redis