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 的强大绘图和动画功能,只需很少的代码就能实现让您屏息凝神的效果. 在线预览 源码下载 实现的代码. ...
随机推荐
- Call requires API level 7 (current min is 1):(问题解决)
在一个导入的项目里修改加入webView的时候设置缩放属性的设置报错: Call requires API level 7 (current min is 1): android.webkit.Web ...
- [poj3041]Asteroids(二分图的最小顶点覆盖)
题目大意:$N*N$的网格中有$n$颗行星,若每次可以消去一整行或一整列,求最小的攻击次数使得消去所有行星. 解题关键:将光束当做顶点,行星当做连接光束的边建图,题目转化为求该图的最小顶点覆盖,图的最 ...
- [转]SQL 模糊查询
在进行数据库查询时,有完整查询和模糊查询之分. 一般模糊查询语句如下: SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式: 1,% :表 ...
- 7-n!末尾有几个0
如何确定一个N!末尾有多少个零 转载 2015年08月30日 15:02:49 622 题目:1*2*3*……*100 求结果末尾有多少个零 分析:一般类似的题目都会蕴含某种规律或简便方法的,阶乘末尾 ...
- STM32 C++编程 005 I2c(Soft)类
使用 C++ 语言给 STM32 编写一个 I2c(Soft)类 我使用的STM32芯片:STM32F103ZET6 我们使用的STM32库版本:V3.5.0 注意: 想学习本套 STM32 C++编 ...
- PCL—点云分割(超体聚类) 低层次点云处理
博客转载自:http://www.cnblogs.com/ironstark/p/5013968.html 1.超体聚类——一种来自图像的分割方法 超体(supervoxel)是一种集合,集合的元素是 ...
- 杭电ACM刷题(2):1005,Number Sequence 标签: 杭电acmC语言 2017-05-11 22:43 116人阅读
Problem Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1 ...
- poj3171 Cleaning Shifts
传送门 题目大意 有一个大区间和n个小区间,每个小区间都有一个代价,求最少付出多少代价可以使得小区间完全覆盖大区间. 分析为了方便起见我们先将s变为2,其它的位置都对应更改以便后期处理.我们考虑以t1 ...
- thinkphp目录解析
- 使用Elasticsearch-jdbc为MySQL数据库建立索引
elasticsearch-jdbc 环境 Ubuntu 14.04 JDK 1.8.0_66 Elasticsearch 2.3.1 Elasticsearch-jdbc 2.3.1.0 Elast ...