我写的是非常非常基础的根据其中一个 obj 页面元素的上下左右,与另一个 obj 页面元素的上下左右比较之后判断是否碰撞,具体代码如下。觉得这么写不是特别的高效,判断太多了,有没有好一点的方式?
function getRect(obj){
return obj.getBoundingClientRect();
}
function crash(obj1,obj2){
var first_Rect = getRect(obj1);
var second_rect = getRect(obj2);
var firstLeft = getRect(obj1).left;
var firstTop = getRect(obj1).top;
var firstRight = getRect(obj1).right;
var firstBottom = getRect(obj1).bottom;
var secondLeft = getRect(obj2).left;
var secondTop = getRect(obj2).top;
var secondRight = getRect(obj2).right;
var secondBottom = getRect(obj2).bottom;
if(firstLeft > secondRight||firstRight < secondLeft||firstTop > secondBottom||firstBottom < secondTop){
return false;
}else{
return true;
}
}
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.