<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Canvas制作动态进度加载水球</title>
<style type="text/css">
#c{
margin: 0 auto;
display: block;
}
#r{
display: block;
margin: 0 auto;
}
#r::before{
color: black;
content: attr(min);
padding-right: 10px;
}
#r::after{
color: black;
content: attr(max);
padding-left: 10px;
}
</style>
<script type="text/javascript">
window.onload=function() { var canvas = document.getElementById('c');
var ctx = canvas.getContext('2d');
var range = document.getElementById('r'); //range控件信息
var rangeValue = range.value;// 默认5
var nowRange = 0; //用于做一个临时的range //画布属性
var mW = canvas.width = 250;
var mH = canvas.height = 250;
var lineWidth = 2; //圆属性
var r = mH / 2; //圆心
var cR = r - 16 * lineWidth; //圆半径 //Sin 曲线属性
var sX = 0;
var sY = mH / 2;
var axisLength = mW; //轴长
var waveWidth = 0.03 ; // 绝对值 波浪宽度,数越小越宽
var waveHeight = 6; //波浪高度,数越大越高
var speed = 0.10; //波浪速度,数越大速度越快 改变sin 的值
var xOffset = 0; //波浪x偏移量 ctx.lineWidth = lineWidth; //画圈函数
var IsdrawCircled = false;
var drawCircle = function(){ ctx.beginPath();
ctx.strokeStyle = '#1080d0';
ctx.arc(r, r, cR+5, 0, 2 * Math.PI);
ctx.stroke();
ctx.beginPath();
ctx.arc(r, r, cR, 0, 2 * Math.PI);
ctx.clip(); } //画sin 曲线函数
var drawSin = function(xOffset){ ctx.save(); var points=[]; //用于存放绘制Sin曲线的点 ctx.beginPath();
//在整个轴长上取点
// 250 20/250 ==3125 个点 绘制多个 x.y 点
for(var x = sX; x < axisLength; x += 20 / axisLength){
//此处坐标(x,y)的取点,依靠公式 “振幅高*sin(x*振幅宽 + 振幅偏移量)”
var y = -Math.sin(x * waveWidth + xOffset); // 返回-1 到 1 的值
var dY = mH * (1 - nowRange / 100 ); points.push([x, dY + y * waveHeight]);
ctx.lineTo(x, dY + y * waveHeight); }//--------------绘制波浪 //封闭路径 ctx.lineTo(axisLength, mH); //250 250 ---最右边
ctx.lineTo(sX, mH); //0 250 ----最左边 ctx.fillStyle = '#1c86d1';
ctx.fill(); ctx.restore();
}; //写百分比文本函数
var drawText = function(){
ctx.save(); var size = 0.4*cR;
ctx.font = size + 'px Microsoft Yahei';
ctx.textAlign = 'center';
ctx.fillStyle = "rgba(06, 85, 128, 0.8)";
ctx.fillText(nowRange + '%', r, r + size / 2); ctx.restore();
}; var render = function(){
ctx.clearRect(0, 0, mW, mH); rangeValue = range.value; if(IsdrawCircled == false){
drawCircle();
} if(nowRange <= rangeValue){
var tmp = 1;
nowRange += tmp;
} if(nowRange > rangeValue){
var tmp = 1;
nowRange -= tmp;
} if(rangeValue>0)
{
drawSin(xOffset);
}
drawText(); xOffset += speed; requestAnimationFrame(render);
}
render();
}
</script>
</head>
<body> </body>
<canvas id="c"></canvas>
<input type="range" id="r" min="0" max="100" step="1" value="0">
</html>

文章引用:    Canvas制作动态进度加载水球

相关动画 :    基于canvas实现物理运动效果与动画效果(一)

Canvas实现直线与圆形的物理运动效果    

[js高手之路]html5 canvas动画教程 - 重力、摩擦力、加速、抛物线运动

最新文章

  1. mono的远程调试
  2. java自定义标签 权限
  3. mac 下面wireshark 找不到网卡
  4. git之添加ssh
  5. 几款开源的图形界面库(GUI Libraries)
  6. 使用HttpURLConnection实现在android客户端和服务器之间传递对象
  7. Active控件有关问题
  8. bash 变量使用技巧
  9. CSS3高级选择器
  10. Ext修改所有Ajax的timeout
  11. TCP/IP协议栈模型
  12. C#Winform窗体 DataGridView全选按钮的实现方式
  13. 【托业】【全真题库】TEST1-语法题
  14. 今天开始学习php,粘一些重点放这以便查看记忆。
  15. postman 断点
  16. Linux 系统安装[Ubuntu]
  17. iOS开发者证书-详解
  18. 关于.NET中FileSystemWatcher的一些不被人注意的细节
  19. fatal error LNK1104: 无法打开文件“libc.lib”的问题
  20. MVVM和MVC的区别,以及MVVM的缺点

热门文章

  1. UIBezierPath和CAShapeLayer配合肆意画图
  2. Android Binder 系统学习笔记(一)Binder系统的基本使用方法
  3. ThinkPHP的URL模式
  4. Java线程池拒绝策略
  5. Newtonsoft Json操作类库的使用
  6. TinkerPop中的遍历:图的遍历策略
  7. 树莓派(Raspberry Pi 3) centos7使用yum命令报错File &quot;/usr/bin/yum&quot;, line 30 except KeyboardInterrupt, e:
  8. WinForm 生命周期, WinForm 事件执行顺序
  9. android中SharedPreferences 读取不到数据的问题
  10. wampserver2.5 在 Win7 64位下的相关配置备忘