时间:2021-05-26
本文实例讲述了js+html5实现的自由落体运动效果。分享给大家供大家参考,具体如下:
运行效果截图如下:
具体代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head> <title>canvas自由落体</title> <script type="text/javascript" > var canvasheight = 500; var canvaswidth = 500; var g = 9.8; var plusV = 0.5; function Block(vo, x, y, width, height, g, context) { var _self = this; _self.vo = vo || 0; _self.x = x; _self.y = y; _self.prevX = x; _self.prevY = y; _self.g = g; _self.height = height; _self.width = width; _self.prevTime = new Date().getTime(); context.fillStyle = "black"; _self.down = function () { var time = (new Date().getTime() - _self.prevTime) / 200, y = _self.vo * time + 1 / 2 * _self.g * time * time + _self.y; //console.log("down:time=" + time + ":y=" + y + ":" + _self.vo); if (y + _self.height >= canvasheight) { _self.g--; _self.vo = _self.g * time; _self.prevTime = new Date().getTime(); _self.up(); } else { context.clearRect(_self.prevX, _self.prevY - 1, _self.prevX + _self.height, _self.prevY + _self.width); context.fillRect(_self.x, y, _self.width, _self.height); _self.prevX = x; _self.prevY = y; setTimeout(function () { _self.down(); }, 30); } } _self.up = function () { var time = (new Date().getTime() - _self.prevTime) / 200, v = _self.vo - _self.g * time, y = canvasheight - _self.height - _self.vo * time + 1 / 2 * _self.g * time * time; //console.log("up:time=" + time + ":v=" + v); if (v <= 0) { _self.vo = 0; _self.y = y; _self.prevTime = new Date().getTime(); if (y + _self.height < canvasheight) { _self.down(); } else { return; } } else { context.clearRect(_self.prevX, _self.prevY - 1, _self.prevX + _self.height , _self.prevY + _self.width); context.fillRect(x, y, _self.width, _self.height); _self.prevX = x; _self.prevY = y; setTimeout(function () { _self.up(); }, 30); } } } window.onload = function () { var canvas = document.getElementById('canvas'); var context = canvas.getContext('2d'); height = canvas.offsetHeight; var block = new Block(0, 100, 0, 20, 20, g, context); block.down(); } </script></head><body><center><canvas id="canvas" width="500" height="500" style="background:#DDDDDD" ></canvas></center><input type="button" value="stop" onclick="stop()" /><input type="button" value="start" onclick="start()" /></body></html>更多关于JavaScript运动相关内容感兴趣的读者可查看本站专题:《JavaScript运动效果与技巧汇总》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了jQuery模拟物体自由落体运动的方法。分享给大家供大家参考,具体如下:运行效果截图如下:点击此处查看在线演示效果。完整实例代码点击此处本站下载。
一个基于jQuery的气泡动画插件,在指定区域上方(左/右)定时间隔产生气泡,然后随机水平速度进行仿自由落体运动。到达区域底部之后做弹跳运动,速度逐渐衰减。直至
本文实例为大家分享了js实现自由落体效果的具体代码,供大家参考,具体内容如下1.效果图2.实现分析利用Canvas画圆球、地面;1.下落过程物理知识回顾,物体下
在flash中绘图与动画制作占比同样重要,在与之结合的基础上能创作出很多日常生活中的情景,水滴下落,也就是自由落体运动就是一个很好的制作模型。 首先我们需
在flash中绘图与动画制作占比同样重要,在与之结合的基础上能创作出很多日常生活中的情景,水滴下落,也就是自由落体运动就是一个很好的制作模型。 首先我们需