畢業(yè)設(shè)計(jì)---基于j2me為平臺(tái)的坦克大戰(zhàn)游戲開(kāi)發(fā)_第1頁(yè)
已閱讀1頁(yè),還剩51頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  摘 要</b></p><p>  J2ME(Java 2 Micro Edition) 是近年來(lái)隨著各種不同設(shè)備,尤其是移動(dòng)通信設(shè)備的飛速發(fā)展而誕生的一項(xiàng)新的開(kāi)發(fā)技術(shù)。它定位在消費(fèi)性電子產(chǎn)品的應(yīng)用上,對(duì)設(shè)備的智能化、多樣化,提供了革命性的解決方案,并因其“Write Once, run anywhere”的Java特性而提高開(kāi)發(fā)的效率。</p>

2、<p>  隨著手機(jī)的日益普及、Java功能在移動(dòng)設(shè)備上的實(shí)現(xiàn),Java應(yīng)用程序產(chǎn)生的手機(jī)增值服務(wù)逐漸體現(xiàn)出其影響力,對(duì)豐富人們的生活內(nèi)容、提供快捷的資訊起著不可忽視的作用。本論文著眼于J2ME技術(shù)的應(yīng)用,開(kāi)發(fā)一款可商用的手機(jī)游戲程序——坦克大戰(zhàn)。本程序的界面和運(yùn)作方式繼承于日本任天堂公司在20世紀(jì)80年代開(kāi)發(fā)的Battle City游戲,將老少皆宜的經(jīng)典作品移植到手機(jī)上來(lái),為更流行的硬件平臺(tái)提供應(yīng)用軟件。</p>

3、;<p>  本論文介紹了任天堂紅白機(jī)的軟硬件特性、J2ME的相關(guān)技術(shù)及本程序的結(jié)構(gòu)分析和具體功能的實(shí)現(xiàn)。</p><p>  關(guān)鍵字:J2ME,手機(jī)游戲, Java,坦克大戰(zhàn)</p><p><b>  ABSTRACT</b></p><p>  J2ME is a kind of fast developing techno

4、logy implemented on various devices especially mobile communication equipments. It focuses on application for consumptive electronic products, providing revolutionary solution to the intelligentization and diversificatio

5、n of the equipment. It improve the efficiency of the development process thanks to its “Write Once, run anywhere” nature.</p><p>  When cell phone is getting ever more popular nowadays, with the implementati

6、on of Java technology on mobile equipment, increment of capital on communication service exhibits its force on people’s everyday life, providing them ever fast information just in hand. This dissertation focuses on imple

7、mentation of J2ME technology and has developed a commercial game suite run on mobile phones—Tank. This application inherits many characters of the old fashioned game Battle City which developed by Nintend</p><

8、p>  This dissertation introduces the characteristic of Nintendo FC machine and its software, J2ME and its relative technology as well as this program’s structure and analysis of implementation in details. </p>

9、<p>  Key words: J2ME, mobile game, Java, tank, Battle City.</p><p><b>  引  言</b></p><p>  Java語(yǔ)言是美國(guó)Sun Microsystem的James Gosling、Pratrick Naughton及Mike Sheridan等人于1991年精心設(shè)計(jì)出來(lái)的計(jì)

10、算機(jī)編程語(yǔ)言,其構(gòu)想在于實(shí)現(xiàn)使用同一種編程語(yǔ)言所寫(xiě)出來(lái)的程序可以在不同的平臺(tái)上運(yùn)作。這種架構(gòu)對(duì)于消費(fèi)性電子產(chǎn)品而言是具有革命性的,因?yàn)樵谙M(fèi)性電子產(chǎn)品中的處理器及操作系統(tǒng)各不相同,要在這些平臺(tái)上開(kāi)發(fā)程序必須要了解各個(gè)平臺(tái)的特性,以及其提供的API使用方式,分別開(kāi)發(fā)不同的版本才能執(zhí)行,影響應(yīng)用程序的普及性。</p><p>  近幾年,由于微處理器性能的大幅提升,加上無(wú)線通訊技術(shù)的突破,手持式移動(dòng)設(shè)備開(kāi)始受到大眾的

11、青睞。短短幾年內(nèi),手機(jī)已經(jīng)升級(jí)了幾代產(chǎn)品,普及率逐年攀升,生產(chǎn)效率不斷上升,產(chǎn)品價(jià)格比個(gè)人電腦的摩爾定律有更驚人的下調(diào),以至手機(jī)是大多是城市居民不可缺少的一件隨身設(shè)備。繼短信、彩信等服務(wù)之后,中國(guó)移動(dòng)提供基于Java的百寶箱業(yè)務(wù),應(yīng)用產(chǎn)品遍及商務(wù)應(yīng)用、信息獲取、英漢互譯、游戲娛樂(lè)等多媒體領(lǐng)域。根據(jù)官方公布的統(tǒng)計(jì)數(shù)據(jù),我國(guó)移動(dòng)電話用戶已突破3億。依托這樣的市場(chǎng),一旦無(wú)線Java應(yīng)用大規(guī)模開(kāi)展起來(lái),將會(huì)創(chuàng)造出比短信業(yè)務(wù)更為驚人的利潤(rùn)。Jav

12、a語(yǔ)言原先的開(kāi)發(fā)目的與市場(chǎng)的需求不謀而合,并且也已經(jīng)成為手機(jī)應(yīng)用程序開(kāi)發(fā)的標(biāo)準(zhǔn),國(guó)際大公司如Nokia、Motorola及Siemens等所設(shè)計(jì)的手機(jī)內(nèi)都加入Java程序的支持,可見(jiàn)在不久的將來(lái),Java將會(huì)成為移動(dòng)設(shè)備上最熱門(mén)的語(yǔ)言。</p><p>  手機(jī)中將Java語(yǔ)言引入,作為一種通用的開(kāi)發(fā)標(biāo)準(zhǔn),并將向市場(chǎng)推廣普及僅僅短短幾年,J2ME仍是一種新型的技術(shù),中文資料除臺(tái)灣出版過(guò)相關(guān)書(shū)籍外,國(guó)內(nèi)相關(guān)介紹資源

13、很有限,國(guó)內(nèi)J2ME開(kāi)發(fā)商也屈指可數(shù),名聲較響的Digital-Red公司也僅成立于1999年。本文可算是對(duì)新技術(shù)的一些嘗試,代表對(duì)無(wú)線平臺(tái)應(yīng)用程序推廣的一些努力。</p><p>  本論文中第一章介紹游戲機(jī)軟硬件歷史、Java語(yǔ)言、J2ME及其相關(guān)技術(shù);</p><p>  第二章介紹了開(kāi)發(fā)工具和相關(guān)軟硬件環(huán)境的背景;</p><p>  第三章分析該作品設(shè)計(jì)的

14、思想和流程,介紹總體結(jié)構(gòu);</p><p>  第四章并詳細(xì)闡述有關(guān)重點(diǎn)實(shí)現(xiàn)細(xì)節(jié);</p><p>  第五章提及了開(kāi)發(fā)過(guò)程、心得體會(huì)、經(jīng)驗(yàn)和感想。</p><p><b>  目 錄</b></p><p>  摘 要- I -</p><p>  Abstract - II -

15、</p><p>  引  言- 3 -</p><p>  第一章  緒 論- 1 -</p><p>  1.1 手機(jī)軟件現(xiàn)狀- 1 -</p><p>  1.2 游戲業(yè)務(wù)及J2ME概況- 1 -</p><p>  1.3 任天堂(Nintendo)的8位FC機(jī)器和Battle City背景介紹

16、- 3 -</p><p>  1.4 本章小結(jié)- 3 -</p><p>  第二章 開(kāi)發(fā)環(huán)境及相關(guān)技術(shù)的介紹- 4 -</p><p>  2.1 開(kāi)發(fā)環(huán)境- 4 -</p><p>  2.2 Java語(yǔ)言的特點(diǎn)- 4 -</p><p>  2.3 關(guān)于JBuilder9- 4 -</p&g

17、t;<p>  2.4 關(guān)于Wireless Tool Kit- 5 -</p><p>  2.5 Java Appication Manager- 5 -</p><p>  2.6 本章小結(jié)- 5 -</p><p>  第三章 程序結(jié)構(gòu)、思想和相關(guān)技術(shù)- 6 -</p><p>  3.1 本程序需解決的

18、有關(guān)技術(shù)問(wèn)題- 6 -</p><p>  3.2 程序流程- 7 -</p><p>  3.3 繪圖與MIDP2.0新增的GameCanvas包- 9 -</p><p>  3.3.1 提供低級(jí)繪制的Canvas類- 9 -</p><p>  3.3.2 Graphics類- 9 -</p><p&g

