Canvas 动态小球重叠效果
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>canvas 动态小球重叠效果</title>
<script>
window.onload=function()
{
var canvas=document.getElementById('canvas');
var w=canvas.width;
var h=canvas.height;
var num=30; // 小球个数
var balls=[]; // 小球存放数组
var cxt=canvas.getContext('2d');
var t=null; function getBalls() // 创建小球
{
for(var i=0;i<num;i++)
{
// 小球随机颜色
var tempR=Math.floor(Math.random()*255);
var tempG=Math.floor(Math.random()*255);
var tempB=Math.floor(Math.random()*255);
var tempColor='rgb('+tempR+','+tempG+','+tempB+')'; //小球随机大小位置
var tempR=Math.floor(Math.random()*30+20);
var tempX=Math.floor(Math.random()*(w-tempR)+tempR);
var tempY=Math.floor(Math.random()*(h-tempR)+tempR); var tempBall={
x:tempX,
y:tempY,
r:tempR,
color:tempColor,
stepX:Math.floor(Math.random()*20-10),
stepY:Math.floor(Math.random()*20-10), // 步长 差值
};
balls.push(tempBall);
}//-----------------------------------------创建小球
} function updateBalls() // 更新小球
{
for(var i=0;i<balls.length;i++)
{
balls[i].x+=balls[i].stepX;
balls[i].y+=balls[i].stepY;
bumpTest(balls[i]); // 更新后的小球数组 x y 位置
}
} function bumpTest(ele) // 碰撞检测
{
//zuo -->向右走
if(ele.x<=ele.r)
{
ele.x=ele.r;
ele.stepX=-ele.stepX; // 反方向运动
}
// you
if(ele.x >= w-ele.r)
{
ele.x=w-ele.r;
ele.stepX=-ele.stepX;
}
//shang
if(ele.y<=ele.r)
{
ele.y=ele.r;
ele.stepY=-ele.stepY;
}
// xia
if(ele.y>=h-ele.r)
{
ele.y=h-ele.r
ele.stepY=-ele.stepY;
}
} function renderBalls()//重置画布
{
cxt.clearRect(0,0,w,h); // 清空画布
for(var i=0;i<balls.length;i++)
{
cxt.beginPath();// 开始路径
cxt.arc(balls[i].x,balls[i].y,balls[i].r,0,2*Math.PI);
cxt.fillStyle=balls[i].color;
cxt.globalCompositeOperation='xor';
cxt.closePath();// 闭合路径
cxt.fill(); //填充颜色
}
} getBalls();
clearInterval(t);
t=setInterval(function(){
updateBalls();// 更新小球
renderBalls();// 重新绘制小球
},50); } </script>
</head> <body>
<button onClick="window.history.go()"> 点击变换 </button>
<canvas width="500" height="300" style="border:1px solid #000" id="canvas"></canvas>
</body>
</html>
Canvas 动态小球重叠效果的更多相关文章
- canvas动态小球重叠效果
前面的话 在javascript运动系列中,详细介绍了各种运动,其中就包括碰壁运动.但是,如果用canvas去实现,却是另一种思路.本文将详细介绍canvas动态小球重叠效果 效果展示 静态小球 首先 ...
- HTML5 Canvas彩色小球碰撞运动特效
脚本简介 HTML5 Canvas彩色小球碰撞运动特效是一款基于canvas加面向对象制作的运动小球动画特效. 效果展示 http://hovertree.com/texiao/html5/39/ ...
- canvas三角函数模拟水波效果
.katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...
- 酷!使用 jQuery & Canvas 制作相机快门效果
在今天的教程中,我们将使用 HTML5 的 Canvas 元素来创建一个简单的摄影作品集,它显示了一组精选照片与相机快门的效果.此功能会以一个简单的 jQuery 插件形式使用,你可以很容易地整合到任 ...
- 如何使用 HTML5 Canvas 制作水波纹效果
今天,我们继续分享 JavaScript 实现的效果例子,这篇文章会介绍使用 JavaScript 实现水波纹效果.水波效果以图片为背景,点击图片任意位置都会触发.有时候,我们使用普通的 Javasc ...
- Android 动态Tab分页效果实现
当前项目使用的是TabHost+Activity进行分页,目前要做个报表功能,需要在一个Tab页内进行Activity的切换.比方说我有4个Tab页分别为Tab1,Tab2,Tab3,Tab4,现在的 ...
- 【转】提示框第三方库之MBProgressHUD iOS toast效果 动态提示框效果
原文网址:http://www.zhimengzhe.com/IOSkaifa/37910.html MBProgressHUD是一个开源项目,实现了很多种样式的提示框,使用上简单.方便,并且可以对显 ...
- 深入学习CSS外边距margin(重叠效果,margin传递效果,margin:auto实现块级元素水平垂直居中效果)
前言 margin是盒模型几个属性中一个非常特殊的属性.简单举几个例子:只有margin不显示当前元素背景,只有margin可以设置为负值,margin和宽高支持auto,以及margin具有非常奇怪 ...
- 基于HTML5 Canvas可撕裂布料效果
分享一款布料效果的 HTML5 Canvas 应用演示,效果逼真.你会看到,借助 Canvas 的强大绘图和动画功能,只需很少的代码就能实现让您屏息凝神的效果. 在线预览 源码下载 实现的代码. ...
随机推荐
- java判断姓是否合格 百家姓
package util; import java.lang.reflect.Array; public class FirstName { public static boolean ClearNa ...
- <!doctype html>这个是干什么的???
html5标准网页声明,原先的是一串很长的字符串,现在是这个简洁形式,支持html5标准的主流浏览器都认识这个声明.表示网页采用html5
- 2018多校第九场1010 (HDU6424) 数学
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6424 解法:找规律.因为最多三项,a1^a2^a3可以拆成(a1+2)+(a2+1)*a3,然后建成数 ...
- php中定义数组的方法
1.PHP定义数组的格式 数组名=array(); 如:$aa=array();//这样就定义了一个数组, 之后给元素赋值: $aa[0]="9016"; $aa[1]=" ...
- ES02 变量、数组、对象、方法
1 变量 1.1 变量的声明 利用var关键字来声明变量,例如: var a = 100; <!DOCTYPE html> <html> <head> <me ...
- win10 更换秘钥报错:拒绝访问:所请求的操作需要提升特权
直接打开cmd执行换秘钥的命令: slmgr /ipk VK7JG-NPHTM-C97JM-9MPGT-3V66T slmgr /skms kms.xspace.in slmgr /ato 报错如图: ...
- Struts第三天
OgnlValueStack贯穿整个 Action 的生命周期. 它是ContextMap中的一部分,里面的结构是一个List,是我们可以快速访问数据一个容器.它的封装是由struts2框架完成的. ...
- Centos7安装mysql缺乏yum源怎么安装
找到mysql5.6的centos的repo源,终于解决mysql的安装问题: 1.确保centos安装了wget,没有的话安装wget 1 yum install wget 2.下载mysql的 ...
- FactoryMethodPattern(23种设计模式之一)
设计模式六大原则(1):单一职责原则 设计模式六大原则(2):里氏替换原则 设计模式六大原则(3):依赖倒置原则 设计模式六大原则(4):接口隔离原则 设计模式六大原则(5):迪米特法则 设计模式六大 ...
- js实现无刷新上传
在新增数据项的时候,用ajax实现无刷新提交,但上传文件的时候,由于数据类型原因,不能将页面的<asp:FileUpload>中以字符串值的方式传到js里调用.我一共找到了两个方法予以解决 ...