Javascript 多物体运动的实现

这篇文章主要介绍了Javascript 多物体运动的实现,需要的朋友可以参考下

我们先来看下之前的运动的代码,是否支持多物体运动,会出现怎么样的问题。

代码如下:

1 <style type="text/css">
2             div {
3                 width: 100px;
4                 height: 50px;
5                 background: red;
6                 margin: 10px;
7             }
8 </style>

代码如下:

1 <body>
2         <div></div>
3         <div></div>
4         <div></div>
5  </body>

以下是Javascript 代码:

代码如下:

 1 <script type="text/javascript">
 2             window.onload = function() {
 3                 var aDiv = document.getElementsByTagName(‘div‘);
 4                 for (var i = 0; i < aDiv.length; i++) {
 5                     aDiv[i].onmouseover = function() {
 6                         startMove(this, 400);
 7                     };
 8                     aDiv[i].onmouseout = function() {
 9                         startMove(this, 100);
10                     };
11                 }
12             }
13             var timer = null;
14             function startMove(obj, iTarget) {
15                 clearInterval(timer);
16                 timer = setInterval(function() {
17                     var speed = (iTarget - obj.offsetWidth) / 6;
18                     speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
19                     if (obj.offsetWidth == iTarget) {
20                         clearInterval(timer);
21                     } else {
22                         obj.style.width = obj.offsetWidth + speed + ‘px‘;
23                     }
24                 }, 30);
25             }
26         </script>

此时当鼠标移入到第一个div 时,他是正常运行的。但是如果现在又移动到第二个或者第三个div时候就会出现bug。

image 这个是什么原因呢? 看图可以看出并没有运动完成。实际上是这样的,

整个程序就一个定时器, 比如第一个div开始动了,第二个div 鼠标移入了 前一个定时器就被干掉了,那么自然就卡在那里了。

所以最大的问题就是整个程序就只有一个定时器。那么怎么解决这个问题呢?

解决方案:

其实很简单,把定时器作为一个物体的属性加上,那么每个物体都有一个定时器在,当关闭定时器的时候是关闭物体上的定时器,开也是物体上的定时器

那么他们之间就可以完全互不干扰的运行。

看下修改后的Javascript代码:

代码如下:

 1 <script type="text/javascript">
 2             window.onload = function() {
 3                 var aDiv = document.getElementsByTagName(‘div‘);
 4                 for (var i = 0; i < aDiv.length; i++) {
 5                     aDiv[i].timer=null; // 把定时器作为一个物体的属性存起来
 6                     aDiv[i].onmouseover = function() {
 7                         startMove(this, 400);
 8                     };
 9                     aDiv[i].onmouseout = function() {
10                         startMove(this, 100);
11                     };
12                 }
13             }
14             function startMove(obj, iTarget) {
15                 clearInterval(obj.timer);
16                 obj.timer = setInterval(function() {
17                     var speed = (iTarget - obj.offsetWidth) / 6;
18                     speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
19                     if (obj.offsetWidth == iTarget) {
20                         clearInterval(obj.timer);
21                     } else {
22                         obj.style.width = obj.offsetWidth + speed + ‘px‘;
23                     }
24                 }, 30);
25             }
26         </script>

这样程序就没有问题了,能够支持多物体的运动。


下面是一个多物体运动的实例哦。


效果:

思路:

利用setInterval计时器进行运动,offsetWidth实现宽度的变动,在用onmouseover将终点和所选中的DIV放入参数再进行缓冲运动。

代码如下:

 1 <head runat="server">
 2     <title></title>
 3     <style type="text/css">
 4         div
 5         {
 6             width: 100px;
 7             height: 50px;
 8             background: #0000FF;
 9             margin: 10px;
10         }
11     </style>
12     <script type="text/javascript">
13         window.onload = function () {
14             var oDiv = document.getElementsByTagName(‘div‘);
15             for (var i = 0; i < oDiv.length; i++) {
16                 oDiv[i].timer = null;           //给买个DIV做个标记,用以关闭相应DIV的定时器
17                 oDiv[i].onmouseover = function () {
18                     move(this, 400);        //给定时器输出参数
19                 }
20                 oDiv[i].onmouseout = function () {
21                     move(this, 100);
22                 }
23             }
24         };
25         function move(div, end) {
26             clearInterval(div.timer);
27             div.timer = setInterval(function () {
28                 var speed = (end - div.offsetWidth) / 5;        //(终点-要走的宽度)/缩放系数=DIV移动的速度
29                 speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);   //小数取整,也就是进位取整
30                 if (div.offsetWidth == end) {       //当到达终点时关闭计时器
31                     clearInterval(div.timer);
32                 }
33                 else {
34                     div.style.width = div.offsetWidth + speed + ‘px‘;   //移动DIV的宽度
35                 }
36             }, 30)
37         }
38     </script>
39 </head>
40 <body>
41     <div>
42     </div>
43     <div>
44     </div>
45     <div>
46     </div>
47 </body>
时间: 2024-11-01 16:31:13