19、t;  3.3.3 PNG格式- 9 -</p><p>  3.3.4 Game包中的新功能- 10 -</p><p>  3.3.5 有關(guān)繪圖的一些技術(shù)- 11 -</p><p>  3.4 坦克的控制和敵方的智能運(yùn)行- 11 -</p><p>  3.5 子彈的運(yùn)行和控制- 12 -</p><

20、;p>  3.6 RMS數(shù)據(jù)庫(kù)系統(tǒng)- 13 -</p><p>  3.7 內(nèi)存使用的最佳化- 14 -</p><p>  3.8 混淆器(Obfuscator)的使用- 15 -</p><p>  3.9 模擬器的相關(guān)調(diào)試- 15 -</p><p>  3.10 本章小結(jié)- 16 -</p>&l

21、t;p>  第四章 程序分析和具體實(shí)現(xiàn)- 17 -</p><p>  4.1 游戲進(jìn)入前的選擇- 17 -</p><p>  4.2 主游戲邏輯及其涉及到的若干類- 18 -</p><p>  4.3 坦克的共同行為- 20 -</p><p>  4.4 玩家坦克的功能屬性- 21 -</p>

22、<p>  4.5 敵人坦克的功能屬性- 21 -</p><p>  4.6 子彈的運(yùn)行和控制- 23 -</p><p>  4.7 記分系統(tǒng)- 24 -</p><p>  4.8 本章小結(jié)- 26 -</p><p>  第五章 總 結(jié)- 27 -</p><p>  5.

23、1 本程序的總結(jié)和展望- 27 -</p><p>  5.2 經(jīng)驗(yàn)和感想- 27 -</p><p>  致 謝- 29 -</p><p>  參考文獻(xiàn)- 30 -</p><p>  附錄 源程序代碼- 31 -</p><p><b>  第一章  緒 論</b>&

24、lt;/p><p>  1.1 手機(jī)軟件現(xiàn)狀</p><p>  在信息社會(huì)中,手機(jī)及其他無(wú)線設(shè)備越來(lái)越多的走進(jìn)普通百姓的工作和生活,隨著信息網(wǎng)絡(luò)化的不斷進(jìn)展,手機(jī)及其他無(wú)線設(shè)備上網(wǎng)絡(luò)勢(shì)在必行。但是傳統(tǒng)手機(jī)存在以下弊端:</p><p>  1. 傳統(tǒng)手機(jī)出廠時(shí)均由硬件廠商固化程序,程序不能增加、刪除,有了錯(cuò)誤也不能更新、修改,若要增加新功能必須另?yè)Q一部手機(jī)。<

25、;/p><p>  2. 傳統(tǒng)手機(jī)訪問(wèn)互聯(lián)網(wǎng)是通過(guò)WAP(Wireless Application Protocal),所有網(wǎng)絡(luò)資源必須接通網(wǎng)絡(luò)才能在線訪問(wèn),非常耗時(shí)、費(fèi)用亦很高。</p><p>  而Java技術(shù)在無(wú)線應(yīng)用方面的優(yōu)勢(shì)非常明顯:</p><p>  1. 應(yīng)用程序可按需下載,而不是購(gòu)買由硬件商提供的套件,可升級(jí)空間大。</p><

26、;p>  2. Java技術(shù)提供了一個(gè)類庫(kù),它使的應(yīng)用開(kāi)發(fā)商可以創(chuàng)建更為直覺(jué)、豐富的用戶界面(GUI);</p><p>  3. Java技術(shù)使網(wǎng)絡(luò)帶寬的應(yīng)用更為有效,因?yàn)閼?yīng)用程序可以下載到器件上,并在本地運(yùn)行,僅僅是在連接到服務(wù)器時(shí)才會(huì)占用網(wǎng)絡(luò)帶寬。</p><p>  基于以上分析,Java手機(jī)將是未來(lái)手機(jī)的發(fā)展方向,是業(yè)界的熱點(diǎn)。</p><p>

27、  1.2 游戲業(yè)務(wù)及J2ME概況</p><p>  雖然 Java 已經(jīng)被用到許多企業(yè)級(jí)軟體上,可是其實(shí)骨子里面還是非常適合用在嵌入式系統(tǒng)之中。Java平臺(tái)演進(jìn)到Java2后,Java平臺(tái)分別針對(duì)不同領(lǐng)域的需求被分成四個(gè)版本,亦即J2EE、J2SE、J2ME以及JavaCard(其結(jié)構(gòu)示意圖見(jiàn)圖1-1)。其中J2ME定位在消費(fèi)性電子產(chǎn)品的應(yīng)用上。這個(gè)版本針對(duì)資源有限的電子消費(fèi)產(chǎn)品的需求精簡(jiǎn)核心類庫(kù),并提供了模

28、塊化的架構(gòu)讓不同類型產(chǎn)品能夠隨時(shí)增加支持的能力。這個(gè)版本的應(yīng)用層面相當(dāng)廣泛,會(huì)是未來(lái)Java平臺(tái)發(fā)展的重點(diǎn)項(xiàng)目。J2ME 在設(shè)計(jì)其規(guī)格的時(shí)候,遵循著“對(duì)各種不同的裝置而造出一個(gè)單一的開(kāi)發(fā)系統(tǒng)是沒(méi)有意義的事”這個(gè)基本原則。于是 J2ME 先將所有的嵌入式裝置大體上區(qū)分為兩種:一種是運(yùn)算功能有限、電力供應(yīng)也有限的嵌入式裝置(比方說(shuō)PDA 、手機(jī));另外一種則是運(yùn)算能力相對(duì)較佳、在電力供應(yīng)上相對(duì)比較充足的嵌入式裝置 (比方說(shuō)冷氣機(jī)、電冰箱、電

29、視機(jī)上盒 (set-top box))。因?yàn)檫@兩種型態(tài)的嵌入式裝置,所以Java 引入了一個(gè)叫做Configuration 的概念,把上述運(yùn)算功能有限、電力有限的嵌入式裝置定義在Connected L</p><p>  縱觀IT產(chǎn)業(yè)的歷史,就像軍事的發(fā)展時(shí)常推動(dòng)計(jì)算機(jī)的演化一樣,計(jì)算機(jī)游戲已經(jīng)成為技術(shù)創(chuàng)新背后的動(dòng)力之一。計(jì)算機(jī)游戲者渴望更加強(qiáng)大的硬件計(jì)算能力;渴望不受不同的軟件的限制——無(wú)論是將圖形強(qiáng)制在人工智

30、能(AI)上 還是網(wǎng)絡(luò)安全性。游戲開(kāi)發(fā)者和玩家常常是前沿計(jì)算機(jī)技術(shù)的最早的采用者。由于他們的創(chuàng)新天性,游戲不再是由大型采購(gòu)公司控制的技術(shù)產(chǎn)品——游戲領(lǐng)域總是有充足的空間給那些在這方面有天分的單個(gè)創(chuàng)新者。</p><p>  手機(jī)游戲的盈利主要是由于它們的涉及面很廣。手機(jī)已經(jīng)與現(xiàn)代生活方式緊緊地結(jié)合在一起。他們是最普遍攜帶的個(gè)人用品中僅次于鑰匙和錢包的東西。傳統(tǒng)的臺(tái)式機(jī)游戲?qū)⒛繕?biāo)鎖定在低級(jí)趣味的人和青少年身上,而手

31、機(jī)游戲則每個(gè)人都可以訪問(wèn)的到——隨時(shí),隨地。盡管每個(gè)手機(jī)游戲都不貴,但是巨大的使用量(如:每人每星期一個(gè)新游戲)將使得這個(gè)市場(chǎng)商機(jī)無(wú)限。但是,對(duì)于開(kāi)發(fā)者來(lái)說(shuō),將控制臺(tái)游戲遷移到手機(jī)游戲工程很大。因?yàn)樗麄兯嫦虻膶?duì)象、生活方式和分布式模型都有著極大的區(qū)別。</p><p>  一個(gè)成功的手機(jī)游戲大多具有以下特征: </p><p>  ·易于學(xué)習(xí): 既然手機(jī)游戲面向的是普通消費(fèi)者而

32、不是計(jì)算機(jī)專家,那么他們不可能深入的學(xué)習(xí)游戲技巧。消費(fèi)者不會(huì)花幾個(gè)小時(shí)去研究一個(gè)3元的手動(dòng)操作的游戲。保持游戲的簡(jiǎn)單是最基本的要求。 </p><p>  ·可中斷性: 多任務(wù)處理是手機(jī)生活方式的基本特征。手機(jī)用戶常常在任務(wù)(如等一個(gè)電子郵件或者等車)之間有一小段時(shí)間。而游戲、日歷管理、通訊和工作數(shù)據(jù)訪問(wèn)使用的是同一個(gè)設(shè)備。所以一個(gè)好的手機(jī)游戲應(yīng)該提供短時(shí)間的娛樂(lè)功能,并且允許用戶在游戲和工作模式之間順

