欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Angular9和TypeScript開發(fā)RPG游戲的方法

 更新時間:2020年03月25日 15:18:12   作者:數(shù)據(jù)可視化俱樂部  
這篇文章主要介紹了使用Angular9和TypeScript開發(fā)RPG游戲的方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

RPG系統(tǒng)構造

通過對于斗羅大陸小說的游戲化過程,熟悉Angular的結構以及使用TypeScript的面向對象開發(fā)方法。

項目地址

人物

和其他RPG游戲類似,游戲里面的人物角色大致有這樣的一些屬性:生命值,魔法值(魂力),攻擊力,防御力,速度。RPG游戲中的角色隨著等級的提高,這些屬性都會提升,屬性提升的快慢則取決于資質,同時,由于在實際戰(zhàn)斗中,會出現(xiàn)各種增益和光環(huán)效果,這些值都是動態(tài)變化的,所以這里將這些屬性都設置了Base和Real兩套數(shù)據(jù)。

Base屬性是指人物的初始屬性,是一種固有屬性,在整個游戲開始的時候就固定下來的。然后每個人物根據(jù)不同的資質,有一個成長值,例如SSR的角色,成長值可以是1.5,普通角色是1。這個成長值關系到每提升一個等級,角色屬性的增加值,代碼大致如下:

 /**經(jīng)過增益之后的生命最大值 */
 get RealMaxHP(): number {
 var R = this.BaseMaxHP + (this.LV - 1) * this.MaxHPUpPerLv * this.GrowthFactor;
 ...
 ...
 ...
 return Math.round(R);
 }

這里的 MaxHPUpPerLv 表示每個等級的最大生命值提升數(shù)值,GrowthFactor則表示成長值。

注意:這里使用了TypeScript的get屬性,也就是只讀/計算屬性來處理Real系的屬性,這些屬性都是實時計算出來的!

在小說里面,經(jīng)??梢钥吹?成功力的角色,為了表示這種情況,代碼里面還設定了一個Factor變量,通過這個變量可以設定整體的縮放比例。這個值默認為1,表示不縮放。

 /**經(jīng)過增益之后的生命最大值 */
 get RealMaxHP(): number {
 var R = this.BaseMaxHP + (this.LV - 1) * this.MaxHPUpPerLv * this.GrowthFactor;
 R = R * this.Factor;
 ...
 ...
 ...
 return Math.round(R);
 }

由于乘法計算會出現(xiàn)小數(shù)點,這里使用了Math.round對結果進行取整。

技能

技能是一個游戲的戰(zhàn)斗核心,所有技能本質上都是為了改變角色狀態(tài)。如果要具體細分大致可以分為

  • 攻擊類:對于指定角色產(chǎn)生傷害
  • 回復類:對于指定角色,回復生命值和魔法值
  • 狀態(tài)改變類:這里其實包含了Buffer和狀態(tài)變化兩種情況,Buffer類大多是被動技能,游戲中只要某個角色在戰(zhàn)場上就獲得,并且效果是持續(xù)性的。狀態(tài)變化則一般必須主動施放技能才行,而且持續(xù)時間也是有限制的。

同時技能設計的時候,還需要設定使用的方向,既這個技能是對于我方使用,還是敵方使用,還是無差別使用。另外這個技能的對象是某個對象,還是群體。

/**技能類型 */
export enum enmSkillType {
 /**攻擊 */
 Attact,
 /**治療 */
 Heal,
 /**光環(huán)和狀態(tài) */
 Buffer
}

/**技能范圍 */
export enum enmRange {
 Self, //自己
 PickOne, //選擇一個人
 RandomOne, //隨機選擇一個人
 FrontAll, //前排所有人
 BackAll, //后排所有人
 EveryOne, //戰(zhàn)場所有人
}

/**只能方向 */
export enum enmDirect {
 MyTeam, //本方
 Enemy, //敵方
 All, //全體
}

一般使用枚舉來編寫這樣相對固定,項目較少的列表

技能的設計,這里使用了OOP的繼承來實現(xiàn),技能的基類定義了一些共通的屬性和抽象方法。設計的時候還考慮到以下幾種特殊情況

  • 每一種具體技能必須要實現(xiàn)一個執(zhí)行(施放)方法:Excute,這里使用抽象函數(shù),來強制子類型必須要實現(xiàn)這個方法
  • 對于復雜技能,需要有一個自定義的執(zhí)行方法:CustomeExcute,同時通過返回值來告訴系統(tǒng)是不是該技能有自定義執(zhí)行方法。則跳過固有的Excute方法。
  • 對于有些技能可能要同時實現(xiàn)兩種效果,這里增加了AddtionSkill變量
/** 技能 */
export abstract class SkillInfo {
 Name: string;
 Order: number; //第N魂技
 SkillType: enmSkillType;
 Range: enmRange;
 Direct: enmDirect;
 Description: string;
 Source: string;
 get MpUsage(): number {
 return Math.pow(2, this.Order);
 }
 /**武魂融合技的融合者列表 */
 Combine: string[];
 abstract Excute(c: character, fs: FightStatus): void;
 /**自定義執(zhí)行方法 */
 CustomeExcute(c: character, fs: FightStatus): boolean {
 return false;
 }
 //攻擊并中毒這樣的兩個效果疊加的技能
 AddtionSkill: SkillInfo = undefined;
}

export class AttactSkillInfo extends SkillInfo {
 SkillType = enmSkillType.Attact;
 Harm: number;
 Excute(c: character, fs: FightStatus) {
 //如果自定義方法被執(zhí)行,則跳過后續(xù)代碼
 if (this.CustomeExcute(c, fs)) return;
 let factor = fs.currentActionCharater.LV / 100;
 c.HP -= Math.round(this.Harm * factor);
 if (c.HP <= 0) c.HP = 0;
 //如果需要產(chǎn)生其他效果
 if (this.AddtionSkill !== undefined) this.AddtionSkill.Excute(c, fs);
 }
}

