這篇文章主要介紹了jQuery實現碰到邊緣反彈的動畫,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
先上效果圖:
#錄出來有點卡頓的趕腳,其實還挺順暢的。
1.HTML:
<p class="box"></p>
#2.CSS:
body{ background:skyblue } .box{ position: absolute; top: 10px; left: 10px; width: 100px; height: 100px; background: white; }
3.JS:
$(function(){ var obj=$(".box"); var x=obj.offset().left;//盒子距离左部的位置 var y=obj.offset().top;//盒子距离顶部的位置 var objwid=obj.width();//盒子的宽 var objhei=obj.height(); var winwid=$(window).width();//页面的宽 var winhei=$(window).height(); var max=10;//设置最大视觉差,就是感觉这个距离刚好碰到 var winx=winwid-objwid-max;//盒子x轴最远达到的距离 var winy=winhei-objhei-max;//盒子y轴最远达到的距离 var sx=0;//x轴是否返回的状态,0是值++即正向移动,1是值--即返回 var sy=0; time1=setInterval(function(){ if(sx==0){ obj.css("left",x++); }else if(sx==1){ obj.css("left",x--); } if(x<=0){ sx=0; }else if(x>=winx){ sx=1; } if(sy==0){ obj.css("top",y++); }else if(sy==1){ obj.css("top",y--); } if(y<=0){ sy=0; }else if(y>=winy){ sy=1; } },1) })
這裡只是簡單的效果,由此可引發多個問題:
1)如果多個方塊出現,頁面會不會卡頓呢?
2)如果要實現多個方塊碰撞之後改變運動的位置,這個怎麼做呢?
3)方塊的初始位置能不能隨機呢?
4)多個方塊的速度怎樣設定不一樣呢
5)能不能做一個彈方塊的小遊戲?
上面是我整理給大家的,希望今後對大家有幫助。
相關文章:
#
以上是在jQuery中實現碰到邊緣反彈的動畫效果該如何做?的詳細內容。更多資訊請關注PHP中文網其他相關文章!