33、利切換。 </p><p>  ·基于訂閱:手機(jī)游戲的盈利成功取決于他們巨大的使用量。一開(kāi)始開(kāi)發(fā)和設(shè)計(jì)每個(gè)游戲都是昂貴的。如果一個(gè)手機(jī)游戲開(kāi)發(fā)者要贏利的話,重要的是:同一個(gè)游戲引擎,多個(gè)標(biāo)題,基本的故事情節(jié)類似?;谟嗛喌挠螒蚴遣粩喈a(chǎn)生收入的最好方法。 </p><p>  ·豐富的社會(huì)交互: 不管一個(gè)游戲設(shè)計(jì)得多好,只要玩家找到了它的根本模式或者玩完了所有的游戲路徑很

34、快就會(huì)厭煩這個(gè)游戲。對(duì)于一個(gè)基于訂閱的游戲,重要的是與別的玩家合作以增強(qiáng)所玩游戲的智力和隨機(jī)性。在今天紛繁復(fù)雜的多玩家游戲中具有豐富社會(huì)交互的游戲證明是成功的。 </p><p>  ·利用手機(jī)技術(shù)的優(yōu)點(diǎn): 巨額的手機(jī)技術(shù)研發(fā)費(fèi)用都花在提高設(shè)備和網(wǎng)絡(luò)的可用性和可靠性上面。因此,手機(jī)設(shè)備硬件和網(wǎng)絡(luò)協(xié)議與桌面/控制臺(tái)世界(如全球定位系統(tǒng)(GPS)擴(kuò)展、條形碼掃描儀、和短消息服務(wù)(SMS)/多媒體信息服務(wù)(M

35、MS)通訊)有著非常大的差別。好的手機(jī)游戲應(yīng)該利用那些更新的設(shè)備特征和網(wǎng)絡(luò)基礎(chǔ)設(shè)備的優(yōu)點(diǎn)。 </p><p>  ·無(wú)違法內(nèi)容:既然所有年齡/性別的人群都玩手機(jī)游戲并且常常在公共/工作場(chǎng)合,就應(yīng)該避免明顯的暴力或者色情內(nèi)容。</p><p>  1.3 任天堂(Nintendo)的8位FC機(jī)器和Battle City背景介紹</p><p>  FC(F

36、amily Computer)主機(jī)在歐美又稱Nintendo Entertainment System(可譯作任天堂娛樂(lè)平臺(tái)即NES)。FC主機(jī)在游戲業(yè)界造成的巨大沖擊眾所周知,這款主機(jī)在當(dāng)時(shí)事實(shí)上幾乎占領(lǐng)了世界各地多個(gè)國(guó)家的整個(gè)游戲市場(chǎng),并使得逐漸沒(méi)落的北美游戲市場(chǎng)再度復(fù)蘇。這款主機(jī)的性能比當(dāng)時(shí)的多數(shù)主機(jī)都要強(qiáng)大,而價(jià)格上卻便宜得多。主機(jī)所采用得處理器為CMOS 6502,一款已經(jīng)淘汰的70年代中期產(chǎn)品。由于其價(jià)格便宜且極易使用,經(jīng)過(guò)

37、任天堂的改造后又煥發(fā)了全新活力。6502 芯片cpu 主頻為8 bit,12 MHz,內(nèi)存8k,畫(huà)面 52色,同屏最多顯示其中的13色,聲音2個(gè)矩波,1個(gè)三角波,1個(gè)雜音,1個(gè)PCM音頻(見(jiàn)圖1-2)。</p><p>  Battle City是其發(fā)售卡帶中的一款力作,設(shè)置了35個(gè)關(guān)卡,可以雙人操縱,畫(huà)面設(shè)置了若干種類的建筑物和阻擋物,以消滅所有敵人為通關(guān)條件,并有接寶物等增加游戲效果的設(shè)置,畫(huà)面精美,音效杰出

38、,在PC機(jī)的80386處理器仍未面世的當(dāng)時(shí),能在硬件上運(yùn)行這樣的2D程序不得不令人驚嘆,難怪常有人說(shuō)游戲程序是最大限度發(fā)揮硬件水平的載體。其游戲界面如圖1-3所示。</p><p>  1.4 本章小結(jié):</p><p>  引言和第一章中介紹了手機(jī)在無(wú)線應(yīng)用方向的當(dāng)今概況,并介紹了游戲業(yè)務(wù)在當(dāng)前社會(huì)的發(fā)展?jié)摿?。分析了J2ME在手機(jī)軟件開(kāi)發(fā)中起的重要作用,描述了本論文的相關(guān)背景。<

39、/p><p>  第二章 開(kāi)發(fā)環(huán)境及相關(guān)技術(shù)的介紹</p><p><b>  2.1 開(kāi)發(fā)環(huán)境</b></p><p>  操作系統(tǒng):Microsoft Windows XP</p><p>  程序語(yǔ)言:Java 2</p><p>  開(kāi)發(fā)包: Java(TM) 2 Standard Edit

40、ion (build 1.4.1_02-b06) Sun Micro. J2ME Wireless Tool Kit 2.1</p><p>  IDE: Borland Jbuilder 9</p><p>  2.2 Java語(yǔ)言的特點(diǎn)</p><p><b>  1. 平臺(tái)無(wú)關(guān)性</b></p&g

41、t;<p>  Java引進(jìn)虛擬機(jī)原理,并運(yùn)行于虛擬機(jī),實(shí)現(xiàn)不同平臺(tái)之間的Java接口。使用Java編寫(xiě)的程序能在世界范圍內(nèi)共享。Java的數(shù)據(jù)類型與機(jī)器無(wú)關(guān)。</p><p><b>  2. 安全性</b></p><p>  Java的編程類似C++,但舍棄了C++的指針對(duì)存儲(chǔ)器地址的直接操作,程序運(yùn)行時(shí),內(nèi)存由操作系統(tǒng)分配,這樣可以避免病毒通過(guò)指

42、針入侵系統(tǒng)。它提供了安全管理器,防止程序的非法訪問(wèn)。</p><p><b>  3. 面向?qū)ο?lt;/b></p><p>  Java吸收了C++面向?qū)ο蟮母拍?,將?shù)據(jù)封裝于類中,實(shí)現(xiàn)了程序的簡(jiǎn)潔性和便于維護(hù)性,使程序代碼可以只需一次編譯就可反復(fù)利用。</p><p><b>  4. 分布式</b></p>

43、<p>  Java建立在TCP/IP網(wǎng)絡(luò)平臺(tái)上,提供了用HTTP和FTP協(xié)議傳送和接收信息的庫(kù)函數(shù),使用其相關(guān)技術(shù)可以十分方便的構(gòu)建分布式應(yīng)用系統(tǒng)。</p><p><b>  5. 健壯性</b></p><p>  Java致力與檢查程序在編譯和運(yùn)行時(shí)的錯(cuò)誤,并自動(dòng)回收內(nèi)存,減少了內(nèi)存出錯(cuò)的可能性。Java取消了C語(yǔ)言的結(jié)構(gòu)、指針、#define語(yǔ)句

44、、多重繼承、goto語(yǔ)句、操作符、重載等不易被掌握的特性,提供垃圾收集器自動(dòng)回收不用的內(nèi)存空間。</p><p>  2.3 關(guān)于JBuilder9</p><p>  JBuilder是目前最好的Java開(kāi)發(fā)工具之一,在協(xié)同管理、對(duì)J2EE和XML的支持等方面均走在其他產(chǎn)品的前面。JBuilder是遵循Sun公司J2EE標(biāo)準(zhǔn)的可視化集成開(kāi)發(fā)工具。Jbuilder是一種處于市場(chǎng)領(lǐng)先地位的

45、跨平臺(tái)環(huán)境,主要用于構(gòu)建具有行業(yè)實(shí)力的企業(yè)Java應(yīng)用程序。JBuilder集成了Borland公司開(kāi)發(fā)工具系列的優(yōu)秀特性,使得使用過(guò)C++Builder,Delphi的程序員很容易的過(guò)度到JBuilder的開(kāi)發(fā)環(huán)境當(dāng)中。由于Java技術(shù)的發(fā)展迅速,經(jīng)常有新的組件推出或新的錯(cuò)誤修正,致使JBuilder的版本升級(jí)很快。當(dāng)兩年前還是JBuilder6時(shí),現(xiàn)今已推出了9、10的版本。</p><p>  2.4 關(guān)

46、于Wireless Tool Kit</p><p>  WTK(Wireless Tool Kit)是Sun公司針對(duì)J2ME推出的用于手機(jī)和Palm等移動(dòng)設(shè)備的開(kāi)發(fā)包,是除手機(jī)廠商的專用開(kāi)發(fā)包外唯一的手機(jī)模擬器開(kāi)發(fā)包。它通用性高,開(kāi)發(fā)出的應(yīng)用程序可保證能運(yùn)行在大部分設(shè)備上,而不像專用廠商具有一定的不兼容性。雖然它沒(méi)有強(qiáng)大的功能和完善的調(diào)試手段,但它提供運(yùn)行模擬器的最基本組件,是其他IDE需集成采用的必備元素。&

47、lt;/p><p>  2.5 Java Appication Manager</p><p>  手機(jī)中負(fù)責(zé)調(diào)配程序運(yùn)行資源的管理后臺(tái)是Java Application Manager。它所使用的傳輸媒體可以是紅外線、網(wǎng)絡(luò)、以及其他可用來(lái)傳輸?shù)拿襟w。Java Application Manager 會(huì)從網(wǎng)絡(luò)上下載代表該Application Suite 的JAR 檔,接著在手機(jī)上安裝此MI

48、Dlet Suite,然后在手機(jī)開(kāi)始執(zhí)行該應(yīng)用程序。整個(gè)詳細(xì)的運(yùn)作流程如圖2-1所示。</p><p>  2.6 本章小結(jié):</p><p>  第二章介紹了Java語(yǔ)言的特點(diǎn)、本程序的開(kāi)發(fā)環(huán)境及其相關(guān)工具的原理和使用。</p><p>  第三章 程序結(jié)構(gòu)、思想和相關(guān)技術(shù)</p><p>  3.1 本程序需解決的有關(guān)技術(shù)問(wèn)題<

49、/p><p>  1. 游戲程序是一項(xiàng)精度要求很高的程序系統(tǒng),因?yàn)槠浯a利用率很高。一個(gè)實(shí)時(shí)運(yùn)行的最終作品,每秒都會(huì)運(yùn)行成千上萬(wàn)行程序,繪圖事件、鍵盤(pán)事件都會(huì)以極高的頻率在后臺(tái)等待響應(yīng),若有絲毫的差別都將很容易導(dǎo)致程序在運(yùn)行不久后可能出現(xiàn)嚴(yán)重錯(cuò)誤,甚至死循環(huán)。因此,其邏輯設(shè)計(jì)應(yīng)當(dāng)相當(dāng)嚴(yán)謹(jǐn),需將所有可能發(fā)生的事件及意外情況考慮在設(shè)計(jì)中。</p><p>  2. 游戲中為了美觀,適用性強(qiáng),可

50、能需要采用外部文件引入的圖片貼圖,有關(guān)貼圖,在MIDP2.0中提供了用于增強(qiáng)游戲功能的game包,使得解決靜態(tài)或動(dòng)態(tài)、畫(huà)面背景、屏幕刷新的雙緩沖等都有較好的解決方案。</p><p>  3. 己方坦克的運(yùn)行可以通過(guò)鍵盤(pán)響應(yīng)事件控制,但敵方則因?yàn)槭亲詣?dòng)運(yùn)行,就需要有一定其一定的智能性;同時(shí),出現(xiàn)在屏幕上的敵方可能會(huì)有較多的數(shù)量,這需要為每個(gè)敵方開(kāi)辟一個(gè)線程以便能讓其獨(dú)立運(yùn)行。Java的多線程能力為實(shí)現(xiàn)這樣的游戲

51、提供了可能。敵人坦克的運(yùn)行算法也需要進(jìn)行適當(dāng)?shù)脑O(shè)置,以免游戲過(guò)于簡(jiǎn)單,單調(diào)。</p><p>  4. 對(duì)于雙方坦克發(fā)出的子彈的控制也需要對(duì)其跟蹤控制,子彈也需要處在獨(dú)立的線程中。敵方子彈僅需要掃描用戶坦克,而用戶坦克需要在每一步掃描所有的敵方坦克。這需要對(duì)所有的對(duì)象有較好的控制。另外,子彈在運(yùn)行過(guò)程中也需要實(shí)時(shí)掃描是否碰撞到了相關(guān)障礙物或屏幕邊界。如此過(guò)多的線程同時(shí)在本來(lái)效率就不高的KVM虛擬機(jī)上運(yùn)行,也許會(huì)

52、導(dǎo)致程序的緩慢。</p><p>  5. 雙方的坦克在前進(jìn)時(shí)也需要考慮到是否碰撞到相關(guān)物體或?qū)Ψ教箍?,以免重疊運(yùn)行,造成許多物理上不可能的情況,缺乏真實(shí)感。每一次刷新頁(yè)面、每前進(jìn)一步都需要將所有的周圍環(huán)境都進(jìn)行掃描。</p><p>  6. 游戲的結(jié)束、開(kāi)始、動(dòng)態(tài)信息畫(huà)面作為構(gòu)成一個(gè)完美程序都是必不可少的重要部分。良好的用戶界面更是吸引用戶的硬指標(biāo),相關(guān)的美術(shù)構(gòu)圖也需要有一定的考慮

53、。</p><p>  7. 游戲的地圖不可能通過(guò)繪圖來(lái)解決。否則,不僅難于控制和處理過(guò)多的元素,也會(huì)因過(guò)多的大型圖片而不能限制程序的大小,失去手機(jī)上程序的原則和Java的優(yōu)勢(shì)。同時(shí),地圖關(guān)卡不宜保存在手機(jī)有限的內(nèi)存中,而最好采取外部文件的讀入讀出方法。</p><p>  8. 用戶運(yùn)行游戲時(shí)需要有分?jǐn)?shù)記錄的可能。如何采用合理的記分標(biāo)準(zhǔn),需要進(jìn)行適當(dāng)?shù)脑O(shè)計(jì)。記錄分?jǐn)?shù)的存儲(chǔ)方式也需要有

54、較好的解決方案。手機(jī)中由于處理器和內(nèi)存空間、存儲(chǔ)空間都十分有限,其數(shù)據(jù)庫(kù)系統(tǒng)與普通PC大相徑庭。其數(shù)據(jù)庫(kù)結(jié)構(gòu)較為簡(jiǎn)單,被稱之為RMS系統(tǒng)。</p><p>  9. Java是基于虛擬機(jī)的半解釋型編譯系統(tǒng),其執(zhí)行效率較C++等完全編譯后的程序會(huì)低很多,程序如果不進(jìn)行精簡(jiǎn)和優(yōu)化,將可能導(dǎo)致運(yùn)行的不流暢。除開(kāi)發(fā)過(guò)程中對(duì)結(jié)構(gòu)上的控制、變量的使用、算法的優(yōu)化等優(yōu)化外,還可以使用混淆器(Obfuscator)進(jìn)行程序打包

55、后的優(yōu)化。</p><p>  以上相關(guān)技術(shù)細(xì)節(jié)和整體流程將分別在以下小節(jié)闡述。</p><p><b>  3.2 程序流程</b></p><p>  MIDlet suite是MIDP應(yīng)用程序的最小單位,JAM負(fù)責(zé)將手機(jī)內(nèi)的MIDlet suite以圖形化的方式呈現(xiàn),讓用戶能夠選取欲執(zhí)行的MIDlet suite,一旦選取了某個(gè)MIDl

56、et suite,操作系統(tǒng)就會(huì)激活KVM執(zhí)行里面的MIDlet。MIDlet及相關(guān)的支持類組成了MIDP應(yīng)用程序的實(shí)際內(nèi)容。</p><p>  每個(gè)MIDlet都必須繼承javax.microedition.midlet.MIDlet這個(gè)抽象類。在MIDP規(guī)格中定義了MIDlet的生命周期,以及可以存在的三種狀態(tài),包括Paused、Active以及Destroyed,每一個(gè)MIDlet在任何時(shí)刻只可能處于其中的

57、一個(gè)狀態(tài)。這三種狀態(tài)的轉(zhuǎn)換關(guān)系如圖所示:</p><p>  本程序采用面向?qū)ο蟮脑O(shè)計(jì)模式,對(duì)游戲中的所有物體賦予對(duì)象的概念和屬性。運(yùn)行程序后允許用戶選擇執(zhí)行選項(xiàng)菜單,在開(kāi)始游戲后將先從外部文件載入地圖文件,對(duì)背景的所有物體進(jìn)行繪圖。在主程序運(yùn)行的線程中,畫(huà)面刷新將以一定的頻率采用雙緩沖技術(shù)對(duì)屏幕重繪,實(shí)時(shí)反映整個(gè)游戲的進(jìn)行狀態(tài)。用戶控制的坦克運(yùn)行在主線程中,隨屏幕刷新的頻率而步進(jìn)。敵方坦克將在游戲開(kāi)始時(shí)逐漸新增

58、線程,每增加一個(gè)敵方對(duì)象就新增加一條線程,一旦線程數(shù)滿到最大值(本程序暫設(shè)置為6),就不允許敵人再繼續(xù)出現(xiàn)。用戶坦克自誕生之時(shí)起將擁有一發(fā)子彈,子彈雖然開(kāi)在單獨(dú)的線程中,但運(yùn)行結(jié)束后(比如撞到相關(guān)物體或敵方坦克時(shí))并不結(jié)束子彈對(duì)象,只是將其線程終止。用戶再次發(fā)射子彈時(shí)只是將終止的線程再次激活。在屏幕重繪的主程序中,將在每次的循環(huán)中判斷若干事件。如:用戶坦克的生命是否已完全用盡,敵方坦克數(shù)是否已經(jīng)為零,屏幕上的坦克數(shù)量是否少于仍剩下的坦克

59、數(shù)量等。以便程序進(jìn)入相關(guān)的分支執(zhí)行相關(guān)的反應(yīng)代碼,結(jié)束游戲或統(tǒng)計(jì)分?jǐn)?shù)等。主程序流程如圖3-2所示:</p><p>  程序?yàn)樾枰瓿瑟?dú)立功能的需顯示的模塊設(shè)置了單獨(dú)的類。TankMain類是繼承自MIDlet的控制主程序啟動(dòng)的首先被載入系統(tǒng)的部分。載入程序后首先啟動(dòng)的是程序介紹的信息畫(huà)面。閃過(guò)后載入StartChoice類,為用戶提供可選擇的選項(xiàng)。在選擇開(kāi)始后,將運(yùn)行BattleCanvas類中的總流程控制。它

60、決定了游戲何時(shí)該結(jié)束,何時(shí)分配敵人數(shù)量,GameOver字樣的閃現(xiàn)規(guī)則,地圖的繪制及整個(gè)游戲的調(diào)度。</p><p>  圖3-3是程序中類之間的UML分析圖。敵方坦克與用戶坦克的相關(guān)功能和具體行為分別定義在EnemySprite和UserSprite類中,它們都繼承自TankSprite公共類,以簡(jiǎn)化程序的代碼、理清結(jié)構(gòu)。</p><p>  在每關(guān)的結(jié)束或死亡后都將載入ScoreScr

61、een類,統(tǒng)計(jì)當(dāng)前的分?jǐn)?shù)。如果已死亡或完成所有的關(guān)數(shù),程序?qū)⒂脩羲玫姆謹(jǐn)?shù)記載到RMS數(shù)據(jù)庫(kù)中,進(jìn)行永久性保存。載入過(guò)程中將對(duì)所得分?jǐn)?shù)與以往歷史比較,放置到合適的位置中,形成排序。</p><p>  3.3 繪圖與MIDP2.0新增的GameCanvas包</p><p>  3.3.1 提供低級(jí)繪制的Canvas類</p><p>  為了能有程序開(kāi)發(fā)人員控制

62、接口的外觀和行為,需要使用大量的初級(jí)用戶接口類,尤其在游戲程序中,幾乎完全依賴的就是Canvas抽象類進(jìn)行繪圖。從程序開(kāi)發(fā)的觀點(diǎn)看,Canvas類可與高級(jí)Screen類交互,程序可在需要時(shí)在Canvas中摻入高級(jí)類的組件。Canvas提供了鍵盤(pán)事件、指點(diǎn)桿事件(如果設(shè)備支持),并定義了允許將鍵盤(pán)按鍵映射為游戲控制鍵的函數(shù)。鍵盤(pán)事件由鍵代碼指定,但這樣控制游戲會(huì)導(dǎo)致缺乏通用性,并不是每個(gè)設(shè)備的鍵盤(pán)布局都適合游戲的操作。應(yīng)當(dāng)將鍵代碼轉(zhuǎn)換為游

63、戲鍵的代碼,以便硬件開(kāi)發(fā)商能定義他們自己的游戲鍵布局。本程序中,操縱用戶坦克運(yùn)行的按鍵都定義為游戲控制鍵,這樣便能適應(yīng)所有的機(jī)器。</p><p>  3.3.2 Graphics類</p><p>  Graphics類提供了簡(jiǎn)單的2D繪圖功能。它具有24位深度色彩的繪制能力,以三原色分別各占一個(gè)字節(jié)表示其顏色。程序只能在paint()函數(shù)中使用Graphics繪制,GameCanvas

64、可調(diào)用getGraphics()函數(shù)直接繪制在緩沖區(qū)上,可以在任何時(shí)間請(qǐng)求傳輸?shù)角芭_(tái)。其對(duì)象會(huì)被傳給Canvas的paint()函數(shù),以便最終顯示。</p><p>  3.3.3 PNG格式</p><p>  PNG(Portable Network Graphics)格式是MIDlet唯一支持的圖象格式,PNG具體格式由PNG Specification,Version 1.0定義的

65、。PNG格式提供透明背景的圖象,這對(duì)繪制游戲畫(huà)面和被操縱主角極有幫助。坦克之間或與障礙物碰撞時(shí)就不會(huì)因?yàn)楸尘坝刑囟ǖ念伾@示出的效果像貼上的圖片而缺乏真實(shí)感,物體之間輕微重疊時(shí)最上層圖片也不會(huì)覆蓋超過(guò)其有效象素外的部分。</p><p>  PNG格式圖片中包含許多定義其圖片特性的冗余部分(Chunks)。這些代碼包含在每一個(gè)單獨(dú)的png格式圖象中,然而如果將多個(gè)png圖象合并在一張幅面稍大一些的整圖中,多個(gè)c

66、hunks就可以得到精簡(jiǎn),圖片的大小可以得到控制。使用Image類中的createImage函數(shù)可從整圖中分割出所需要的元素。在Game包中的TiledLayer和Sprite類都整合了這樣的功能。本程序中的地圖元素都集成在一張tile.png圖片中,實(shí)現(xiàn)了方便的管理和程序體積的精簡(jiǎn)。</p><p>  3.3.4 Game包中的新功能</p><p>  MIDP自2.0以后新增了G

67、ame包,為游戲的開(kāi)發(fā)帶來(lái)了極大的便利。地圖繪制、主角的動(dòng)態(tài)顯示、按鍵的檢測(cè)、圖層的控制等游戲?qū)俚奶匦远嫉玫搅嗽谝苿?dòng)設(shè)備上最大的發(fā)揮。</p><p>  LayerManager(以下簡(jiǎn)稱LM)提供控制整體畫(huà)面層的控制。它包括了一系列自動(dòng)獲取了代號(hào)和位置的層,簡(jiǎn)化了各層加入游戲畫(huà)面的過(guò)程,提供了自動(dòng)排序和繪制的能力。</p><p>  LM存儲(chǔ)了一個(gè)層的列表,新的層可以用append

68、函數(shù)附加、刪除和插入。層的序號(hào)相當(dāng)于坐標(biāo)的Z軸,0層表示最接近用戶視覺(jué),層數(shù)越高,離用戶越遠(yuǎn)。層號(hào)總是連續(xù)的,即使有中間的層被移除,其他層的序號(hào)會(huì)作相應(yīng)的調(diào)整以保持整體的完整性。LM中的View Window控制著與LM相對(duì)坐標(biāo)的可視區(qū)域。改變View Window的位置可以制造出滾動(dòng)屏幕的效果。</p><p>  本程序中所有的地圖、坦克都采用LM控制,敵方坦克的生成由附加一個(gè)EnemySprite對(duì)象得到。

69、唯有界面右側(cè)的計(jì)分欄由Graphics類繪制。</p><p>  Sprite類是繼承自Layer的用于存儲(chǔ)多楨的基本可視元素。不同的frame可交相顯示,構(gòu)成動(dòng)態(tài)的效果。圖片可翻轉(zhuǎn)、顛倒、由一個(gè)主角圖片就可以方便的得到所有方向的顯示狀態(tài),相比原先只能使用Canvas繪圖,需要將所有方向的主角圖象都繪制在png圖象中簡(jiǎn)化了許多。Sprite也可以從整合的圖象中讀圖,讀圖時(shí)將把大圖分解為若干等寬等高的小圖。每個(gè)小

