第七讲:HTML5中的canvas两个小球全然弹性碰撞

2024-01-21 05:20

本文主要是介绍第七讲:HTML5中的canvas两个小球全然弹性碰撞,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

<html><head><title>小球之间的碰撞(全然弹性碰撞)</title><script src="../js/jscex.jscexRequire.min.js" type="text/javascript"></script></head><body><canvas id="mc" width="1200px" height="600px"></canvas><script type="text/javascript">var canvas = document.getElementById('mc');var cxt = canvas.getContext('2d');//设置画布背景颜色cxt.fillStyle = "#030303";cxt.fillRect(0, 0, canvas.width, canvas.height);var cyc = 20;var balls = [];//定义一个向x轴正前方运动var ball_1 = {x:100,y:550,r:50,vx:500,vy:0};//定义一个向x轴反方向运动var ball_2 = {x:1000,y:550,r:50,vx:-400,vy:0};balls.push(ball_1);balls.push(ball_2);cxt.fillStyle = "#030303";cxt.fillRect(0,0,canvas.width,canvas.height);//画出两个小球function init () {cxt.fillStyle = "#fff";for(var i in balls){cxt.beginPath();cxt.arc(balls[i].x,balls[i].y,balls[i].r,0,Math.PI*2,true);cxt.closePath();cxt.fill();}	}init();var ct //动态绘出小球相碰撞的情形var somethingAsync = eval(Jscex.compile("async", function (ct) {while (true) {cxt.fillStyle = "rgba(0,0,0,1)";cxt.fillRect(0,0,canvas.width,canvas.height);cxt.fillStyle = "#fff";//小球运动for(var i in balls){balls[i].x += balls[i].vx *cyc /1000;cxt.beginPath();cxt.arc(balls[i].x,balls[i].y,balls[i].r,0,Math.PI*2,true);cxt.closePath();cxt.fill();//小球触碰左右两个墙壁if(balls[i].x + balls[i].r >= canvas.width || balls[i].x <= balls[i].r){balls[i].vx *= -1;}}//推断两个小球是否相互碰撞if(Math.abs(ball_1.x - ball_2.x) <= 2*50){var temp = ball_1.vx;ball_1.vx = ball_2.vx;ball_2.vx = temp;}$await(Jscex.Async.sleep(cyc,ct));	}		}));//手动控制小球的运动function Button1_onclick() {ct.cancel();}function Button2_onclick() {ct = new Jscex.Async.CancellationToken();somethingAsync(ct).start();}</script><br><br /><br /><input id="Button2" class="css3btn" type="button" value="run" οnclick="return Button2_onclick()" /><input id="Button1" class="css3btn" type="button" value="stop" οnclick="return Button1_onclick()" /></body>
</html>

这篇关于第七讲:HTML5中的canvas两个小球全然弹性碰撞的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628468

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo