[Canvas]碰撞球
观赏动态效果请点此下载并用Chrome/Firefox打开index.html
图例:
代码:
- <!DOCTYPE html>
- <html lang="utf-8">
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
- <head>
- <title>碰撞球 19.3.3 18:11 by:逆火 horn19782016@163.com</title>
- <style>
- #canvas{
- background:#ffffff;
- cursor:pointer;
- margin-left:10px;
- margin-top:10px;
- -webkit-box-shadow:3px 3px 6px rgba(0,0,0,0.5);
- -moz-box-shadow:3px 3px 6px rgba(0,0,0,0.5);
- box-shadow:3px 3px 6px rgba(0,0,0,0.5);
- }
- #controls{
- margin-top:10px;
- margin-left:15px;
- }
- </style>
- </head>
- <body onload="init()">
- <div id="controls">
- <input id='animateBtn' type='button' value='运动'/>
- </div>
- <canvas id="canvas" width="750px" height="500px" >
- 出现文字表示你的浏览器不支持HTML5
- </canvas>
- </body>
- </html>
- <script type="text/javascript">
- <!--
- var paused=true;
- animateBtn.onclick=function(e){
- paused=! paused;
- if(paused){
- animateBtn.value="运动";
- }else{
- animateBtn.value="暂停";
- window.requestAnimationFrame(animate);
- }
- }
- var ctx;// 绘图环境
- var balls;// 球数组
- function init(){
- var canvas=document.getElementById('canvas');
- canvas.width=750;
- canvas.height=500;
- ctx=canvas.getContext('2d');
- balls=[
- {
- x:150,
- y:250,
- lastX:150,
- lastY:250,
- vx:-7.2,
- vy:3.8,
- radius:25,
- innerColor:'rgba(255,25,0,1)',
- middleColor:'rgba(255,25,0,0.7)',
- outerColor:'rgba(255,25,0,0.5)',
- strokeStyle:'gray',
- },
- {
- x:650,
- y:50,
- lastX:150,
- lastY:250,
- vx:-8.2,
- vy:2.5,
- radius:25,
- innerColor:'rgba(113,232,227,1)',
- middleColor:'rgba(113,232,227,0.7)',
- outerColor:'rgba(113,232,227,0.5)',
- strokeStyle:'red',
- },
- {
- x:50,
- y:150,
- lastX:150,
- lastY:250,
- vx:12,
- vy:-14,
- radius:25,
- innerColor:'rgba(23,45,227,1)',
- middleColor:'rgba(23,45,227,0.7)',
- outerColor:'rgba(23,45,227,0.5)',
- strokeStyle:'blue',
- },
- ];
- };
- function update(){
- for(var i=0;i<balls.length;i++){
- var ball=balls[i];
- if(ball.x+ball.vx+ball.radius>ctx.canvas.width || ball.x+ball.vx-ball.radius<0){
- ball.vx=-ball.vx;
- }
- if(ball.y+ball.vy+ball.radius>ctx.canvas.height || ball.y+ball.vy-ball.radius<0){
- ball.vy=-ball.vy;
- }
- ball.x+=ball.vx;
- ball.y+=ball.vy;
- }
- }
- function draw(){
- ctx.clearRect(0,0,ctx.canvas.width,ctx.canvas.height);
- for(var i=0;i<balls.length;i++){
- var ball=balls[i];
- gradient=ctx.createRadialGradient(ball.x,ball.y,0,ball.x,ball.y,ball.radius);
- gradient.addColorStop(0.3,ball.innerColor);
- gradient.addColorStop(0.5,ball.middleColor);
- gradient.addColorStop(1.0,ball.outerColor);
- ctx.save();
- ctx.beginPath();
- ctx.arc(ball.x,ball.y,ball.radius,0,Math.PI*2,false);
- ctx.fillStyle=gradient;
- ctx.strokeStyle=ball.strokeStyle;
- ctx.fill();
- ctx.stroke();
- ctx.restore();
- }
- }
- function animate(){
- if(!paused){
- update();
- draw();
- setTimeout( function(){
- window.requestAnimationFrame(animate); /// 让浏览器自行决定帧速率
- }, 0.10 * 1000 );// 延时执行
- }
- }
- //-->
- </script>
2019年3月3日19点52分
[Canvas]碰撞球的更多相关文章
- [Canvas]碰撞球 增加小球间碰撞检测
请点此下载代码并用Chrome或是Firefox打开index.html 图例: 代码: <!DOCTYPE html> <html lang="utf-8"&g ...
- 2017了,回家前 "年末" 分享:下雨,飘雪,红包雨,碰撞球,自定义View
(本博客为原创:http://www.cnblogs.com/linguanh/) 目录: 效果展示 感想 代码拆解 开源地址 效果展示 有没有兴趣继续看下去,直接看下"颜值"是第 ...
- [Canvas]更多的球
欲观看动态效果请点此下载代码并用Chrome或者Firefox打开. 图例: 代码: <!DOCTYPE html> <html lang="utf-8"> ...
- (canvas)两小球碰撞后的速度问题研究
这两天在研究canvas碰撞 先把小球开始运动的图拿出来 参考了一下别的的代码,在两个小球碰撞处理上,我觉得不完善 怎么样处理才算完善呢,当然是要用高中物理学的动量守恒了和机械能守恒了 机械能守恒我其 ...
- 知乎背景图 canvas 效果
思路分析: 1.创造一块画布, 2.在画布内随机产生一些小球,小球位置,半径,颜射,大小,速度等都可以随机产生, 3.定义画小球函数与小球移动函数, 4.将每一个小球圆心都与其它小球链接, 5判断每一 ...
- 高阶自定义View --- 粒子变幻、隧道散列、组合文字
高阶自定义View --- 粒子变幻.隧道散列.组合文字 作者:林冠宏 / 指尖下的幽灵 掘金:https://juejin.im/user/587f0dfe128fe100570ce2d8 博客:h ...
- python写的屏保程序
__author__ = 'ChenYan' from random import randint from tkinter import * class Randball(): def __init ...
- unity5.x中的关节和布料
关节 布料 关节 铰链关节(Hinge Joint):将两个物体以链条的形式绑在一起,当力量过大超过链条的固定力矩时,两个物体就会产生相互的拉力. 固定关节(Fixed Joint): ...
- Python---TKinter项目实战---屏保
### 项目分析 - 屏保可以自己启动,也可以手动启动 - 一旦敲击键盘或者移动鼠标后,或者其他的引发时间,则停止 - 如果屏保是一幅画的话,则没有画框 - 图像的动作是随机的,具有随机性,可能包括颜 ...
随机推荐
- STM32F4 External interrupts
STM32F4 External interrupts Each STM32F4 device has 23 external interrupt or event sources. They are ...
- [C# 基础知识系列]专题八: 深入理解泛型(二)
引言: 本专题主要是承接上一个专题要继续介绍泛型的其他内容,这里就不多说了,就直接进入本专题的内容的. 一.类型推断 在我们写泛型代码的时候经常有大量的"<"和"& ...
- Revit MEP API找到连接器连接的连接器
通过conn.AllRefs;可以找到与之连接的连接器. //连接器连接的连接器 [TransactionAttribute(Autodesk.Revit.Attributes.Transaction ...
- Android:intent的基础
只有一个活动的应用也太简单了吧?没错,你的追求应该更高一点.不管你想创建多少 个活动,方法都和上一节中介绍的是一样的.唯一的问题在于,你在启动器中点击应用的图 标只会进入到该应用的主活动,那么怎样才能 ...
- 用 setMessage 方法灵活复用 UIAlertView
- Facebook工程师是如何改进他们Android客户端的
from://http://greenrobot.me/devnews/facebook-engineer-improve-android-app/ Facebook工程师是如何改进他们Android ...
- WordPress主题开发:网站搜索
调用方法一:手动输入html <form role="search" method="get" id="searchform" act ...
- JS --- 三目运算符
1.什么是三目运算:(布尔表达式 ? 值0:值1;) 5>3?alert('5大'):alert('3大'); 即 if(5>3){alert('5大')}else{alert('3 ...
- 关于android studio 出现Error:Execution failed for task ':app:preDebugAndroidTestBuild'. 的解决办法
Error:Execution failed for task ':app:preDebugAndroidTestBuild'. > Conflict with dependency 2018年 ...
- 《Redis设计与实现》
<Redis设计与实现> 基本信息 作者: 黄健宏 丛书名: 数据库技术丛书 出版社:机械工业出版社 ISBN:9787111464747 上架时间:2014-6-3 出版日期:2014 ...