首頁 web前端 js教程 javascript製作坦克大戰全紀錄(1)_javascript技巧

javascript製作坦克大戰全紀錄(1)_javascript技巧

May 16, 2016 pm 04:30 PM
javascript 物件導向

PS:這場戰車大戰是在網路下的一段源碼之後,自己進行的重寫。本身沒有太難的東西,這個案例將js物件導向的比較好,可以作為js物件導向的入門教學。

1.   建立基本對象,實現坦克簡單的移動

1.1    如何在地圖中繪製畫布

    考慮到瀏覽器相容的問題,我們用操作dom的方式來實現遊戲物件的繪製和刷新。我們如何儲存我們的地圖呢? 我們應該把地圖用一個二維數組來保存, js中沒有二維數組,但是可以透過在一維數組從儲存數組來實現。

1.2    程式碼實作

    我們將畫布設計為13 * 13 的一個二維數組,每個元素在地圖中對應的長和寬均為40px,可以把整個地圖看成由40px*40p x大小的單元格組成的一個表格,那麼我們整個畫布的大小為520px  *  520px ;
 
   上程式碼前先給大家來一張物件關係圖:

1.2.1    建立頂層物件

html代碼:

複製程式碼 程式碼如下:

 
 
 
     戰車大戰
    
    
    
    
    
    
     <script><br />          window.onload = function () {<br />              // 呼叫遊戲裝載​​者<br />              var loader = new GameLoader();<br />              loader.Begin();<br />          }<br />      </script>
 
 
 
    
    

    

    

    

 
 

TankObject.js檔:
 

複製程式碼 程式碼如下:

 // 頂級物件
 TankObject = function () {
     this.XPosition = 0; // 物件在地圖(13*13)中的X的位置
     this.YPosition = 0;
     this.UI = null; // dom元素
 }
 // 更改UI靜態方法
 TankObject.prototype.UpdateUI = function (battlFiled) { }
 // 設定位置,參數是這樣:1*40,6*40
 TankObject.prototype.SetPosition = function (leftPosition, topPosition) {
     // 在地圖的位置 Math.round四捨五入   
     this.XPosition = Math.round(leftPosition / 40);
     this.YPosition = Math.round(topPosition / 40);
     // 設定在視窗上的位置
     if (this.UI != null && this.UI.style != null) {
         this.UI.style.left = leftPosition "px";
         this.UI.style.top = topPosition "px";
     }
 }

 
    這裡我們用X,Y座標表示物件在地圖上的位置。後面我們會將地圖中的每個物件放入二維數組中,這時可以透過X,Y座標來取得對應的物件。
    接著用css中的left和top來控制我們物件在窗體中的位置。 (可以移動的物件:坦克,子彈)
 

1.2.2   建立公用物件

    我們也需要建立一個公開的對象,來寫入我們常用的一些方法。
 
Common.js:
 

複製程式碼 程式碼如下:

// 坦克車移動的四個方向
var EnumDirection = {
    Up: "0",
    Right: "1",
    Down: "2",
    Left: "3"
};
// 通用方法物件
var UtilityClass = {
    // 建立dom元素到parentNode中,可指定id,className
    CreateE: function (type, id, className, parentNode) {
        var J = document.createElement(type);
        if (id) { J.id = id };
        if (className) { J.className = className };
        return parentNode.appendChild(J);
    },  // 移除元素
    RemoveE: function (obj, parentNode) {
        parentNode.removeChild(obj);
    },
    GetFunctionName: function (context, argumentCallee) {
        for (var i in context) {
            if (context[i] == argumentCallee) { return i };
        }
        return "";
    },  // 綁定事件,回傳func方法,this為傳入的obj
    BindFunction: function (obj,func) {
        return function () {
            func.apply(obj, arguments);
        };
    }
};

1.2.3    建立移動物件

Mover.js
 

複製程式碼 程式碼如下:

 // 移動對象,繼承自頂層對象
 Mover = function () {
     this.Direction = EnumDirection.Up;
     this.Speed = 1;
 }
 Mover.prototype = new TankObject();
 Mover.prototype.Move = function () {
     if (this.lock) {
         return;/* 停用或尚在步進中,操作無效 */
     }
     // 依照方向設定坦克車的背景圖片
     this.UI.style.backgroundPosition = "0 -" this.Direction * 40 "px";
     // 如果方向是上和下,vp就是top;如果方向是上和左,val就是-1
     var vp = ["top", "left"][((this.Direction == EnumDirection.Up) || (this.Direction == EnumDirection.Down)) ? 0 : 1];
     var val = ((this.Direction == EnumDirection.Up) || (this.Direction == EnumDirection.Left)) ? -1 : 1;
     this.lock = true;/* 加鎖 */
     // 把目前物件儲存到This
     var This = this;
     // 記錄對象移動起始位置
     var startmoveP = parseInt(This.UI.style[vp]);
     var xp = This.XPosition, yp = This.YPosition;
     var subMove = setInterval(function () {
         // 開始移動,且每次移動5px
         This.UI.style[vp] = parseInt(This.UI.style[vp]) 5 * val "px";
         // 每次移動一個儲存格 40px
         if (Math.abs((parseInt(This.UI.style[vp]) - startmoveP)) >= 40) {
             clearInterval(subMove);
             This.lock = false;/* 解鎖,允許再步進 */
             // 記錄物件移動後在表格中的位置
             This.XPosition = Math.round(This.UI.offsetLeft / 40);
             This.YPosition = Math.round(This.UI.offsetTop / 40);
         }
     }, 80 - this.Speed * 10);
 }

 
    這裡的移動物件繼承自我們的頂級物件 ,這裡this就代表呼叫Move方法的物件。
    Move物件的功能依物件的方向和速度移動,每次移動5px總共移動40px一個單元格。後面這個物件還會進行擴展,會加入碰撞偵測等功能。

1.2.4    建立坦克物件
 
Tank.js 檔案:

複製程式碼 程式碼如下:

//tank物件 繼承自Mover
Tank=function(){}
Tank.prototype = new Mover();

// 創建玩家坦克,繼承自tank物件
SelfTank = function () {
    this.UI = UtilityClass.CreateE("div", "", "itank", document.getElementById("divMap"));
    this.MovingState = false;
    this.Speed = 4;
}
SelfTank.prototype = new Tank();
// 設定坦克車的位置
SelfTank.prototype.UpdateUI = function () {
    this.UI.className = "itank";
    // 頂級物件方法,設定坦克的位置
    this.SetPosition(this.XPosition * 40, this.YPosition * 40);
}

     現在只創建了玩家坦克,後面我們還會在裡面添加敵人坦克。

1.2.5    建立遊戲裝載物件(核心)

複製程式碼 程式碼如下:

 // 遊戲載入物件 整個遊戲的核心物件
 GameLoader = function () {
     this.mapContainer = document.getElementById("divMap");  // 存放遊戲地圖的div
     this._selfTank = null;  // 玩家戰車
     this._gameListener = null; // 遊戲主循環計時器id
 }
 GameLoader.prototype = {
     Begin: function () {
         // 初始化玩家坦克
         var selfT = new SelfTank();
         selfT.XPosition = 4;
         selfT.YPosition = 12;
         selfT.UpdateUI();
         this._selfTank = selfT;
         // 新增按鍵事件
         var warpper = UtilityClass.BindFunction(this, this.OnKeyDown);
         window.onkeydown = document.body.onkeydown = warpper;
         warpper = UtilityClass.BindFunction(this, this.OnKeyUp);
         window.onkeyup = document.body.onkeyup = warpper;
         // 遊戲主循環
         warpper = UtilityClass.BindFunction(this, this.Run);
         /*長定時器監聽控制鍵*/
         this._gameListener = setInterval(warpper, 20);
     }
     // 鍵盤按下玩家坦克開始移動
     , OnKeyDown: function (e) {
         switch ((window.event || e).keyCode) {
             case 37:
                 this._selfTank.Direction = EnumDirection.Left;
                 this._selfTank.MovingState = true;
                 break;        //左
             case 38:
                 this._selfTank.Direction = EnumDirection.Up;
                 this._selfTank.MovingState = true;
                 break;        //則上
             case 39:
                 this._selfTank.Direction = EnumDirection.Right;
                 this._selfTank.MovingState = true;
                 break;        //右
             case 40:
                 this._selfTank.Direction = EnumDirection.Down;
                 this._selfTank.MovingState = true;
                 break;        //且下
         }
     }
     // 按鍵彈起停止移動
     , OnKeyUp: function (e) {
         switch ((window.event || e).keyCode) {
             case 37:
             case 38:
             case 39:
             case 40:
                 this._selfTank.MovingState = false;
                 break;
         }
     }
     /*遊戲主循環運作函數,遊戲的心臟,樞紐*/
     , Run: function () {
         if (this._selfTank.MovingState) {
             this._selfTank.Move();
         }
     }
 };

   遊戲裝載物件程式碼看起來很多,其實就做了兩件事:
        1、創建玩家坦克物件。
        2、新增按鍵監聽事件,當玩家按下移動鍵呼叫坦克Move方法移動坦克。

總結:到這裡我們的坦克可以透過按鍵自由的移動了。下一步我們需要完善地圖和碰撞偵測。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1670
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

PHP高階特性:物件導向程式設計的最佳實踐 PHP高階特性:物件導向程式設計的最佳實踐 Jun 05, 2024 pm 09:39 PM

PHP中OOP最佳實務包括命名約定、介面與抽象類別、繼承與多型、依賴注入。實戰案例包括:使用倉庫模式管理數據,使用策略模式實現排序。

探索Go語言中的物件導向編程 探索Go語言中的物件導向編程 Apr 04, 2024 am 10:39 AM

Go語言支援物件導向編程,透過型別定義和方法關聯實作。它不支援傳統繼承,而是透過組合實現。介面提供了類型間的一致性,允許定義抽象方法。實戰案例展示如何使用OOP管理客戶訊息,包括建立、取得、更新和刪除客戶操作。

如何在JavaScript中取得HTTP狀態碼的簡單方法 如何在JavaScript中取得HTTP狀態碼的簡單方法 Jan 05, 2024 pm 01:37 PM

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務

Golang中有類似類別的物件導向特性嗎? Golang中有類似類別的物件導向特性嗎? Mar 19, 2024 pm 02:51 PM

在Golang(Go語言)中並沒有傳統意義上的類別的概念,但它提供了一種稱為結構體的資料類型,透過結構體可以實現類似類別的物件導向特性。在本文中,我們將介紹如何使用結構體實現物件導向的特性,並提供具體的程式碼範例。結構體的定義和使用首先,讓我們來看看結構體的定義和使用方式。在Golang中,結構體可以透過type關鍵字定義,然後在需要的地方使用。結構體中可以包含屬

Go語言的物件導向特性解析 Go語言的物件導向特性解析 Apr 04, 2024 am 11:18 AM

Go語言支援物件導向編程,透過struct定義對象,使用指標接收器定義方法,並透過介面實現多態。物件導向特性在Go語言中提供了程式碼重用、可維護性和封裝,但也存在缺乏傳統類別和繼承的概念以及方法簽章強制型別轉換的限制。

PHP物件導向程式設計的深入理解:物件導向程式設計的除錯技巧 PHP物件導向程式設計的深入理解:物件導向程式設計的除錯技巧 Jun 05, 2024 pm 08:50 PM

透過掌握追蹤物件狀態、設定斷點、追蹤異常和利用xdebug擴展,可以有效調試PHP物件導向程式碼。 1.追蹤物件狀態:使用var_dump()和print_r()檢視物件屬性和方法值。 2.設定斷點:在開發環境中設定斷點,偵錯器會在執行到達斷點時暫停,以便檢查物件狀態。 3.追蹤異常:使用try-catch區塊和getTraceAsString()取得異常發生時的堆疊追蹤和訊息。 4.利用偵錯器:xdebug_var_dump()函數可在程式碼執行過程中檢查變數的內容。

JavaScript和WebSocket:打造高效率的即時搜尋引擎 JavaScript和WebSocket:打造高效率的即時搜尋引擎 Dec 17, 2023 pm 10:13 PM

JavaScript和WebSocket:打造高效率的即時搜尋引擎引言:隨著網路的發展,使用者對即時搜尋引擎的要求也越來越高。傳統的搜尋引擎在進行搜尋時,使用者需要點擊搜尋按鈕後才能得到結果,這種方式無法滿足使用者對於即時搜尋結果的需求。因此,採用JavaScript和WebSocket技術來實現即時搜尋引擎成為了一個熱門的話題。本文將詳細介紹使用JavaScri

See all articles