日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
JS游戲開發(fā)(五)可移動(dòng)地圖的實(shí)現(xiàn)

一、前言

這一講的內(nèi)容很簡(jiǎn)單,大家理解起來(lái)會(huì)更快。因此我只對(duì)重點(diǎn)加以分析,其他的就輪到大家思考哦!首先來(lái)說(shuō),我對(duì)游戲開發(fā)可以算是不怎么深入,因?yàn)楝F(xiàn)在的程序員愛用canvas,我卻就只會(huì)拿幾個(gè)div湊和。不過(guò)沒關(guān)系,因?yàn)樽龀鰜?lái)的同樣是游戲。哈!廢話最近有點(diǎn)多,望大家原諒。接下來(lái)請(qǐng)看代碼解析。

二、代碼講解

今天調(diào)一下講解順序,先看代碼后看圖片:

 
 
 
  1. var subtractedMargin = 0;  
  2. var subtractedMarginL = 0;  
  3. var mousedown = 0;  
  4. var toright;  
  5. var toleft;  
  6. var todown;  
  7. var toup;  
  8. window.onmouseup = function(){  
  9.     mousedown = 0;  
  10.     clearInterval(toright);  
  11.     clearInterval(toleft);  
  12.     clearInterval(todown);  
  13.     clearInterval(toup);  
  14. }  
  15. function mapMove(direction)  
  16. {  
  17.     switch(direction){  
  18.         case "down":  
  19.             subtractedMargin -= 15;  
  20.  
  21.             $("#ID_IMG_MAP").animate({marginTop: subtractedMargin + "px"}, 120);            
  22.             break;           
  23.         case "up":  
  24.             subtractedMargin += 15;  
  25.             $("#ID_IMG_MAP").animate({marginTop: subtractedMargin + "px"}, 120);               
  26.             break;           
  27.         case "right":  
  28.             subtractedMarginL -= 15;   
  29.             $("#ID_IMG_MAP").animate({marginLeft: subtractedMarginL + "px"}, 120);           
  30.             break;       
  31.         case "left":  
  32.             subtractedMarginL += 15;  
  33.             $("#ID_IMG_MAP").animate({marginLeft: subtractedMarginL + "px"}, 120);           
  34.             break;  
  35.     }  
  36.     if(subtractedMarginL < -415){  
  37.         clearInterval(toright);  
  38.         clearInterval(toleft);  
  39.     }  
  40.     if(subtractedMarginL > -20){  
  41.         clearInterval(toright);  
  42.         clearInterval(toleft);  
  43.     }  
  44.     if(subtractedMargin < -640){  
  45.         clearInterval(todown);  
  46.         clearInterval(toup);  
  47.     }  
  48.     if(subtractedMargin > -20){  
  49.         clearInterval(todown);  
  50.         clearInterval(toup);  
  51.     }  
  52. }  
  53. $("body").ready(function(){  
  54.     $("#ID_DIV_TORIGHT").mousedown(function(){  
  55.         mousedown = 1;  
  56.         if(subtractedMarginL > -415 && mousedown == 1){  
  57.             mapMove("right");  
  58.             toright = setInterval(function(){mapMove("right");}, 120);  
  59.         }  
  60.     });  
  61.     $("#ID_DIV_TOLEFT").mousedown(function(){  
  62.         mousedown = 1;  
  63.         if(subtractedMarginL < -20 && mousedown == 1){  
  64.             mapMove("left");  
  65.             toleft = setInterval(function(){mapMove("left");}, 120);  
  66.         }  
  67.     });  
  68.     $("#ID_DIV_TODOWN").mousedown(function(){  
  69.         mousedown = 1;  
  70.         if(subtractedMargin > -640 && mousedown == 1){  
  71.             mapMove("down");  
  72.             todown = setInterval(function(){mapMove("down");}, 120);  
  73.         }  
  74.     });  
  75.     $("#ID_DIV_TOUP").mousedown(function(){  
  76.         mousedown = 1;  
  77.         if(subtractedMargin < -20 && mousedown == 1){  
  78.             mapMove("up");  
  79.             toup = setInterval(function(){mapMove("up");}, 120);  
  80.         }  
  81.     });  
  82. }); 

當(dāng)大家看到本文題目時(shí)肯定不大了解題目的含義,因?yàn)樘橄罅恕,F(xiàn)在做一下解釋:可移動(dòng)是代表可以向四面八方走動(dòng),地圖就是地圖,可以是世界地圖,中國(guó)地圖,游戲地圖。。。反正必須是一張圖。在此多說(shuō)了兩句,不過(guò)沒關(guān)系,因?yàn)榱私馇闆r比不知廬山真面目要好得多。

接下來(lái)我把html代碼再公布出來(lái),因?yàn)檫@次html代碼的重要性很大:

 
 
 
  1.  
  2.   
  3.      SLG   
  4.       
  5.       
  6.       
  7.        
  8.       
  9.   
  10.   
  11.       
  12.           
  13.      
 
  •       
  •      
  •  
  •      
  •  
  •      
  •  
  •      
  •  
  •   
  •   
  • 現(xiàn)在大家可以對(duì)照兩段代碼看,值得注意得是有一點(diǎn):在html代碼中,我把一張圖片放入了div,這時(shí)div原本是不會(huì)遮蓋住圖片的,但當(dāng)你加上overflow: hidden;時(shí)就可以遮蓋住圖片了。

    在這個(gè)程序中為了點(diǎn)擊邊框附近就能使地圖移動(dòng),我用了四個(gè)div壓住圖片四邊,當(dāng)邊框附近被點(diǎn)擊時(shí),就等于點(diǎn)了div,點(diǎn)了div就會(huì)調(diào)動(dòng)相應(yīng)函數(shù)。這樣做雖然技術(shù)會(huì)有點(diǎn)差,不過(guò)也是一個(gè)好辦法。

    另一點(diǎn)值得注意得是:當(dāng)點(diǎn)擊邊框附近調(diào)用函數(shù)時(shí),我用了一個(gè)很特別的方法讓地圖一直移動(dòng),除非你松開鼠標(biāo)。這個(gè)方法就是用setInterval()等待幾秒后又移動(dòng),setInterval()又是個(gè)不停循環(huán)的東東,于是就一直調(diào)用下去,當(dāng)松開鼠標(biāo)時(shí),就用clearInterval();讓setInterval()停下,于是,這個(gè)環(huán)節(jié)搞定了?。?!哈哈哈。

    對(duì)了,不忘把圖片給大家,圖片有點(diǎn)大。。。

    源代碼下載:http://files.cnblogs.com/ducle/moveMap.rar

    三、演示效果

    先看演示圖片:

    然后是:

    演示地址:http://www.cnblogs.com/yorhom/archive/2012/09/29/2708977.html

    原文鏈接:http://www.cnblogs.com/ducle/archive/2012/09/29/2708969.html


    當(dāng)前名稱:JS游戲開發(fā)(五)可移動(dòng)地圖的實(shí)現(xiàn)
    網(wǎng)頁(yè)URL:http://www.5511xx.com/article/cdhsipg.html