70、圖按照其排列順序有相應(yīng)的序號(hào),在程序中調(diào)用其序號(hào),就可以繪制出相應(yīng)的圖片。本程序中的雙方坦克、子彈都由Sprite繼承得到。在有些情況下,控制主角的翻轉(zhuǎn),尤其是多幅圖片配合顯示的過(guò)程,如果將多圖的共享定位點(diǎn)設(shè)置在通常的左上角,將很不容易控制,因?yàn)樵S多翻轉(zhuǎn)都是以其他點(diǎn)為參考電的(比如,中心點(diǎn))。由此,引入?yún)⒖键c(diǎn)的概念。參考點(diǎn)由defineReferencePixel函數(shù)確定未翻轉(zhuǎn)圖片狀態(tài)時(shí)的坐標(biāo)。默認(rèn)是(0,0)點(diǎn),如果需要,可將參考點(diǎn)設(shè)

71、置在畫(huà)面邊界之外。本程序中的坦克的參考點(diǎn)定義在圖片正中,以便簡(jiǎn)便的實(shí)現(xiàn)轉(zhuǎn)向等功能。子彈的參考點(diǎn)設(shè)置在子彈底部的中心,因?yàn)樽訌椧怀雠谕驳臅r(shí)候緊挨著坦克的象素就是其底部中心。</p><p>  TiledLayer是有一組圖象格元素(grid of cells)組成的整塊虛擬圖象。該類使不需要高分辨率的圖象就能創(chuàng)建大幅圖面成為可能。這項(xiàng)技術(shù)通常應(yīng)用在2D游戲平臺(tái)的滾動(dòng)背景的繪圖。一塊整圖可被分割成等大小的圖象格,每

72、塊格有其對(duì)應(yīng)的序號(hào),按照行列遞增。多塊格可由大塊同時(shí)替換組合而模擬動(dòng)態(tài)的背景,這不需要逐塊替換所有的靜態(tài)圖象格而顯得非常方便。</p><p>  本程序中的地圖即為游戲背景。每塊障礙物都有其響應(yīng)的代號(hào),其中,用戶需保護(hù)的總部因?yàn)轶w積稍大,使用了四塊圖象格顯示。地圖背景分為20*22個(gè)圖象格,每個(gè)格使用一個(gè)字節(jié)表示其中的障礙物,圖象文件存儲(chǔ)在外部文件中,以16進(jìn)制的整數(shù)串表示,因此每個(gè)地圖的大小為固定的440字節(jié)

73、。如果整塊地圖均由繪圖產(chǎn)生,將導(dǎo)致體積迅速增加,且對(duì)坦克與障礙物的碰撞也難以檢測(cè)。J2ME中并沒(méi)有J2SE中的File類,獲取外部文件的手段很有限,僅僅在Class類中提供了一個(gè)getResourceAsStream函數(shù),將外部文件獲取為輸入流,再由InputStream的繼承類讀出。</p><p>  3.3.5 有關(guān)繪圖的一些技術(shù)</p><p>  在沒(méi)有MIDP2.0前,進(jìn)行游

74、戲繪圖一般需要手動(dòng)編程使用雙緩沖。需要在paint()方法內(nèi)所想要畫(huà)的圖形畫(huà)在一張預(yù)先準(zhǔn)備好的背景,等所有繪圖操作都完成后再將背景的數(shù)據(jù)拷貝到實(shí)際的屏幕上。Image類提供了一個(gè)建立背景的靜態(tài)方法createImage(int width, int height),再利用getGraphics()方法取得屬于這個(gè)背景的Graphics對(duì)象,所進(jìn)行的繪圖操作都會(huì)作用在背景上,等到全部的繪圖操作完成后,再調(diào)用drawImage()方法將背景

75、的數(shù)據(jù)復(fù)制到實(shí)際顯示的屏幕上。</p><p>  這樣的技術(shù)在繪制動(dòng)畫(huà)時(shí)特別有用。繪制動(dòng)畫(huà)時(shí)經(jīng)常需要不斷地更新畫(huà)面,而更新畫(huà)面的操作就是先將屏幕以fillRect()的方式清除,再將下一張圖片畫(huà)在屏幕上,然而反復(fù)的清除及重繪會(huì)造成屏幕的閃爍現(xiàn)象(flicker),因此使用雙重緩沖的好處就是在背景進(jìn)行這個(gè)清除及重繪的操作,再將完成的繪圖拷貝到屏幕上,由于用戶看不到清除的操作,因此就不會(huì)出現(xiàn)閃爍的現(xiàn)象了。不過(guò)在某些

76、MIDP的實(shí)現(xiàn)上已經(jīng)加上了雙重緩沖的支持,因此在處理前應(yīng)先利用Canvas類的isDoubleBuffer()方法來(lái)判斷。</p><p>  3.4 坦克的控制和敵方的智能運(yùn)行</p><p>  GameCanvas中提供了與以往MIDP1.0不同的鍵盤(pán)采樣功能。Canvas類中采取響應(yīng)鍵盤(pán)事件的方法,每次執(zhí)行周期時(shí)會(huì)讀取keyPressed函數(shù)中需執(zhí)行的代碼。這樣的機(jī)制并不適合某

77、些游戲場(chǎng)合。在某些不支持keyRepeat功能的設(shè)備上,反復(fù)執(zhí)行的按鍵,比如發(fā)射子彈,將不能因?yàn)殚L(zhǎng)時(shí)間按壓而自動(dòng)重復(fù),這樣就需要用戶高頻率的手動(dòng)擊鍵,這在操縱空間非常有限的移動(dòng)設(shè)備上是非常困難的。同時(shí),事件的執(zhí)行周期也并不一定適合游戲的場(chǎng)合,也許需要更高頻率執(zhí)行的按鍵卻只能在指定的周期內(nèi)規(guī)律的響應(yīng)。對(duì)此,針對(duì)游戲的開(kāi)發(fā),Game包提供的鍵盤(pán)狀態(tài)功能將顯得十分有效。</p><p>  GameCanvas提供ge

78、tKeyStates函數(shù)可獲取當(dāng)前鍵盤(pán)上的信息。將以位的形式返回鍵盤(pán)上所有鍵的按與釋放的狀態(tài),當(dāng)bit為1時(shí),鍵就是被按下的狀態(tài),為0時(shí)則為釋放狀態(tài)。只需要此一個(gè)函數(shù)的返回值就可以返回所有鍵的狀態(tài)。這保證了快速的按鍵和釋放也會(huì)被循環(huán)所捕捉。同時(shí),這樣的機(jī)制也可檢測(cè)到幾個(gè)鍵同時(shí)按下的狀態(tài),從而提供斜向運(yùn)行等相應(yīng)功能。</p><p>  敵方按照規(guī)則不能和用戶坦克重合,則它每行走一步就需要把用戶坦克掃描一次,判斷其

79、是否碰撞到了用戶的坦克。Sprite類中提供了collidesWith函數(shù),用于判斷是否與某個(gè)TiledLayer、Sprite、Image的對(duì)象有圖象上的重合(即游戲中的碰撞)。然而不能僅僅將用戶坦克作為其Sprite參數(shù)傳遞給敵人的類進(jìn)行判斷。因?yàn)槿绻l(fā)生碰撞,collidesWith成立,則兩輛坦克已經(jīng)發(fā)生了圖象重合,違反了規(guī)則,甚至若再進(jìn)行collidesWith判斷的話,其結(jié)果將永為真。為了提前預(yù)知碰撞,可以將所有坦克的碰撞范

80、圍設(shè)定為一個(gè)比坦克圖片稍大一些的矩形,此矩形僅在坦克前方比坦克圖形多出一個(gè)象素。在多出的11個(gè)象素中,按照每個(gè)象素依次檢查此象素是否于外界發(fā)生碰撞,如果不是按照象素檢查,則當(dāng)坦克與障礙物錯(cuò)位并同時(shí)與兩種物體接觸時(shí)將有可能忽略檢測(cè)其中的一樣物體。這樣,就可以提前一步判斷。如果發(fā)生碰撞,則坦克應(yīng)當(dāng)選擇掉轉(zhuǎn)方向,此時(shí),兩輛碰撞的坦克又因?yàn)槠渚匦螀^(qū)域不重合而不符合collidesWith的條件,就可以繼續(xù)正常運(yùn)行了。</p>&l

