javascript遊戲開發之《三國志曹操傳》零組件開發(五)可移動地圖的實現_javascript技巧

來源:互聯網
上載者:User

一、前言

這一講的內容很簡單,大家理解起來會更快。因此我只對重點加以分析,其他的就輪到大家思考哦!首先來說,我對遊戲開發可以算是不怎麼深入,因為現在的程式員愛用canvas,我卻就只會拿幾個div湊和。不過沒關係,因為做出來的同樣是遊戲。哈!廢話最近有點多,望大家原諒。接下來請看代碼解析。

二、代碼講解

今天調一下講解順序,先看代碼後看圖片。

這是slg.js裡的內容:

複製代碼 代碼如下:

var subtractedMargin = 0;
var subtractedMarginL = 0;
var mousedown = 0;

var toright;
var toleft;
var todown;
var toup;

window.onmouseup = function(){
mousedown = 0;

clearInterval(toright);
clearInterval(toleft);
clearInterval(todown);
clearInterval(toup);
}

function mapMove(direction)
{
switch(direction){
case "down":
subtractedMargin -= 15;

$("#ID_IMG_MAP").animate({marginTop: subtractedMargin + "px"}, 120);

break;

case "up":
subtractedMargin += 15;

$("#ID_IMG_MAP").animate({marginTop: subtractedMargin + "px"}, 120);

break;

case "right":
subtractedMarginL -= 15;

$("#ID_IMG_MAP").animate({marginLeft: subtractedMarginL + "px"}, 120);

break;

case "left":
subtractedMarginL += 15;

$("#ID_IMG_MAP").animate({marginLeft: subtractedMarginL + "px"}, 120);

break;
}

if(subtractedMarginL < -415){
clearInterval(toright);
clearInterval(toleft);
}
if(subtractedMarginL > -20){
clearInterval(toright);
clearInterval(toleft);
}

if(subtractedMargin < -640){
clearInterval(todown);
clearInterval(toup);
}
if(subtractedMargin > -20){
clearInterval(todown);
clearInterval(toup);
}
}

$("body").ready(function(){
$("#ID_DIV_TORIGHT").mousedown(function(){
mousedown = 1;

if(subtractedMarginL > -415 && mousedown == 1){
mapMove("right");
toright = setInterval(function(){mapMove("right");}, 120);
}

});

$("#ID_DIV_TOLEFT").mousedown(function(){
mousedown = 1;

if(subtractedMarginL < -20 && mousedown == 1){
mapMove("left");
toleft = setInterval(function(){mapMove("left");}, 120);
}
});

$("#ID_DIV_TODOWN").mousedown(function(){
mousedown = 1;

if(subtractedMargin > -640 && mousedown == 1){
mapMove("down");
todown = setInterval(function(){mapMove("down");}, 120);
}
});

$("#ID_DIV_TOUP").mousedown(function(){
mousedown = 1;

if(subtractedMargin < -20 && mousedown == 1){
mapMove("up");
toup = setInterval(function(){mapMove("up");}, 120);
}
});
});

當大家看到本文題目時肯定不大瞭解題目的含義,因為太抽象了。現在做一下解釋:可移動是代表可以向四面八方走動,地圖就是地圖,可以是世界地圖,中國地圖,遊戲地圖。。。反正必須是一張圖。在此多說了兩句,不過沒關係,因為瞭解情況比不知廬山真面目要好得多。
接下來我把html代碼再公布出來,因為這次html代碼的重要性很大:
複製代碼 代碼如下:

<html>
<head>
<title>SLG</title>

<link rel="stylesheet" type="text/css" href="./main_looks.css" />
<script type="text/javascript" src="jquery-1.8.0.js"></script>

<script type="text/javascript" src="./slg.js"></script>
</head>
<body>
<div id="ID_DIV_SLGPAGE" style="width: 718px; height: 500px; border: 5px solid lightgray; overflow: hidden;">
<img src="./picture/map01.jpg" id="ID_IMG_MAP" style=" margin-top: 0px; margin-left: 0px;" />
</div>
<!--<input type="button" value="Down" id="ID_BUTTON_DOWN" />
<input type="button" value="Up" id="ID_BUTTON_UP" />
<input type="button" value="Left" id="ID_BUTTON_LEFT" />
<input type="button" value="Right" id="ID_BUTTON_RIGHT" />-->
<div id="ID_DIV_TORIGHT" style="width: 30px; height: 500px; border: 0px solid lightgray; position:absolute; z-index: 9; margin: -508px 0 0 689px;"></div>
<div id="ID_DIV_TOLEFT" style="width: 30px; height: 500px; border: 0px solid lightgray; position:absolute; z-index: 9; margin: -508px 0 0 0px;"></div>
<div id="ID_DIV_TODOWN" style="width: 718px; height: 30px; border: 0px solid lightgray; position:absolute; z-index: 10; margin: -41px 0 0 0px;"></div>
<div id="ID_DIV_TOUP" style="width: 718px; height: 30px; border: 0px solid lightgray; position:absolute; z-index: 10; margin: -508px 0 0 0px;"></div>
</body>
</html>

現在大家可以對照兩段代碼看,值得注意得是有一點:在html代碼中,我把一張圖片放入了div,這時div原本是不會遮蓋住圖片的,但當你加上overflow: hidden;時就可以遮蓋住圖片了。

在這個程式中為了點擊邊框附近就能使地圖移動,我用了四個div壓住圖片四邊,當邊框附近被點擊時,就等於點了div,點了div就會調動相應函數。這樣做雖然技術會有點差,不過也是一個好辦法。

另一點值得注意得是:當點擊邊框附近調用函數時,我用了一個很特別的方法讓地圖一直移動,除非你鬆開滑鼠。這個方法就是用setInterval()等待幾秒後又移動,setInterval()又是個不停迴圈的東東,於是就一直調用下去,當鬆開滑鼠時,就用clearInterval();讓setInterval()停下,於是,這個環節搞定了!!!哈哈哈。

對了,不忘把圖片給大家,圖片有點大。。。

 

源碼下載地址

三、示範效果

先看示範圖片:


然後是:


 

示範地址:
注意:進入demo後點擊圖片邊緣便可以移動地圖。

希望大家多支援!謝謝!

“用Javascript開發《三國志曹操傳》”系列文章差不多到此就該結束了,下次我們來研究研究html5遊戲開發。相信那更是智慧的挑戰。敬請期待!---Yorhom Wang

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.