js實現(xiàn)div色塊碰撞
更新時間:2020年01月16日 10:35:09 作者:SSSkyCong
這篇文章主要為大家詳細介紹了js實現(xiàn)div色塊碰撞,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了js實現(xiàn)div色塊碰撞的具體代碼,供大家參考,具體內(nèi)容如下
描述:
生成兩個div色塊,一個可以拖動,一個不可以,用拖動的去撞擊不能動的,會將這個色塊隨機撞到一個位置,改變顏色。
效果:
實現(xiàn):
js文件:
function DragObj(_obj) { this.obj=_obj; this.point={}; this.moveBool=false; this.obj.self=this; this.obj.addEventListener("mousedown",this.mouseHandler); this.obj.addEventListener("mouseup",this.mouseHandler); this.obj.addEventListener("mousemove",this.mouseHandler); this.obj.addEventListener("mouseleave",this.mouseHandler); } DragObj.prototype={ mouseHandler:function (e) { if(!e){ e=window.event; } if(e.type=="mousedown"){ this.self.moveBool=true; this.self.point.x=e.offsetX; this.self.point.y=e.offsetY; }else if(e.type=="mousemove"){ if(!this.self.moveBool) return; this.self.obj.style.left=(e.clientX-this.self.point.x)+"px" this.self.obj.style.top=(e.clientY-this.self.point.y)+"px" }else if(e.type=="mouseup" || e.type=="mouseleave"){ this.self.moveBool=false; } }, removeEvent:function () { this.obj.removeEventListener("mousedown",this.mouseHandler); this.obj.removeEventListener("mouseup",this.mouseHandler); this.obj.removeEventListener("mousemove",this.mouseHandler); this.obj.removeEventListener("mouseleave",this.mouseHandler); this.obj=null; this.point=null; } }; var HitTest=HitTest || (function () { return { to:function (display0,display1) { var rect=display0.getBoundingClientRect(); var rect1=display1.getBoundingClientRect(); if(rect.left>=rect1.left && rect.left<=rect1.left+rect1.width && rect.top>=rect1.top && rect.top<=rect1.top+rect1.height){ return true; } if(rect.left+rect.width>=rect1.left && rect.left+rect.width<=rect1.left+rect1.width && rect.top>=rect1.top && rect.top<=rect1.top+rect1.height){ return true; } if(rect.left>=rect1.left && rect.left<=rect1.left+rect1.width && rect.top+rect.height>=rect1.top && rect.top+rect.height<=rect1.top+rect1.height){ return true; } if(rect.left+rect.width>=rect1.left && rect.left+rect.width<=rect1.left+rect1.width && rect.top+rect.height>=rect1.top && rect.top+rect.height<=rect1.top+rect1.height){ return true; } } } })(); var LoadImg=LoadImg || (function () { return { load:function (listSrc,callBack) { this.callBack=callBack; this.listSrc=listSrc; this.num=0; this.imgArr=[]; var img=new Image(); img.addEventListener("load",this.loadHandler.bind(this)); img.src=listSrc[0]; }, loadHandler:function (e) { if(!e){ e=window.event; } e.currentTarget.removeEventListener ("load",this.loadHandler.bind(this)); this.imgArr[this.num]=e.currentTarget; if(this.num==this.listSrc.length-1){ this.callBack(this.imgArr) return; } var img=new Image(); this.num++; img.addEventListener("load",this.loadHandler.bind(this)); img.src=this.listSrc[this.num]; } } })();
html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> div{ width: 200px; height: 200px; position: absolute; } </style> <script src="js/dragObj.js"></script> </head> <body> <div id="div0"></div> <div id="div1"></div> <script> window.addEventListener("mousedown",mousedownHandler);//生成一個 function mousedownHandler(e) { if(!e){ e=window.event; } e.preventDefault(); } var div0=document.getElementById("div0"); var div1=document.getElementById("div1"); div0.style.backgroundColor=randomColor(); div1.style.backgroundColor=randomColor(); randomPosition(div0) randomPosition(div1) var drag0=new DragObj(div0); div0.addEventListener("mousemove",mouseMoveHandler) function randomColor() { var str="#"; for(var i=0;i<3;i++){ var color=Math.floor(Math.random()*256).toString(16); if(color.length<2){ color="0"+color; } str+=color; } return str; } function randomPosition(div) { div.style.left=Math.random()*(document.documentElement.clientWidth-50)+"px"; div.style.top=Math.random()*(document.documentElement.clientHeight-50)+"px"; } function mouseMoveHandler(e) { if(!e){ e=window.event; } if(!drag0.moveBool) return; if(HitTest.to(div0,div1)){ randomPosition(div1); div1.style.backgroundColor=randomColor(); } } </script> </body> </html>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序整個頁面的自動適應(yīng)布局的實現(xiàn)
這篇文章主要介紹了微信小程序整個頁面的自動適應(yīng)布局的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07JS動態(tài)添加的div點擊跳轉(zhuǎn)到另一頁面實現(xiàn)代碼
這篇文章主要介紹了JS動態(tài)添加的div點擊跳轉(zhuǎn)到另一頁面實現(xiàn)代碼,需要的朋友可以參考下2017-09-09關(guān)于Aptana Studio生成自動備份文件的解決辦法
關(guān)于Aptana Studio生成自動備份文件的解決辦法2009-12-12js數(shù)值和和字符串進行轉(zhuǎn)換時可以對不同進制進行操作
這篇文章主要介紹了js數(shù)值和和字符串進行轉(zhuǎn)換時可以對不同進制進行操作,需要的朋友可以參考下2014-03-03