undefined來檢測是否擁有對象

劇情

劇情暫時使用傳統(tǒng)的列表在當前位置指針方式來制作

export const FightPrefix = "[FightScene]";
export const ChangeScenePrefix = "[ChangeScene]";
export const Scene0000: SceneInfo = {
 Title: "引子 穿越的唐家三少",
 Background: "唐門",
 Lines: [
 "唐門唐三@我知道,偷入內(nèi)門,偷學本門絕學罪不可恕,門規(guī)所不容。但唐三可以對天發(fā)誓,絕未將偷學到的任何一點本門絕學泄露與外界。",
 FightPrefix + "Battle0001",
 "唐門唐三@我說這些,并不是希望得到長老們的寬容,只是想告訴長老們,唐三從未忘本。以前沒有,以后也沒有。",
 "唐門唐三@唐三的一切都是唐門給的,不論是生命還是所擁有的能力,都是唐門所賦予,不論什么時候,唐三生是唐門的人,死是唐門的鬼,",
 "唐門唐三@我知道,長老們是不會允許我一個觸犯門規(guī)的外門弟子尸體留在唐門的,既然如此,就讓我骨化于這巴蜀自然之中吧。",
 "唐門長老@玄天寶錄,你竟然連玄天寶錄中本門最高內(nèi)功也學了?",
 "唐門唐三@赤裸而來,赤裸而去,佛怒唐蓮算是唐三最后留給本門的禮物。",
 "唐門唐三@現(xiàn)在,除了我這個人以外,我再沒有帶走唐門任何東西,秘籍都在我房間門內(nèi)第一塊磚下。唐三現(xiàn)在就將一切都還給唐門。",
 "唐門唐三@哈哈哈哈哈哈哈……。",
 "唐門長老@等一下。",
 "唐門唐三@(云霧很濃,帶著陣陣濕氣,帶走了陽光,也帶走了那將一生貢獻給了唐門和暗器的唐三。)",
 ChangeScenePrefix + "Scene0001"
 ]
};

這里使用 FightPrefix表示進入戰(zhàn)斗,ChangeScenePrefix表示場景轉換。對話列表則使用@符號將角色和臺詞進行區(qū)分。

總結

到此這篇關于使用Angular9和TypeScript開發(fā)RPG游戲的文章就介紹到這了,更多相關Angular9和TypeScript開發(fā)RPG游戲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • ionic4+angular7+cordova上傳圖片功能的實例代碼

    ionic4+angular7+cordova上傳圖片功能的實例代碼

    ionic是一個垮平臺開發(fā)框架,可通過web技術開發(fā)出多平臺的應用。這篇文章主要介紹了ionic4+angular7+cordova上傳圖片功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • Angular自定義指令Tooltip的方法實例

    Angular自定義指令Tooltip的方法實例

    現(xiàn)實世界千變?nèi)f化,區(qū)區(qū)幾種內(nèi)置指令不可能滿足所有的需求,下面這篇文章主要給大家介紹了關于Angular自定義指令Tooltip的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • AngularJs基本特性解析(一)

    AngularJs基本特性解析(一)

    angularjs是javascript的一個框架,通過script標簽添加到網(wǎng)頁中。這篇文章主要介紹了AngularJs基本特性解析(一)的相關資料,需要的朋友可以參考下
    2016-07-07
  • 簡單談談require模塊化jquery和angular的問題

    簡單談談require模塊化jquery和angular的問題

    下面小編就為大家?guī)硪黄唵握務剅equire模塊化jquery和angular的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 在AngularJS框架中處理數(shù)據(jù)建模的方式解析

    在AngularJS框架中處理數(shù)據(jù)建模的方式解析

    這篇文章主要介紹了在AngularJS框架中處理數(shù)據(jù)建模的方式,作者同時也對AngularJS使用過程中的一些"坑"作了介紹,需要的朋友可以參考下
    2016-03-03
  • AngularJS中使用ng-repeat的index問題

    AngularJS中使用ng-repeat的index問題

    這篇文章主要介紹了AngularJS中使用ng-repeat的index問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Angular跨字段驗證器中如何直接調(diào)用其它獨立的驗證器

    Angular跨字段驗證器中如何直接調(diào)用其它獨立的驗證器

    我們在開發(fā)的時候都會用到表單,那么驗證器就是必不可少的東西,這篇文章主要給大家介紹了關于在Angular跨字段驗證器中如何直接調(diào)用其它獨立的驗證器的相關資料,需要的朋友可以參考下
    2022-03-03
  • AngualrJS中的Directive制作一個菜單

    AngualrJS中的Directive制作一個菜單

    本文給大家介紹AngualrJS中的Directive制作一個菜單,涉及到angularjs directive相關知識,本文介紹的非常詳細,具有參考借鑒價值,特此分享供大家學習
    2016-01-01
  • 詳解Angular組件生命周期(一)

    詳解Angular組件生命周期(一)

    每個Angular版本在其生命周期中都經(jīng)歷了各個階段。組件在Angular中起著關鍵作用; 在這里,本文將討論Angular中的組件生命周期以及它們?nèi)绾斡绊懣蚣芩邪姹镜纳芷凇?/div> 2021-05-05
  • 學習Angularjs分頁指令

    學習Angularjs分頁指令

    這篇文章主要和大家一起學習Angularjs分頁指令,代碼很詳細,文章結構緊湊,感興趣的小伙伴們可以參考一下
    2016-07-07

最新評論