相思资源网 Design By www.200059.com
本文实例讲述了JavaScript+html5 canvas绘制的圆弧荡秋千效果。分享给大家供大家参考,具体如下:
运行效果截图如下:
具体代码如下:
<!DOCTYPE html>
<html>
<head>
<title>demo</title>
<style type="text/css">
#canvas {
margin:50px; border:5px solid gray; box-shadow:0px 0px 5px 5px #494949;
}
</style>
</head>
<body>
<canvas id="canvas" width="500px" height="500px"></canvas>
</body>
<script type="text/javascript">
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
var r_x = 250, r_y = 0;
var offset_h = 250;
var offset_w = 500;
var count = 0;
var mode = "up";
var temp = 0;
var getRPoint = function(x, y) {
var r = (Math.pow(x, 2) + Math.pow(y, 2)) / (2 * y);
var point = {
x: x,
y: Math.abs(250 - (r - y)),
r: r
};
return point;
};
function arc(attrs) {
ctx.beginPath();
ctx.arc(attrs.x, attrs.y, attrs.r, attrs.startAngle || 0, attrs.endAngle || Math.PI);
ctx.stroke();
}
var interval = setInterval(function() {
count++;
switch(mode) {
case "up":
temp = count;
ctx.clearRect(0, 0, 500, 500);
if(count%18 == 0) {
mode = "down";
return;
}
break;
case "down":
temp = 36 - count;
ctx.clearRect(0, 0, 500, 500);
if(count%36 == 0) {
mode = "default";
return;
}
break;
case "default":
temp = count - 36;
if(count%54 == 0) {
mode = "up";
count = 0;
return;
}
}
arc(getRPoint(250, 250-8*temp));
}, 100);
</script>
</html>
更多关于js特效相关内容感兴趣的读者可查看本站专题:《jQuery动画与特效用法总结》及《jQuery常见经典特效汇总》
希望本文所述对大家JavaScript程序设计有所帮助。
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例的评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