Javascript 多物体运动的实现的相关文章

Javascript 多物体运动——逐行分析代码,让你轻松了运动的原理

我们先来看下之前的运动的代码,是否支持多物体运动,会出现怎么样的问题. <style type="text/css"> div { width: 100px; height: 50px; background: red; margin: 10px; } </style> <body> <div></div> <div></div> <div></div> </body>

201509010 javascript事件-多物体运动

问题代码: <!doctype html> <html> <head> <meta charset="utf-8"> <title>多物体运动</title> <style> *{margin:0; padding:0;} body{ background:#D1D1D1} ul,li{list-style:none;} ul li{width:200px;height:100px; backgroun

js动画之多物体运动

多个物体这不能使用一个定时器了,要给每个物体一个定时器 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>多物体运动</title> <style> body{margin: 0px;padding: 0px;} .animation{ background-color: green; marg

多物体运动

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content=

Javascript 链式运动框架——逐行分析代码,让你轻松了运动的原理

所谓链式运动,就是一环扣一环.我们的很多运动实际上来说指的就是分阶段的,第一个阶段动完,下个阶段开始动.这个链式运动框架就是用来处理这些问题的. 我们先来看下之前的运动框架,以下是Javascript 代码 function getStyle(obj, name) { if (obj.currentStyle) { return obj.currentStyle[name]; } else { return getComputedStyle(obj, null)[name]; } } funct

基于Aforge的物体运动识别-入门

基于Aforge的物体运动识别-入门篇chatbot人工智能机器人开发,提供教学视频>>>   0 收藏(2) 本文来自http://blog.csdn.net/hellogv/ ,引用必须注明出处! 最近看到越来越多人在做物体运动识别(例如:"第六感"中的指套),而且我最近也有点闲空,所以也来玩玩.....大多数人都是用Opencv来做,那我就不做重复的工作了,换个别的开源类库~~~Aforge. 来自百度知道的Aforge介绍:AForge.NET 是一个专门为开

Unity游戏开发的数学与物理 4 ( 在物体运动中加入重力 )

在物体运动中加入重力 实现注意: 使用级数叠加算法 y += vy; //对位置上的加速度 vy += GR: //速度上的加速度 GR为重力加速度,在计算机中使用的加速度单位是特殊的dot/F^2 (像素/平方帧),而不是9.8 m/s^2 (米/平方秒) 微分是一种操作,是一种求微分系数的操作, 而微分系数是指函数关于某个值的变化率,这个概念在游戏开发中经常被用来考察某个函数变化的速度; f(x)关于x的变化率,基本的微分公式 d/dx(x) = 1 d/dx(x^2) = 2x d/dx(

【unity3d游戏开发脚本笔记之一:坐标系选择对物体运动的影响】

时间:2016年9月24日17:38:21   作者:yexiaopeng 博客园     在unity3d的世界中,其坐标系可分为四种,世界坐标系-WorldSpace   本地坐标系-LocalSpace  屏幕坐标系-ScreenSpace 视口坐标-ViewPortSpace.其中作者本人当前面对的是世界坐标系和本地坐标系的问题.本文讲诉这两个坐标系对物体运动的影响,其他的坐标系涉及到再做说明.    在学习unity3d官方例子(太空大战)的过程中,编写脚本对陨石的运动进行控制时发现旋

js 多物体运动框架

多物体运动框架例子:多个Div,鼠标移入biankuan 单定时器,存在问题每个Div一个定时器总结:参数问题:当运动当前的div的时候可以传参数onStart(obj,tag):obj为当前运动的div 调用时用thistag表示运动的终点距离开一个定时器(当三个div一起运动时会卡)所以利用for循环开三个定时器步骤:1.设置定时器 var timer=null:2.关闭定时器clearInterval(obj.timer);3.开启定时器:obj.timer=setInterval(fun