jQuery實現(xiàn)碰到邊緣反彈的動畫效果
先上效果圖:
錄出來有點卡頓的趕腳,實際上還是挺順暢的。
1.HTML:
<div class="box"></div>
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;//設(shè)置最大視覺差,就是感覺這個距離剛好碰到 var winx=winwid-objwid-max;//盒子x軸最遠達到的距離 var winy=winhei-objhei-max;//盒子y軸最遠達到的距離 var sx=0;//x軸是否返回的狀態(tài),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) })
這里只是簡單的效果,由此可引發(fā)多個問題:
1)如果多個方塊出現(xiàn),頁面會不會卡頓呢?
2)如果要實現(xiàn)多個方塊碰撞之后改變運動的位置,這個怎么做呢?
3)方塊的初始位置能不能隨機呢?
4)多個方塊的速度怎樣設(shè)置不一樣呢
5)能不能做一個彈方塊的小游戲?
總結(jié)
以上所述是小編給大家介紹的jQuery實現(xiàn)碰到邊緣反彈的動畫效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
使用jQuery向asp.net Mvc傳遞復(fù)雜json數(shù)據(jù)-ModelBinder篇
jQuery提供的ajax方法能很方便的實現(xiàn)客戶端與服務(wù)器的異步交互,在asp.net mvc 框架使用jQuery能很方便地異步獲取提交數(shù)據(jù),給用戶提供更好的體驗!2010-05-05jquery offset函數(shù)應(yīng)用實例
點擊一個按鈕,然后在按鈕的下方顯示一個div,當按鈕位于角落時,div的位置設(shè)定就需要調(diào)整,不然,div將顯示不完全.我打算使用offset()方法實現(xiàn)此功能2012-11-11清空元素html("") innerHTML="" 與 empty()的區(qū)別和應(yīng)用(推薦)
這篇文章主要介紹了清空元素html("")、innerHTML="" 與 empty()的區(qū)別和應(yīng)用,詳細介紹了三者之間的原理及應(yīng)用,需要的朋友可以參考下2017-08-08jQuery替換節(jié)點用法示例(使用replaceWith方法)
這篇文章主要介紹了jQuery替換節(jié)點的方法,結(jié)合簡單實例形式分析了jQuery使用replaceWith方法替換P標簽顯示內(nèi)容的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-09-09