原生JavaScript之实战 模拟重力场(篮球)

成品图如下所示:

点击篮球让篮球掉下

 

 搭建HTML+CSS代码

html:

1 <div id="demo"></div>

 

 css:

div{
    width:100px;
    height:100px;
    background-image:url("../images/lanqiu.png");
    background-size: 100px 100px;
    position: absolute;
    left: 0px;
    top: 0px;
    border-radius: 50% 50%;
    }

 

js代码(注释都在里面):

 1      var oDiv = document.getElementById('demo');
 2         var timer = null;
 3         
 4         
 5         oDiv.onclick = function (){ //点击篮球触发运动函数
 6             startMove(this);
 7         }
 8         
 9         
10         function startMove (dom){//运动函数
11             clearInterval(dom.timer);//清理定时器
12             var iSpeedX = 6; //横向初速度
13             var iSpeedY = 8; //竖向初速度
14             var g = 3; //重力初速度
15 
16             dom.timer = setInterval(function (){ //开启定时器
17                 iSpeedY += g; //竖向坐标每次加等于本身
18                 var newTop = dom.offsetTop + iSpeedY; //篮球自身纵坐标加上竖向速度值付给newTop
19                 var newLeft = dom.offsetLeft + iSpeedX;//篮球自身横坐标加上横向速度值付给newLeft
20                 if(newTop >= document.documentElement.clientHeight - dom.clientHeight){ //newTop如果大于或等于浏览器窗口高度减去篮球自身高度
21                     iSpeedY *= -1; //当篮球到达窗口底部的时候纵向速度乘以-1,使篮球反向运动
22                 
23                     //加上能量损失,让篮球碰到四壁的时候,能量减小
24                     iSpeedY *= 0.8;  //纵向速度乘以0.8,会越乘越小
25                     iSpeedX *= 0.8;  //横向速度乘以0.8,会越乘越小
26                     newTop = document.documentElement.clientHeight - dom.clientHeight;
27                     //为了防止篮球大于等于底部的时候略过浏览器窗口底边出现滚动条,所以让newTop值直接等于浏览器窗口高度减去自身高度
28                 }
29                 if(newTop <= 0){ //当newTop值反向走到流浪器窗口顶部的时候,即等于0
30                     iSpeedY *= -1; //则继续以纵向速度乘以-1,继续反向运动
31                                     
32                     //加上能量损失,让篮球碰到四壁的时候,能量减小
33                     iSpeedY *= 0.8;//纵向速度乘以0.8,会越乘越小
34                     iSpeedX *= 0.8;//横向速度乘以0.8,会越乘越小
35                     newTop = 0; //防止略过窗口,直接让newTop值等于0
36                 }
37                 if(newLeft >= document.documentElement.clientWidth - dom.clientWidth){//newLeft如果大于或等于流浪器窗口宽度减去篮球自身宽度
38                     iSpeedX *= -1;//则继续以横向速度乘以-1,继续反向运动
39                                     
40                     //加上能量损失,让篮球碰到四壁的时候,能量减小
41                     iSpeedY *= 0.8;//纵向速度乘以0.8,会越乘越小
42                     iSpeedX *= 0.8;//横向速度乘以0.8,会越乘越小
43                     newLeft = document.documentElement.clientWidth - dom.clientWidth;
44                     //为了防止篮球大于等于宽度的时候略过浏览器窗口宽度出现横向滚动条,所以让newTop值直接等于浏览器窗口宽度减去自身宽度
45                 }
46                 if(newLeft <= 0){ //当newLeft值反向走到流浪器窗口最左侧的时候,即等于0
47                     iSpeedX *= -1;//则继续以横向速度乘以-1,继续反向运动
48                                     
49                     //加上能量损失,让篮球碰到四壁的时候,能量减小
50                     iSpeedY *= 0.8;//纵向速度乘以0.8,会越乘越小
51                     iSpeedX *= 0.8;//横向速度乘以0.8,会越乘越小
52                     newLeft = 0;//防止略过窗口,直接让newTop值等于0
53                 }
54                 if(Math.abs(iSpeedX) < 1 && Math.abs(iSpeedY) < 1){ //当横向速度和纵向速度小于1的时候,横向纵向速度等于0
55                     iSpeedX = 0;
56                     iSpeedY = 0;
57                 }
58                 if(iSpeedX == 0 && iSpeedY == 0 && newTop == document.documentElement.clientHeight - dom.clientHeight){
59                     //当横向速度和纵向速度等于0并且newTop值等于窗口高度减去自身高度的时候
60                     clearInterval(dom.timer);//清理定时器,停止运动
61                 }else{//停了运动就跟着停止了
62                     dom.style.top = newTop + 'px'; 
63                     dom.style.left = newLeft + 'px';    
64                 }
65             },30);//每30毫秒运行一次
66         }

 

 

谢谢观看,如有大佬经过请多指教!    谢谢观看,如有大佬经过请多指教!   谢谢观看,如有大佬经过请多指教!

posted @ 2019-05-10 10:43  杨培贤  阅读(582)  评论(0编辑  收藏  举报