更多>
最新下载
jQuery点击文字滚动Scrollocue插件
jQuery点击文字滚动Scrollocue插件是一款用于构建一个简单的提示提词器系统的jQuery小插件。本作品由【站长素材】收集整理,转载请注明出处!
0
2025-12-19
24小时阅读排行榜
- 1 如何使用Golang反射修改struct字段值_Golang reflect动态修改字段值技巧整理
- 2 手机中如何打开html_在手机浏览器打开HTML文件步骤【步骤】
- 3 c++的std::bitset怎么用 高效的位操作容器【STL详解】
- 4 Linux本机可以访问外网不行_路由与DNS排错流程【教学】
- 5 javascript内存泄漏是什么_如何避免和检测内存泄漏
- 6 HTML如何遍历DOM节点_元素循环访问方法【教程】
- 7 mysql中的视图是什么_mysql视图作用与使用说明
- 8 javascript模块化是什么_如何使用import和export?
- 9 SQL分组统计如何实现_GROUPBY使用技巧与常见错误【技巧】
- 10 如何在mysql中实现评论回复_mysql评论回复表设计
- 11 cssrelative定位看不到效果怎么办_relative只作为定位参照使用
- 12 如何配置mysql数据文件路径_mysql数据文件路径设置
- 13 Linux多IP绑定怎么配置_业务隔离实战方案【教学】
- 14 Python构建跨部门数据同步系统的结构化设计方案【教程】
- 15 Python快速掌握数据分析中模型调优技巧【教程】
更多>
最新教程
-
- Node.js 教程
- 14120 2025-08-28
-
- CSS3 教程
- 1540677 2025-08-27
-
- Rust 教程
- 21824 2025-08-27
-
- Vue 教程
- 24338 2025-08-22
-
- PostgreSQL 教程
- 21058 2025-08-21
-
- Git 教程
- 8298 2025-08-21
html5 css3圆形波浪百分比加载动画特效
js代码
<script>
var wave = (function () {
var ctx;
var waveImage;
var canvasWidth;
var canvasHeight;
var needAnimate = false;
function init (callback) {
var wave = document.getElementById('wave');
var canvas = document.createElement('canvas');
if (!canvas.getContext) return;
ctx = canvas.getContext('2d');
canvasWidth = wave.offsetWidth;
canvasHeight = wave.offsetHeight;
canvas.setAttribute('width', canvasWidth);
canvas.setAttribute('height', canvasHeight);
wave.appendChild(canvas);
waveImage = new Image();
waveImage.onload = function () {
waveImage.onload = null;
callback();
}
waveImage.src = 'images/wave.png';
}
function animate () {
var waveX = 0;
var waveY = 0;
var waveX_min = -203;
var waveY_max = canvasHeight * 0.7;
var requestAnimationFrame =
window.requestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function (callback) { window.setTimeout(callback, 1000 / 60); };
function loop () {
ctx.clearRect(0, 0, canvasWidth, canvasHeight);
if (!needAnimate) return;
if (waveY < waveY_max) waveY += 1.5;
if (waveX < waveX_min) waveX = 0; else waveX -= 3;
ctx.globalCompositeOperation = 'source-over';
ctx.beginPath();
ctx.arc(canvasWidth/2, canvasHeight/2, canvasHeight/2, 0, Math.PI*2, true);
ctx.closePath();
ctx.fill();
ctx.globalCompositeOperation = 'source-in';
ctx.drawImage(waveImage, waveX, canvasHeight - waveY);
requestAnimationFrame(loop);
}
loop();
}
function start () {
if (!ctx) return init(start);
needAnimate = true;
setTimeout(function () {
if (needAnimate) animate();
}, 500);
}
function stop () {
needAnimate = false;
}
return {start: start, stop: stop};
}());
wave.start();
</script>
本站所有资源都是由网友投搞发布,或转载各大下载站,请自行检测软件的完整性!本站所有资源仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您自己承担!如有侵权请联系我们删除下架,联系方式:admin@php.cn
