C#飛行棋小程序設(shè)計(jì)分析
C#小程序飛行棋,程序效果圖
1、設(shè)計(jì)分析
這個(gè)程序界面大致分為四部分:
① 最上面游戲名字界面
②信息提示區(qū)
③游戲界面區(qū)
④游戲操作提示區(qū)
2、分區(qū)設(shè)計(jì)實(shí)現(xiàn)
一、游戲界面顯示區(qū),由于只需要顯示出圖形即可,因此直接用Console.Writeline()輸出即可。
二、信息提示區(qū),此處用于顯示 游戲?qū)?zhàn)雙方的姓名等信息,在游戲開始時(shí)需要由用戶錄入對(duì)戰(zhàn)雙方的姓名信息,因此可用Console.Readline()來讀取 用戶鍵入的值,<注:需要檢查驗(yàn)證對(duì)戰(zhàn)雙方的姓名不可相同!>
三、游戲界面區(qū),此處用于顯示游戲每一步的界面,可看出界面中有普通的方塊、關(guān)卡方塊以及游戲?qū)?zhàn)雙方。針對(duì)該操作界面需要多次繪制 ,因此可單獨(dú)寫成一個(gè)方法進(jìn)行實(shí)現(xiàn),對(duì)游戲界面普通的方塊 出現(xiàn)的最多,因此可將地圖的繪制初始化為 數(shù)組 ,并將其出初始化為普通方塊,此處可利用一個(gè)整形數(shù)組來存儲(chǔ)坐標(biāo)的屬性,(例如:用0表示普通方塊,1表示幸運(yùn)轉(zhuǎn)盤,2表示地雷,3表示暫停,4表示時(shí)空隧道,A、B分別表示對(duì)戰(zhàn)用戶)在繪制地圖時(shí) 再根據(jù)不同的數(shù)字繪制出相應(yīng)的圖案,在用戶進(jìn)行對(duì)戰(zhàn)重新繪制地圖時(shí)只需根據(jù)相應(yīng)坐標(biāo)上的值 來繪制出地圖即可,游戲界面繪制可分為 5部分 進(jìn)行繪制,如下圖所示:
繪制第一部分和第五部分,可用常規(guī)的Console.Write()進(jìn)行輸出,而第二部分則需繪制出前面的空格,第三部分由于是逆向繪制的,所以 在繪制時(shí)可采用循環(huán)從大坐標(biāo)到小坐標(biāo)遞減進(jìn)行繪制。
四、游戲操作提示區(qū),此處用于提示用戶進(jìn)行操作游戲,只需輸出語(yǔ)句即可。
這個(gè)飛行棋小游戲最難的部分便在于 繪制游戲地圖,以及關(guān)卡操作上面。
繪制地圖:
1、 初始化地圖,在繪制時(shí)可先將地圖進(jìn)行初始化,用數(shù)組來存儲(chǔ)關(guān)卡的位置,然后利用循環(huán)給地圖中 關(guān)卡所在處賦予代表關(guān)卡的值。
關(guān)鍵代碼如下
/// <summary> /// 初始化游戲地圖 /// </summary> static void InitialMap() { for (int i=0;i<Map.Length;i++) { Map[i] =0; } //用于存儲(chǔ)關(guān)卡位置 int[] luckyTurn = { 6, 23, 40, 55, 69, 83,98 };//幸運(yùn)轉(zhuǎn)盤 1 int[] landMine = { 5, 13, 17, 33, 38, 50, 64, 80, 94 };//地雷 2 int[] pause = { 9, 27, 60, 93 };//暫停 3 int[] timeTunnel = { 20, 25, 45, 63, 72, 88, 90};//時(shí)空隧道 4 for (int i=0;i<luckyTurn.Length;i++) { int pos = luckyTurn[i]; Map[pos] = 1; } for (int i=0;i<landMine.Length;i++) { Map[landMine[i]] = 2; } for (int i=0;i<pause.Length;i++) { int pos = pause[i]; Map[pos] = 3; } for(int i=0;i<timeTunnel.Length;i++) { int pos = timeTunnel[i]; Map[pos] =4; } }
2、檢查坐標(biāo)的值,在將地圖進(jìn)行初始化之后,便可開始進(jìn)行繪制地圖的操作了,地圖繪制可使用 在程序設(shè)計(jì)時(shí)所講的分布繪制,在繪制地圖時(shí)應(yīng)檢驗(yàn)該該坐標(biāo)點(diǎn)的值,在根據(jù)該點(diǎn)的值繪制相應(yīng)的圖案,在檢查時(shí)根據(jù)值 返回相應(yīng)的圖案 ,在利用循環(huán)繪制出即可,檢查坐標(biāo)的值代碼如下:
/// <summary> /// 獲得要繪制的坐標(biāo) /// </summary> /// <param name="i"> 要繪制的坐標(biāo)</param> /// <returns></returns> static string GetMapString(int i) { string Result="";//用于返回 給一個(gè)坐標(biāo)相應(yīng)的圖案 if (playerPos[0] == i && playerPos[1] == i)//判斷是否是對(duì)戰(zhàn)雙方所在此處 { Console.ForegroundColor = ConsoleColor.Yellow;//設(shè)置圖案的前景色為黃色 Result = "<>";//得到兩人均在圖案 } else if (playerPos[0] == i) { Console.ForegroundColor = ConsoleColor.Yellow; Result = "A";//得到A均在圖案 } else if (playerPos[1] == i) { Console.ForegroundColor = ConsoleColor.Yellow; Result = "B";//得到B均在圖案 } else { switch (Map[i]) { case 0: Console.ForegroundColor = ConsoleColor.White; Result = "□";//得到普通均在圖案 break; case 1: Console.ForegroundColor = ConsoleColor.Red; Result = "○";//得轉(zhuǎn)盤圖案 break; case 2: Console.ForegroundColor = ConsoleColor.Blue; Result = "☆"; break; case 3: Console.ForegroundColor = ConsoleColor.Green; Result = "▲"; break; case 4: Console.ForegroundColor = ConsoleColor.DarkBlue; Result = "卍"; break; } } return Result; //返回圖案 }
3、繪制地圖,在得到 返回的圖案后,便可進(jìn)行地圖的繪制,這里給出繪制第一行的代碼
/// <summary> /// 繪制游戲地圖 /// </summary> static void DrownMap() { Console.WriteLine("圖例:幸運(yùn)轉(zhuǎn)盤 ○ 地雷 ☆ 暫停 ▲ 時(shí)空隧道 卍"); //畫第一行 下標(biāo)0-29 的地圖 for(int i=0;i<30;i++)//循環(huán)坐標(biāo)得到 第一行每個(gè)點(diǎn)的圖案 { Console.Write(GetMapString(i)); //調(diào)用函數(shù)得到每個(gè)坐標(biāo)的圖案 } Console.Write("\n"); Console.ResetColor();//重置前景色 }
關(guān)卡操作:
1、分析設(shè)計(jì)
飛行棋的基本規(guī)則為二人輪流擲骰子,則此處為循環(huán)結(jié)構(gòu),然后根據(jù)投擲出的點(diǎn)數(shù)進(jìn)行前進(jìn)<注:在每一步前進(jìn)之后均應(yīng)該判斷是否走完了游戲>,在遇到關(guān)卡時(shí)進(jìn)行相應(yīng)的操作,關(guān)卡有四種,每一種對(duì)應(yīng)的操作不同,因此此處可運(yùn)用switch-case 循環(huán)結(jié)構(gòu)在每走一步操作后均進(jìn)行判斷是否踩到關(guān)卡,在根據(jù)判斷的結(jié)果進(jìn)行下一步操作,每一次操作完成后 ,重新繪制最新的地圖。
2、代碼實(shí)現(xiàn)
一玩家擲骰子,二人輪流投擲,當(dāng)有一人勝利時(shí)結(jié)束游戲 。投擲骰子可用函數(shù)Random()產(chǎn)生隨機(jī)數(shù)實(shí)現(xiàn),每前進(jìn)一步后需要檢查游戲是否勝利,方法如下 :
/// <summary> /// 檢查坐標(biāo)是否越界 /// </summary> static void CheckPos() { for (int i = 0; i <= 1; i++) { if (playerPos[i] > 99) { playerPos[i] = 99; } if (playerPos[i] < 0) { playerPos[i] = 0; } } }
當(dāng)遇到關(guān)卡時(shí),根據(jù)關(guān)卡設(shè)定的性質(zhì)進(jìn)行操作,在遇到幸運(yùn)轉(zhuǎn)盤時(shí)可供用戶進(jìn)行選擇1:與對(duì)方交換 位置,2:轟炸對(duì)方,讓對(duì)方后退6格,此處需要讓用戶輸入1或者2,在讀取時(shí)需要對(duì)用戶鍵入的值進(jìn)行檢驗(yàn),可用以下方法實(shí)現(xiàn):
static int ReadInt(int min,int max) { while (true) { try { int number = Convert.ToInt32(Console.ReadLine()); if(number<min||number>max) { Console.WriteLine("只能輸入{0}-{1}之間的數(shù)字,請(qǐng)重新輸入!", min, max); continue; } return number; } catch { Console.WriteLine("只能輸入數(shù)字,請(qǐng)重新輸入!"); } } }
當(dāng)遇到關(guān)卡3暫停時(shí),需要用戶在下一次該行動(dòng)時(shí)暫停一次,此處可定義一個(gè)bool 類型的數(shù)組來表示用戶是否應(yīng)該在這一步暫停操作 ,下面給出用戶A投擲 的代碼:
//這個(gè)循環(huán)中 玩家輪流擲骰子,當(dāng)任何一人坐標(biāo)>=99時(shí),游戲結(jié)束 while(playerPos[0]<99&&playerPos[1]<99) { Random r = new Random();//產(chǎn)生隨機(jī)數(shù) int Step;//存放產(chǎn)生的隨機(jī)數(shù); if (isStop[0] == false) { #region//玩家A擲骰子 Console.WriteLine("{0}按任意鍵擲骰子....", names[0]); ConsoleKeyInfo rec = Console.ReadKey(true); if (rec.Key == ConsoleKey.Tab) { Step = 6; } else { Step = r.Next(1, 7); } Console.WriteLine("{0}擲出了{(lán)1}", names[0], Step); Console.WriteLine("{0}按任意鍵行動(dòng)...", names[0]); Console.ReadKey(true);//不顯示 按下按下的按鍵的值 playerPos[0] = playerPos[0] + Step;//更改坐標(biāo)<一旦坐標(biāo)發(fā)生改變,判斷是否大于99或 小于0> CheckPos(); if (playerPos[0] == playerPos[1])//玩家A踩到玩家B { playerPos[1] = 0; msg = string.Format("{0}踩到了{(lán)1},退回原點(diǎn)", names[0], names[1]);//Format函數(shù)用于拼接字符段 } #region else //沒踩到,判斷此位置是否有其他關(guān)卡 { switch (Map[playerPos[0]]) { case 0: //普通位置,無效果 msg = ""; break; case 1: //幸運(yùn)轉(zhuǎn)盤 Console.Clear(); DrownMap(); Console.WriteLine("{0}走到了幸運(yùn)轉(zhuǎn)盤,請(qǐng)選擇運(yùn)氣?", names[0]); Console.WriteLine("1:交換位置 2: 轟炸 "); int userSelect = ReadInt(1, 2); if (userSelect == 1) { int temp; temp = playerPos[0]; playerPos[0] = playerPos[1]; playerPos[1] = temp; msg = string.Format("{0}選擇了與{1}交換位置,哈哈,一夜回到解放前啊", names[0], names[1]); } else { playerPos[1] = playerPos[1] - 6; CheckPos(); msg = string.Format("{0}選擇了與讓 {1}后退6步,自求多福吧", names[0], names[1]); } break; case 2: //地雷 playerPos[0] = playerPos[0] - 6; CheckPos(); msg = string.Format("{0}踩到了地雷,后退6步,阿彌陀佛", names[0]); break; case 3: //暫停 isStop[0] = true; msg = string.Format("{0}暫停一次!", names[0]); break; case 4: //時(shí)空隧道 playerPos[0] = playerPos[0] + 6; CheckPos(); msg = string.Format("{0}進(jìn)入了時(shí)空隧道 ,前進(jìn)吧!", names[0]); break; } } #endregion Console.WriteLine("按任意鍵開始行動(dòng)..."); Console.ReadKey(true); Console.Clear(); DrownMap(); if (msg != "") { Console.WriteLine(msg); } Console.WriteLine("{0}擲出了{(lán)1},行動(dòng)完成!", names[0], Step); Console.WriteLine("*******w玩家A和玩家B的位置如下***********"); Console.WriteLine(" 玩家{0}的位置為{1}", names[0], playerPos[0] + 1); Console.WriteLine(" 玩家{0}的位置為{1}", names[1], playerPos[1] + 1); #endregion } else { //說明A暫停一次 isStop[0] = false; } if(playerPos[0]>=99) { break; } #region 玩家B擲骰子 #endregion }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
講解C#設(shè)計(jì)模式編程中享元模式的運(yùn)用
這篇文章主要介紹了C#設(shè)計(jì)模式編程中享元模式的運(yùn)用,享元模式主張限制對(duì)象的數(shù)量來優(yōu)化內(nèi)存使用,需要的朋友可以參考下2016-02-02淺談c#.net中巧用ToString()將日期轉(zhuǎn)成想要的格式
有時(shí)候我們要對(duì)時(shí)間進(jìn)行轉(zhuǎn)換,達(dá)到不同的顯示效果,更多的該怎么辦呢?2013-03-03C#設(shè)計(jì)模式之建造者模式生成器模式示例詳解
這篇文章主要為大家介紹了C#設(shè)計(jì)模式之建造者模式生成器模式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08混合語(yǔ)言編程—C#使用原生的Directx和OpenGL繪圖的方法
本文要說的是混合C#和C/C++語(yǔ)言編程,在C#的Winform和WPF下使用原生的Direct和OpenGL進(jìn)行繪圖2013-09-09簡(jiǎn)述C#枚舉高級(jí)戰(zhàn)術(shù)
這篇文章主要介紹了簡(jiǎn)述C#枚舉高級(jí)戰(zhàn)術(shù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10C#實(shí)現(xiàn)運(yùn)行狀態(tài)堆疊柱狀圖
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)運(yùn)行狀態(tài)堆疊柱狀圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02DevExpress之ChartControl實(shí)現(xiàn)柱狀圖演示實(shí)例
這篇文章主要介紹了DevExpress中ChartControl實(shí)現(xiàn)柱狀圖演示方法,實(shí)例展示了相關(guān)繪圖函數(shù)的具體用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10C#使用委托實(shí)現(xiàn)的快速排序算法實(shí)例
這篇文章主要介紹了C#使用委托實(shí)現(xiàn)的快速排序算法,實(shí)例分析了C#委托機(jī)制與快速排序算法的實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-07-07