81、t;p>  敵方坦克由于需要具有一定的智能性,以便對(duì)玩家攻擊,使之具有一定的可玩性。敵人可以自動(dòng)行走,但是應(yīng)當(dāng)在以下適當(dāng)?shù)那闆r下轉(zhuǎn)向:首先是是否超出界面的邊界,其次是是否與地圖障礙物發(fā)生了碰撞,再次是是否與用戶坦克發(fā)生了碰撞。需要指出的是,當(dāng)發(fā)生阻礙不能在不變方向的情況下繼續(xù)行走時(shí),并不一定立即需要采取轉(zhuǎn)向的對(duì)策。如果一定發(fā)生轉(zhuǎn)向,試想,當(dāng)敵方碰到玩家時(shí),如果它立即轉(zhuǎn)向,將不會(huì)對(duì)玩家發(fā)射射向他的子彈,就不構(gòu)成任何威脅,當(dāng)然,也不能

82、永遠(yuǎn)不轉(zhuǎn)向。本程序設(shè)置為:當(dāng)碰撞到障礙物或邊界時(shí)立即轉(zhuǎn)向,但碰到玩家坦克時(shí)需要有一個(gè)等待的時(shí)間,這個(gè)時(shí)間由碰撞前隨機(jī)取得的在某方向上的持續(xù)行走步數(shù)決定,當(dāng)發(fā)生坦克間碰撞時(shí),此隨機(jī)數(shù)將在下一次循環(huán)前減少為原來(lái)的2/3,這樣就實(shí)現(xiàn)了加快轉(zhuǎn)向的時(shí)間,避免死鎖在一個(gè)方向上靜止的停留過(guò)長(zhǎng)的時(shí)間。另外,坦克的發(fā)炮間隔和轉(zhuǎn)后的具體方向都由隨機(jī)數(shù)決定。坦克之間由以上道理也不會(huì)發(fā)生重疊,但當(dāng)某坦克正從上方生成而正巧有另一輛阻礙在其生成點(diǎn)處,這將導(dǎo)致不可避

83、免的重合。這是允許的,但需要對(duì)他們標(biāo)注狀態(tài),即當(dāng)坦克剛出現(xiàn)時(shí)暫時(shí)允許重合,一旦在某個(gè)時(shí)間他們脫離了重合狀態(tài),就不能在允許重合,如果不設(shè)置這</p><p>  3.5 子彈的運(yùn)行和控制</p><p>  每一個(gè)坦克都有他自己的一顆子彈,這顆子彈在任何一輛坦克被構(gòu)造時(shí)就一直存在,直至此坦克生命的結(jié)束,子彈的再次只是將屏幕上暫時(shí)掩蓋的圖象重新置于坦克炮筒才恰當(dāng)位置,并使其顯示出來(lái),這與現(xiàn)實(shí)中

84、每個(gè)子彈都是單獨(dú)的個(gè)體有所不同。</p><p>  子彈所需要完成的任務(wù)有:</p><p>  它是一個(gè)繼承了Runnable虛類的可運(yùn)行單獨(dú)線程的對(duì)象。在其出現(xiàn)在屏幕上的運(yùn)行周期中,每一步都需要循環(huán)檢測(cè)以下條件:</p><p>  是否與某坦克發(fā)生了碰撞,即擊中了這輛坦克。子彈使用的是象素級(jí)的碰撞檢測(cè),因?yàn)樽訌椀膱D片形狀不規(guī)則,如果使用矩形碰撞檢測(cè),將有可能

85、在子彈尚未接觸到物體時(shí)就已返回碰撞的真值。分為兩種情況,如果此子彈來(lái)自于敵方,將只檢測(cè)玩家坦克,因?yàn)閿撤街g的子彈必須允許可以透明的穿過(guò),以保證不會(huì)在敵人之間發(fā)生子彈的消減。如果來(lái)自玩家,則每一步需掃描所有的敵方坦克,檢查是否發(fā)生碰撞,這可能會(huì)花費(fèi)不少的CPU時(shí)間。</p><p>  其次,子彈之間需要檢測(cè)是否碰撞。敵人之間顯然,如上已經(jīng)提過(guò),不需要檢測(cè),但敵人與玩家之間應(yīng)當(dāng)可以互相消除子彈,以便在狹窄的路口中

86、仍有存活的機(jī)會(huì)。玩家的子彈需要在每一步檢測(cè)所有敵人的子彈的運(yùn)行狀態(tài)。這樣較多的運(yùn)算也將不可避免的耗費(fèi)大量CPU時(shí)間。</p><p>  子彈對(duì)不同障礙物將有不同的反映。對(duì)磚墻將有能力將其擊毀,使之在畫(huà)面上消失;對(duì)水泥鋼筋將不能發(fā)生作用,子彈也不能通過(guò);對(duì)于河流,坦克不可以通過(guò),但子彈可以;對(duì)于草叢,子彈和坦克都可以通過(guò)。</p><p>  3.6 RMS數(shù)據(jù)庫(kù)系統(tǒng)</p>

87、<p>  MIDP為MIDlets提供了一種永久存儲(chǔ)和后來(lái)讀出數(shù)據(jù)的數(shù)據(jù)庫(kù)解決方案,被稱為Record Managerment System(RMS),是一種類簡(jiǎn)單的基于記錄的數(shù)據(jù)庫(kù)。</p><p>  很顯然,手機(jī)上的數(shù)據(jù)庫(kù)系統(tǒng)不可能有PC上的強(qiáng)大功能。微小的存儲(chǔ)空間也限制了它們的結(jié)構(gòu)不能過(guò)于復(fù)雜。RMS是專門(mén)針對(duì)移動(dòng)設(shè)備的服務(wù)的。</p><p>  RMS包中包括Re

88、cordStore類。在一個(gè)MIDlet suite包里的所有MIDlet都允許創(chuàng)建多個(gè)記錄集,只要它們賦有不同的名稱。當(dāng)MIDlet包從平臺(tái)中被移除后,所有與該包有關(guān)的的記錄集都同時(shí)會(huì)被移除。同一個(gè)包內(nèi)的MIDlets可以直接互相訪問(wèn)它們的記錄集,不同包內(nèi)也可產(chǎn)生共享,但這需要有包的授權(quán)屬性決定。訪問(wèn)模式會(huì)在準(zhǔn)備提供共享的RecordStore被建立時(shí)被創(chuàng)建。訪問(wèn)模式允許私有使用或訪問(wèn)。</p><p>  R

89、ecordStore的API采用了時(shí)間戳的概念,其長(zhǎng)整型變量由System的currentTimeMillis()函數(shù)返回決定。Record store 每次被修改后都會(huì)自動(dòng)在其屬性上附加上時(shí)間戳,這為同步化引擎和程序的控制都極為有效。</p><p>  記錄是字節(jié)數(shù)組。開(kāi)發(fā)者可以利用InputStream的派生類DataInputStream、DataOutputStream以及ByteArrayInputS

90、tream、ByteArrayOutputStream將不同種類的數(shù)據(jù)類型打包,以字節(jié)流的形式發(fā)送和接收。</p><p>  區(qū)別記錄的唯一標(biāo)記是他們的ID值,作為記錄集的主鍵。第一項(xiàng)記錄的ID是1,其后的每個(gè)記錄ID遞增。</p><p>  Record是以字節(jié)為基本單位來(lái)存放的,所以所有要寫(xiě)入record的數(shù)據(jù)都必須先將其轉(zhuǎn)為字節(jié)才能寫(xiě)入,從record所讀出來(lái)的數(shù)據(jù)也是字節(jié),必須

91、將其轉(zhuǎn)換為原先寫(xiě)入時(shí)的數(shù)據(jù)類型才有意義。</p><p>  然而讀取或?qū)懭氲淖止?jié)數(shù)組都只能代表一個(gè)字段的信息,如果需要讀取或?qū)懭攵鄠€(gè)字段就必須要將數(shù)據(jù)轉(zhuǎn)換成字節(jié)信息,并且提供適當(dāng)?shù)臋C(jī)制來(lái)分隔這些信息。主要有兩種方法:</p><p><b>  標(biāo)記法。</b></p><p>  將所有要存放的數(shù)據(jù)用字符串表示,但是在字段和字段之間以一個(gè)特

92、殊的符號(hào)作為分隔。符號(hào)不能和字段內(nèi)的數(shù)據(jù)相同的字符。</p><p>  2.利用輸入/輸出流</p><p>  這一種方法較上一種復(fù)雜,但是較為實(shí)用。方法一中所有的字段只能以字符串的形式存儲(chǔ),要對(duì)這些字段作進(jìn)一步的處理非常麻煩。利用輸入輸出流可以寫(xiě)入及讀取不同數(shù)據(jù)類型的數(shù)據(jù),做法是在寫(xiě)入數(shù)據(jù)時(shí)先將一個(gè)DataOutputStream數(shù)據(jù)流對(duì)象串接到一個(gè)ByteArrayOutStrea

