<del id="d4fwx"><form id="d4fwx"></form></del>
      <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

            <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
          • 利用JavaScript如何實(shí)現(xiàn)一個(gè)碰撞檢測(cè)功能示例-創(chuàng)新互聯(lián)

            利用JavaScript如何實(shí)現(xiàn)一個(gè)碰撞檢測(cè)功能示例?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。

            專注于為中小企業(yè)提供成都網(wǎng)站制作、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)襄垣免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

            具體如下:

            <!doctype html>
            <html>
            <head>
            <meta charset="utf-8">
            <title>www.jb51.net JS碰撞檢測(cè)</title>
            <style>
            div{width:100px;
              height:100px;
            }
            #box{background:red; position:absolute; }
            #box1{background:green;position:absolute;top:300px; left:300px;}
            </style>
            <script>
            //兩個(gè)碰撞的盒子。是建立在一個(gè)不動(dòng)的基礎(chǔ)上。所以可以根據(jù)不動(dòng)的盒子求出四個(gè)方向的left和top值。然后再判斷其是否碰撞,且碰撞的過程隨時(shí)改變其層級(jí),(原需 var 8個(gè)變量,現(xiàn)在只需4個(gè)變量)
            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>
            <div id="box"></div>
            <div id="box1"></div>
            </body>
            </html>

            關(guān)于利用JavaScript如何實(shí)現(xiàn)一個(gè)碰撞檢測(cè)功能示例問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

            文章題目:利用JavaScript如何實(shí)現(xiàn)一個(gè)碰撞檢測(cè)功能示例-創(chuàng)新互聯(lián)
            URL網(wǎng)址:http://www.jbt999.com/article28/shhjp.html

            成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站搜索引擎優(yōu)化、標(biāo)簽優(yōu)化、網(wǎng)站內(nèi)鏈、App開發(fā)、網(wǎng)站制作

            廣告

            聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

            成都seo排名網(wǎng)站優(yōu)化

              <del id="d4fwx"><form id="d4fwx"></form></del>
              <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

                    <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
                  • 2025无码视频 | 在线无码高清观看 | 麻豆国产原创 | 欧美日韩一区二区三区四区 | 青青草免费视频日本 |