Vml+Js算法:完成5个小球在网页运动(碰壁返回)的游戏,详细注释

原创 2003年08月22日 11:07:00
<HTML xmlns:v>
<HEAD>
<META http-equiv='Content-Type' content='text/html;charset=gb2312'>
<Meta name='Gemeratpr' content='网络程序员伴侣(Lshdic)2004'>
<TITLE>物极必反</TITLE>
<STYLE>
v/:*{behavior:url(#default#VML);} //声明变量v为VML对象
*{font-size:12px;color:;}
a{text-decoration:none;}
a:hover{color:red;}
</STYLE>
</HEAD>
<BODY topmargin='2' leftmargin='2'>
<BASE target='_top'>
<div id=a style='table-Layout:fixed;width:100%;height:100%;border:1 solid black'></div>
<script>
//原作:风云舞,载自:http://www.lshdic.com/bbs
//以前在VB里很容易实现用我摸索的这套“物极必反”的算法完成物体碰壁返回的游戏,这次是DHTML版的,VB的下载来http://www.lshdic.com/download/lshdic/vb_xiaoguo.rar
var wid1,hei1,str1=""     //定义全局变量,为提高运行速度
var xx=new Array(0,0,0,0,0)  //分别存储5个球的X坐标
var yy=new Array(0,0,0,0,0)  //分别存储5个球的Y坐标
var xjia=new Array(false,true,false,true,false)  //分别判断5个球是否“物极”到了X极限
var yjia=new Array(true,false,true,false,true)   //分别判断5个球是否“物极”到了Y极限
var ovalwid=new Array(0,0,0,0,0) //直鸫娲?个球随机的大小
wid1=a.offsetWidth-70;hei1=a.offsetHeight-70    //得到容器的宽和高
for(i=0;i<5;i++){  //首次向容器内塞进5个球,球属性是随机的
tempx=Math.round(Math.random()*wid1);tempy=Math.round(Math.random()*hei1);
tempcolor="rgb("+Math.round(Math.random()*255)+","+Math.round(Math.random()*255)+","+Math.round(Math.random()*255)+")";
ovalwid[i]=Math.round(Math.random()*70)+20;
xx[i]=tempx;yy[i]=tempy
str1+="<v:oval fillcolor='"+tempcolor+"' style='position:absolute;left:"+tempx+";top:"+tempy+";z-index:"+i+";width:"+ovalwid[i]+";height:"+ovalwid[i]+";' id='oval1'/>"
}
a.innerHTML=str1; //插入STR1,STR1是5个VML球的代码
function play1(){  //播放函数
wid1=a.offsetWidth;hei1=a.offsetHeight
for(i=0;i<5;i++){   //循环5次
if(wid1-xx[i]<ovalwid[i]+5)xjia[i]=false //到达X极限,值为FALSE
if(xx[i]<5)xjia[i]=true    //到达X起点,值为TRUE
if(hei1-yy[i]<ovalwid[i]+5)yjia[i]=false
if(yy[i]<5)yjia[i]=true
if (xjia[i]==true)xx[i]+=5;else xx[i]-=5  //TRUE的话就++,FALSE的话就--
if (yjia[i]==true)yy[i]+=5;else yy[i]-=5
oval1[i].style.left=xx[i];oval1[i].style.top=yy[i]  //更新球的位置
}}
setInterval("play1()",10)  //10毫秒播放一次,一般CPU保证能消化~~~
</script>
</BODY>
</HTML>

Java 碰壁小球游戏实例教程

本教程会举例用Java实现简单的小球碰壁反弹游戏,效果如图所示: JFrame: 窗体部分 首先创建一个窗体界面,下面举一个简单的例子(Jframe是自己定义的类名,注意和JFrame的区...
  • Wiiix
  • Wiiix
  • 2015年07月31日 00:00
  • 1583

用Java实现小球碰壁反弹(算法十分简单)

核心代码如下: if(addX){ x+=3; }else{ x-=3; } if(addY){ y+=6; }else{ y-=6; } ...
  • wsdhla
  • wsdhla
  • 2014年07月23日 22:12
  • 2980

MFC游戏程序 - 碰撞的小球

windows程序设计做的练习。高中的时候就是靠物理吃饭的,学了windows编程很期待能用一用。这个程序就是模拟了许多刚体小球在平面上运动,当两球撞在一起时按照动量守恒定理改变两球的运动速度。地面和...
  • tiaotiaoyly
  • tiaotiaoyly
  • 2008年05月27日 16:07
  • 3917

JavaScript碰壁反弹效果

简介:小球在盒子中运动碰到边缘则弹回 主要思路及部分代码: 给小球定义速度变量speedX,speedY。以及偏移的总量x,y。   var speedX = 1;   var speed...
  • Agoni_lxh
  • Agoni_lxh
  • 2016年09月12日 16:28
  • 1378

c语言实现小球反弹

1.c语言实现小球反弹 #include #include #include void ball()//1.画出小球 { printf("\t\t\t◎"); } int main() { ...
  • qq_35038153
  • qq_35038153
  • 2017年04月19日 20:28
  • 853

java小程序(小球碰壁)

模拟一个小球碰壁后,沿光的反射方向运动的动画。 package mypro01; import java.awt.*; class Main { public static void ...
  • qq_33665647
  • qq_33665647
  • 2016年06月08日 19:00
  • 730

用java模拟球随机运动

         最近想写个泡泡龙的游戏,可是遇到几个问题,其中有一个是模拟球的运行轨迹.其实以前也想过类似的问题,最初的时候是用了一个Vista的泡泡屏保然后是玩一个桌球游戏,我都在想着到底怎样计算...
  • bird_wang
  • bird_wang
  • 2008年02月25日 20:15
  • 1937

Java课程设计---碰撞的小球

import java.awt.*; import java.awt.geom.*; import java.awt.event.*; import javax.swing.*; import...
  • nbda1121440
  • nbda1121440
  • 2011年01月17日 18:40
  • 5206

Android实现小球一直运动

private ObjectAnimator objectAnimator1; private ObjectAnimator objectAnimator2;private ObjectAnimato...
  • Happy_Develop_
  • Happy_Develop_
  • 2017年01月05日 12:01
  • 403

小球沿不同轨迹运动时水平方向速度的比较

探讨一个问题这两天网络流行如图的一个演示问题:有点像伽利略匹萨斜塔试验,打破了一些常识:走曲线的小球反而速度更快,奇怪也哉。粗略的数值模拟问题的分析用到的都是简单物理原理,只是计算繁琐一些,但是也没有...
  • stereohomology
  • stereohomology
  • 2017年02月13日 14:44
  • 1141
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Vml+Js算法:完成5个小球在网页运动(碰壁返回)的游戏,详细注释
举报原因:
原因补充:

(最多只允许输入30个字)