93、m數(shù)據(jù)流對(duì)象,然后再依字段的數(shù)據(jù)類型用writeInt()、writeBoolean()等方法寫(xiě)入,最后把ByteArrayOutputStream內(nèi)的元素?cái)?shù)據(jù)寫(xiě)入record中。反之若要讀取數(shù)據(jù),則先要串接一個(gè)DataInputStream對(duì)象和ByteArrayInputStream,依字段的數(shù)據(jù)類用readInt()、readBoolean()等方法讀取。</p><p>  本程序中主要存放在永久區(qū)的內(nèi)容

94、為用戶得到的最高分?jǐn)?shù)的記錄。一共可以存儲(chǔ)10條最高分。每次有新的更高的記錄就會(huì)插入進(jìn)相應(yīng)的位置,將最低一名排擠出記錄。在輸入記錄前,要求用戶在TextField框中寫(xiě)入他自己的名字。返回的getString可以將名字輸送給字節(jié)流。因?yàn)槊總€(gè)記錄包括用戶名和分?jǐn)?shù),因此需要使用多字段的方式編入。打印到屏幕上時(shí),記錄ID號(hào)即為排名,因此將顯示三項(xiàng)數(shù)據(jù)。</p><p>  3.7 內(nèi)存使用的最佳化</p>

95、<p>  通常在MIDP應(yīng)用程序的手機(jī)執(zhí)行環(huán)境中,所牽涉的內(nèi)存有下列三種:</p><p><b>  ﹡應(yīng)用程序存儲(chǔ)內(nèi)存</b></p><p>  ﹡RecordStore存儲(chǔ)內(nèi)存</p><p>  ﹡執(zhí)行時(shí)期內(nèi)存(Java Heap)</p><p>  其中前兩種是持久性的內(nèi)存,關(guān)閉電源后還能保持

96、數(shù)據(jù)的正確性,通常這兩種內(nèi)存所能存儲(chǔ)的容量是合并計(jì)算的,這個(gè)上限對(duì)每種手機(jī)都不一樣,大部分在一兩百KB內(nèi)。在這樣的情況下需要在不影響原有功能的情況下適當(dāng)?shù)目s減JAR文件的大小,除了可以克服內(nèi)存空間的限制外,也能大幅度縮短下載的時(shí)間(費(fèi)用也降低了),勢(shì)必會(huì)有更多的人愿意下載所開(kāi)發(fā)的程序。其方法有:</p><p>  第一,就是盡量縮短命名的長(zhǎng)度。在應(yīng)用程序內(nèi),對(duì)于所建立的類、接口、方法及變量名而言,都需要賦予一個(gè)

97、識(shí)別的名稱,所命名的名稱每多一個(gè)字符就會(huì)在類文件內(nèi)多產(chǎn)生一個(gè)字節(jié),對(duì)于一個(gè)較復(fù)雜的應(yīng)用程序而言就會(huì)增加為數(shù)不小的數(shù)據(jù)量。所有這些可以借助混淆器來(lái)幫助實(shí)現(xiàn)。</p><p>  第二是減少?gòu)?fù)雜的程序結(jié)構(gòu),為一些共同的行為建立一個(gè)抽象類(Abstract Class) 來(lái)表示繼承的子類的共通性。</p><p>  第三是減少圖形數(shù)據(jù)的大小。將PNG格式的小分辨率圖象合并在一張大的高分辨率圖象

98、中,由于減少了chunks,將比合并前的總大小減少許多。</p><p>  3.8 混淆器(Obfuscator)的使用</p><p>  Java 語(yǔ)言并沒(méi)有完全編譯成二進(jìn)制可執(zhí)行文件,編譯出的.class文件是一種介于源程序和二進(jìn)制之間的一中基于半解釋的字節(jié)碼,需要虛擬機(jī)來(lái)執(zhí)行。它包括了所有的信息。然而這樣會(huì)導(dǎo)致.class很容易被反編譯為源代碼,從而不能保護(hù)作者的知識(shí)成果。目前

99、流行的如decode,JAD等反編譯工具可以以很快的速度生成源文件。如果不加以施行有效的措施,將造成嚴(yán)重的后果。</p><p>  由此引入混淆器的概念。混淆器將代碼中的所有變量、函數(shù)、類的名稱變?yōu)楹?jiǎn)短的英文字母代號(hào),如果缺乏相應(yīng)的函數(shù)名指示和程序注釋,即使被反編譯,也將難以閱讀。</p><p>  混淆器的作用不僅僅是保護(hù)代碼,它也有精簡(jiǎn)編譯后程序大小的作用。由于以上介紹的減少變量、

100、函數(shù)的命名長(zhǎng)度的關(guān)系,編譯后也會(huì)從.class文件中減少這些冗余的信息?;煜螅w積大約能減少25%,這對(duì)當(dāng)前費(fèi)用較貴的無(wú)線網(wǎng)絡(luò)傳輸是有一定意義的。</p><p>  為了能與各種IDE集成,就像Java2 SDK一樣,混淆器采用命令行參數(shù)的形式,以便可被其調(diào)用。目前流行的Obfuscator有RetroGuard等。</p><p>  3.9 模擬器的相關(guān)調(diào)試</p>

101、<p>  IDE整合的Wireless Tool Kit提供了許多在運(yùn)行時(shí)監(jiān)視運(yùn)行狀態(tài)的工具。 包括內(nèi)存狀況的檢測(cè)(手機(jī)上的內(nèi)存空間十分有限,必須時(shí)刻關(guān)注機(jī)載內(nèi)存是否大于程序所能使用到的最大可能的內(nèi)存空間),網(wǎng)絡(luò)狀況的檢測(cè),運(yùn)行函數(shù)的跟蹤等。如圖3-4,是內(nèi)存跟蹤測(cè)試隨時(shí)間變化的調(diào)試器。其中,允許強(qiáng)制垃圾回收(Garbage Collection)。由于Java語(yǔ)言中,不像許多其他的如C++語(yǔ)言,不需要指定回收函數(shù)中特定不

102、使用的資源,資源回收機(jī)制將自動(dòng)清空無(wú)效變量占用的空間。在程序運(yùn)行中也可以調(diào)用System類的gc()函數(shù)手動(dòng)收回廢棄的內(nèi)存。</p><p>  3.10 本章小結(jié):</p><p>  第三章中介紹了程序的流程、相關(guān)技術(shù)的思想及其在本程序中的應(yīng)用。分別對(duì)繪圖、數(shù)據(jù)庫(kù)、游戲基本算法等做了詳細(xì)敘述。具體算法的代碼實(shí)現(xiàn)和詳細(xì)流程將在下章介紹。</p><p>  第四

103、章 程序分析和具體實(shí)現(xiàn)</p><p>  4.1 游戲進(jìn)入前的選擇</p><p>  每個(gè)MIDlet程序都必須有一個(gè)主類,該類必須繼承自MIDlet。它控制著整個(gè)程序的運(yùn)行,并且可以通過(guò)相應(yīng)函數(shù)從程序描述文件中獲取相關(guān)的信息。該類中擁有可以管理程序的創(chuàng)建、開(kāi)始、暫停(手機(jī)中很可能有正在運(yùn)行程序卻突然來(lái)電的情況,這時(shí)應(yīng)進(jìn)入暫停狀態(tài)。)、結(jié)束的函數(shù)。</p><p&

104、gt;  進(jìn)入時(shí),首先載入畫(huà)面的不是游戲運(yùn)行狀態(tài),而是提供選項(xiàng),當(dāng)再次選擇Start Game時(shí)才正式運(yùn)行。運(yùn)行畫(huà)面如圖4-1所示。因此,在TankMain的構(gòu)造函數(shù)中分配了StartChoice類,即選項(xiàng)畫(huà)面的內(nèi)存空間。在startApp()函數(shù)中,隨即調(diào)用了Displable的setCurrent()函數(shù)將當(dāng)前屏幕設(shè)置為startChoice。在顯示高級(jí)用戶界面前,建造了一個(gè)Alert類。Alert對(duì)象用于顯示提示、警告等告之用戶信

105、息的臨時(shí)閃現(xiàn)的屏幕,它可作為setCurrent的參數(shù),提前顯示在最終需要顯示的屏幕前。當(dāng)將FOREVER作為Alert的參數(shù)時(shí),將永久顯示,直到用戶點(diǎn)擊相應(yīng)按鈕手動(dòng)結(jié)束。但是當(dāng)顯示的畫(huà)面元素超過(guò)一屏大小時(shí),將自動(dòng)轉(zhuǎn)換為永久狀態(tài)。在此,由于貼在Alert上的圖片大小超出了其范圍,故已成為永久狀態(tài)。效果如圖4-2所示。</p><p>  startChoice繼承了接口commandListener,這樣,就可以

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論