最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS实现碰撞检测步骤详解

来源:动视网 责编:小采 时间:2020-11-27 19:47:46
文档

JS实现碰撞检测步骤详解

JS实现碰撞检测步骤详解:这次给大家带来JS实现碰撞检测步骤详解,JS实现碰撞检测的注意事项有哪些,下面就是实战案例,一起来看一下。<!doctype html> <html> <head> <meta charset="utf-8"> <title> J
推荐度:
导读JS实现碰撞检测步骤详解:这次给大家带来JS实现碰撞检测步骤详解,JS实现碰撞检测的注意事项有哪些,下面就是实战案例,一起来看一下。<!doctype html> <html> <head> <meta charset="utf-8"> <title> J
 这次给大家带来JS实现碰撞检测步骤详解,JS实现碰撞检测的注意事项有哪些,下面就是实战案例,一起来看一下。

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title> JS碰撞检测</title>
<style>
p{width:100px;
 height:100px;
}
#box{background:red; position:absolute; }
#box1{background:green;position:absolute;top:300px; left:300px;}
</style>
<script>
//两个碰撞的盒子。是建立在一个不动的基础上。所以可以根据不动的盒子求出四个方向的left和top值。然后再判断其是否碰撞,且碰撞的过程随时改变其层级,(原需 var 8个变量,现在只需4个变量)
function collText(obj,left,top,obj1){
 var l1=obj.offsetLeft-obj.offsetWidth;
 var t1=obj.offsetTop-obj.offsetHeight;
 var r1=obj.offsetLeft+obj.offsetWidth;
 var b1=obj.offsetTop+obj.offsetHeight;
 if(left<l1||top<t1||left>r1||top>b1){
 obj.style.zIndex=3;
 obj1.style.zIndex=1;
 return true;
 }else{
 obj.style.zIndex=1;
 obj1.style.zIndex=3;
 return false;
 }
};
window.onload=function(){
 var oBox=document.getElementById('box');
 var oBox1=document.getElementById('box1');
 oBox.onmousedown=function(ev){
 var oEvent= ev || event;
 var disX=oEvent.clientX-oBox.offsetLeft;
 var disY=oEvent.clientY-oBox.offsetTop;
 document.onmousemove=function(ev){
 var oEvent= ev || event;
 var l=oEvent.clientX-disX;
 var t=oEvent.clientY-disY;
 oBox.style.left=l+'px' ;
 oBox.style.top=t+'px' ;
 if(collText(oBox1,l,t,oBox)){
 oBox1.style.background='green';
 }else{
 oBox1.style.background='yellow';
 }
 };
 document.onmouseup=function(){
 document.onmousemove=null;
 document.onmouseup=null;
 oBox.reseaseCapture&&oBox.reseaseCapture();
 };
 oBox.setCapture&&oBox.setCapture();
 return false;
 }
 oBox1.onmousedown=function(ev){
 var oEvent= ev || event;
 var disX1=oEvent.clientX-oBox1.offsetLeft;
 var disY1=oEvent.clientY-oBox1.offsetTop;
 document.onmousemove=function(ev){
 var oEvent= ev || event;
 var le=oEvent.clientX-disX1;
 var to=oEvent.clientY-disY1;
 oBox1.style.left=le+'px' ;
 oBox1.style.top=to+'px' ;
 if(collText(oBox,le,to,oBox1)){
 oBox.style.background='red';
 }else{
 oBox.style.background='#000';
 }
 };
 document.onmouseup=function(){
 document.onmousemove=null;
 document.onmouseup=null;
 oBox1.reseaseCapture&&oBox1.reseaseCapture();
 }
 oBox1.setCapture&&oBox1.setCapture();
 return false;
 }
}
</script>
</head>
<body>
<p id="box"></p>
<p id="box1"></p>
</body>
</html>

这里使用在线HTML/CSS/JavaScript运行工具http://tools.jb51.net/code/HtmlJsRun测试运行效果如下(碰撞判定时颜色改变):

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

react-navigation使用步骤详解

vue父子组件传值及slot应用步骤详解

文档

JS实现碰撞检测步骤详解

JS实现碰撞检测步骤详解:这次给大家带来JS实现碰撞检测步骤详解,JS实现碰撞检测的注意事项有哪些,下面就是实战案例,一起来看一下。<!doctype html> <html> <head> <meta charset="utf-8"> <title> J
推荐度:
标签: 方法 检测 实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top