1、 第 1 页基于 GUI 的手机游戏开发摘 要:这款游戏的名字叫大富翁。J2ME(Java 2 Micro Edition) 是近年来随着各种不同设备,尤其是移动通信设备的飞速发展而诞生的一项新的开发技术。它定位在消费性电子产品的应用上,对设备的智能化、多样化,提供了革命性的解决方案,并因其“Write Once, run anywhere”的 Java特性而提高开发的效率。随着手机的日益普及、Java 功能在移动设备上的实现,Java 应用程序产生的手机增值服务逐渐体现出其影响力,对丰富人们的生活内容、提供快捷的资讯起着不可忽视的作用。本论文着眼于 J2ME技术的应用,开发一款可商用的手机游
2、戏程序。本程序将老少皆宜的经典作品移植到手机上来,为更流行的硬件平台提供应用软件。本论文介绍了 J2ME的相关技术及本程序的结构分析和具体功能的实现。关键字:J2ME;手机游戏;JavaAbstract: The game is called the “Monopoly.“ J2ME (Java 2 Micro Edition) in recent years with various equipment, particularly mobile communications equipment and the rapid development of the birth of a new d
3、evelopment technology. It positioning in consumer electronics applications, the equipment intelligent, diversified, providing a revolutionary solution, and because of “Write Once, run anywhere“ of the Java development and improve the efficiency. With the growing popularity of mobile phones, Java fea
4、tures on mobile devices the realization, Java application of the mobile phone value-added services gradually reflect their influence to enrich peoples lives, to provide fast information can not be ignored to play the role. The papers focus on J2ME technology applications, the development of a commer
5、cial mobile phone can Games. This procedure will be the classic works of all ages migrate to the phone line, for the more popular hardware platform to provide application software. This paper introduced the J2ME technology and the process of structural analysis and specific functions can be achieved
6、. Keyword: J2ME; mobile phone games; Java第 2 页目 录第一章 绪论 31.1 课题的研究背景与意义 31.2 JAVA 语言的特点和及其与游戏的结合 .41.2.1 J2ME 介绍 .41.2.2 Java 语言的特点 .51.2.3 Java 与网络的结合 .61.3 手机游戏应具有的特征 .71.4 需求分析 .81.4.1 系统初步分析 81.4.1.1 用户需求分析 .81.4.1.2 功能需求分析 .91.4.1.3 系统的可靠性和可用性需求分析 91.4.2 数据流分析 101.5 本章小结 10第二章 开发环境及相关技术的介绍 .102
7、.1 开发环境 .102.2 JAVA 语言特点 .112.3 关于 ECLIPSE112.4 关于 WIRELESS TOOL KIT .122.5 JAVA APPICATION MANAGER.122.6 本章小结: 12第三章 程序结构、思想和相关技术 .123.1 本程序需要解决的主要技术问题 123.2 程序流程 .133.3 CANVAS 类 143.4 GRAPHICS 类 .153.5 MIDP1.0 技术下的绘制背景技术 153.6 MIDP2.0 新增的 GAMECANVAS 包 .153.7 PNG 图片格式 163.8 内存的优化 173.9 内存检测器 173.10
8、 关于混淆器 .173.11 本章小结 .18第四章 程序分析和具体实现 .184.1 游戏进入前的选择 184.2 MYBULLETS 类 204.3 游戏逻辑及 GAMESCREEN 类 .204.3.1 gameScreen 类所实现的功能 204.3.2 地图的创建 .204.3.3 地图的移动 .214.3.4 gameScreen 类的构造函数 21第 3 页4.3.5 关于 commandAction()方法 .224.4 详细设计 224.4.1 Player 类的设计与实现: 224.4.2 Statistic 类的设计与实现: .244.5 本地翻译包的设计 244.5.1
9、 TranslationBoudle 类的设计与实现 .254.5.2 MapTranslator 类的设计与实现 .264.6 网络包的设计 294.7 人工智能包的设计 344.8 其他工具类的设计 37第五章 测试 .425.1 打包测试的过程 425.2 发现的 BUG 及解决情况 445.3 未完善的功能 44第六章 总 结 456.1 本程序的总结和展望 456.2 感想 45致 谢 .46参考文献 47附录一 代码 48附录二 操作说明 49附录三 英文文献及其译文 50第 4 页第一章 绪论1.1 课题的研究背景与意义随着计算机日益普及,计算机已然成为人们日常生活的一部分的今天
10、,计算机游戏也越来越成为人们生活中不可或缺的元素。游戏可以简单地理解为调节人们生活节奏和缓解人们生活压力的一种手段。现在理解的游戏基本意义都是娱乐性质较浓,要有特定的行为模式,遵循一定规则以达到游戏者目的的行动。游戏的最初目的就是让游戏者(玩家)在游戏中得到放松。游戏一直存在于人类活动中,如今定义的游戏从早期的猜谜游戏,发展到如今的单机 RPG游戏,网络游戏等,已经升华为更高级别意义上的娱乐活动,对人们的感官刺激也越发强烈,得到的乐趣也更多。而对于编写游戏而言,Java终于变得足够成熟了(Java 的语言特性和其与游戏的结合请见下一小节) 。它现在是一种开发能够在多种平台上运行的中小型游戏的很
11、好的方式。此外,Java 支持和其他的库一起工作,而且它的速度变得越来越快。Java 并不是以游戏编程为目的而被开发的,事实上,游戏编程可能是 Java创造者心中的最后一个目标。在过去,妨碍 Java发展的是它的运行环境;浏览器和 Java类库一起从本质上决定了 Java应该用来写哪种类型的应用程序,而高速的游戏和图象则不在其中。这给 Java带来了不好的影响,因为人们注意的不是语言,而是它的运行环境。现在,浏览器已经不能控制一切了,Java 作为游戏编程语言的另一个机会到来了。Java 在过去有一点超前于它的时代,当时市场的动力落后于Java,但是现在 Java可以而且已经取得成功。据悉,中
12、国民族网络游戏出版工程将在 5年内出版 100种大型民族网络游戏,总投资预计超过 3亿元。信息产业部已将网络游戏通用引擎研究及示范产品纳入国家“863 计划” ,这是中国首次将网络游戏技术纳入国家科技计划。文化部也向国内 12家在网络游戏业的实力厂商首批颁发了网络文化经营许可证 ,加大对网络游戏的监管力度,进口游戏审查制,限制国内对国外的受理措施。科技部制定科技发展规划,将把网络游戏纳入现代服务业并加以扶持。政府态度和政策都是一种信号,表明 2005年对本土网络游戏的扶持力度将加大;国内游戏厂商将可获得发展的核心技术平台;政策有利于保护中国游戏软件的自主知识产权;这为网络游戏发展创造了良好的政
13、策环境。而 Java的创建者把 Java称为“网络编程语言” ,且由于 JAVA游戏一般来说简单有趣,并且对用户硬件要求极小,所以 JAVA游戏通常对 85%的计算机用户都有吸引力。第 5 页1.2 Java 语言的特点和及其与游戏的结合1.2.1 J2ME 介绍虽然 Java 已经被用到许多企业级软体上,可是其实骨子里面还是非常适合用在嵌入式系统之中。Java 平台演进到 Java2后,Java 平台分别针对不同领域的需求被分成四个版本,亦即 J2EE、J2SE、J2ME 以及 JavaCard。其中 J2ME定位在消费性电子产品的应用上。这个版本针对资源有限的电子消费产品的需求精简核心类库
14、,并提供了模块化的架构让不同类型产品能够随时增加支持的能力。这个版本的应用层面相当广泛,会是未来 Java平台发展的重点项目。J2ME在 1999年的 JavaOne开发人员大会上初次亮相,它的目标是面向智能无线设备和小型计算机设备的开发人员。J2ME 的一个关键优点是,J2ME 与所有支持 Java的设备都是兼容的。支持 Java的设备就是任何运行 Java虚拟机器的计算机。Motorola、Nokia等生产厂商都生产支持 Java的设备。、J2ME平台是由配置(Configuration)和简表(Profile)构成的。配置是提供给最大范围设备使用的最小类库集合,在配置中同时包含 Java
15、虚拟机。简表是针对一系列设备提供的开发包集合。在 J2ME中还有一个重要的概念是可选包(Optional Package),它是针对特定设备提供的类库,比如某些设备是支持蓝牙的,针对此功能 J2ME中制定了JSR82(Bluetooth API)提供了对蓝牙的支持。目前,J2ME 中有两个最主要的配置,分别是 Connected Limited Devices Configuration(CLDC)和 Connected Devices Configuration(CDC)。作为第一个面对小型设备的 Java应用开发规范,CLDC 是由包括 Nokia,Motorola和 Siemens在内的
16、 18家全球知名公司共同协商完成的。CLDC 是 J2ME核心配置中的一个,可以支持一个或多个 profile。其目标主要面向小型的、网络连接速度慢、能源有限(主要是电池供电)且资源有限的设备,如手机、PDA 等。而 CDC则是主要用于运算能力相对较佳、在电力供应上相对比较充足的嵌入式装置 (比方说冷气机、电冰箱、电视机机顶盒 (set-top box)1.2.2 Java 语言的特点Java能够取得如此的成功,是因为它在设计时的目标就定位在要解决当今程序员们第 6 页所面临的众多问题。Java 的基本目标之一就是要提高生产率。生产率来源于许多方面,但是 Java希望在语言方面相对于它的前辈有
17、明显的提高,从而为程序员提供更大的便利。1.系统易于表达、易于理解被设计用来适应问题的“类” ,在表达问题的能力上显得更强。这意味着当你编写代码时,你是在用问题空间的术语,而不是计算机也就是解空间的术语,来描述解决方案。可以用更高层的概念来处理问题,并且只用一行代码就可以做更多的事。易于表达所带来的另一个好处就是易于维护,维护在程序生命周期中所占的成本比例极大。如果程序易于理解,那么他必定易于维护。同时,这也降低了创建和维护文档的费用。2.类库的巨大影响力创建程序最快捷的方式就是使用已经编写好的代码:类库。Java 的主要目标之一就是要使类库更易于使用。这是通过将类库转型为新的数据类型来实现的
18、,因此,引入类库意味着在语言中添加了新的数据类型。因为 Java编译器会照管类库的使用方式确保正确地初始化和回收垃圾,并保证其他方法被正确地调用,因此,你只需专注于你想让类库做些什么,而不必关心应如何去做。3.错误处理在 C语言中,错误处理一直是一个声名狼籍的问题,而且经常被忽视经常只能靠上帝保佑了。如果你在构建一个大型的、复杂的程序,那么没有什么比在程序某处暗藏了一个错误,而你却没有任何能够暗示它在何处的线索更糟糕的事情了。Java 异常处理便是一种能够确保错误必须被报告,而且对此必须有所响应的机制。4.大型程序设计许多传统语言在程序大小和复杂度方面都有内置的限制。例如,BASIC 可能对某
19、类问题的解决能力非常强,可以快速地创建解决方案,但是如果程序长度超过数页,或者超出该语言正常的题域之外,它就会像“在非常粘稠的液体中游泳” 。它没有明确的界线来表示何时你所使用的语言会导致最终的失败,即使有这样的界线,你也会忽视它。你总不能说:“我的 BASIC程序太大了,我不得不用 C来重写它!”相反,你会试着将几行代码硬塞进去,以便在程序中增加新功能。因此,不知不觉中,你就付出了额外的开销。Java具备编写大型程序的能力也就是说,它消除了小型程序和大型程序之间的复杂度界线。在编写“hello,world”风格的小应用程序时,你当然不必使用 OOP,但是第 7 页当你需要用到时,这些功能随手
20、可得。而且,对小型程序和大型程序,编译器都会一视同仁地、积极地找出因 bug而产生的错误。1.2.3 Java 与网络的结合Java 不仅是一种功能强大的、安全的、跨平台的、国际化的编程语言,而且它还在不断地被扩展,以提供更多的 语言功能和类库,能够优雅地处理在传统编程语言中很难解决的问题,例如线程、数据库访问、网络编程和分部式计算。Java 是通过 applet 以及使用 Java Web Start 来进行客户端编程的。Applet 是只在 Web 浏览中器运行的小程序,它是作为网页的一部分而自动下载的。当 applet 被激活时,它便开始执行一个程序,这正是它优雅之处:它提供一种分发软件
21、的方法,一旦用户需要客户端软件时,就自动从服务器把客户端软件分发给用户。用户获取最新版本的客户端软件时不会产生错误,而且也不需要很麻烦的重新安装过程。Java的这种设计方式,使得程序员只需创建单一的程序,而只要一台计算机有浏览器,且浏览器具有内置的 Java 解释器,那么这个程序就可以自动在这台计算机上运行。由于 Java是一种成熟的编程语言,所以在提出对服务器的请求之前和之后,可以在客户端尽可能多地多做些事情。例如,不必跨网络地发送一张请求表单来检查自己是否填写了错误的日期或其他参数,客户端计算机就可以快速地标出错误数据,而不用等待服务器作出标记并给你传回图片。这不仅立即就获得了高速度和快速
22、的响应能力,而且也降低了网络流量和服务器负载,从而不会使整个 Internet 的速度都慢下来。Java applet 胜过脚本语言程序的优势之一就是,它是以被编译过的形式存在的,因此其源代码对客户端来说是不可见的。另一方面,虽然反编译 Java applet 并不需要花费多少力气,但是隐藏你的代码通常并不是一个重要的话题。有另外两个因素很重要。如果编译过的 applet 很大的话,那么就需要额外的时间去下载它。脚本语言程序只是被作为Web页面的一部分文本而集成到了 Web 页面中。这对 Web 网站的响应能力来说很重要。另一个因素是非常重要的“学习曲线”问题。如果你是一个 Visual BA
23、SIC 程序员,那么转而学习 VBScript 可能是最快的解决方案,而且由于它或许能够解决大多数典型的客户 /服务器问题,所以你可能很难对学习 Java 报以公正的态度。如果你已经对脚本语言很有经验了,那么你在考虑使用 Java 之前,应该先看看 JavaScript 是否满足你的要求,这样对你会很有好处,因为它们能够更方便地满足你的要求,而且使你更具生产力。Java 引起人们的注意很大程度上始于 applet。Java 确实是一种通用的编程语言,至少第 8 页在理论上可以解决各种其他语言能够解决的问题。正像前面指出的那样,可能存在其他更有效的方式去解决客户/服务器问题。当你离开 apple
24、t 的竞技场时,你便步入了通用应用系统的世界,这里的系统都是独立运行的,不需要浏览器,就像其他普通程序一样。在这里,Java 的威力不仅在于它的可移植性,还包括它的可编程性。Java 已经具备了许多功能,让你创建健壮的程序,而花费的时间比使用 Java 之前的任何编程语言都更少。不过,这是好坏参半的事。为 Java 带来的改进,所付出的代价是降低了执行速度。像任何语言一样,Java 也具有不适合解决某类问题的天生的限制。然而,Java 是快速进化的语言,而且每当发布一个新版本时,它都会因为能够解决更多的问题而变得越来越具有吸引力。1.3 手机游戏应具有的特征一个手机游戏应该具有以下特征:易于学
25、习: 既然手机游戏面向的是普通消费者而不是计算机专家,那么他们不可能深入的学习游戏技巧。消费者不会花几个小时去研究一个 3元的手动操作的游戏。保持游戏的简单是最基本的要求。可中断性: 多任务处理是手机生活方式的基本特征。手机用户常常在任务(如等一个电子邮件或者等车)之间有一小段时间。而游戏、日历管理、通讯和工作数据访问使用的是同一个设备。所以一个好的手机游戏应该提供短时间的娱乐功能,并且允许用户在游戏和工作模式之间顺利切换。基于订阅:手机游戏的盈利成功取决于他们巨大的使用量。一开始开发和设计每个游戏都是昂贵的。如果一个手机游戏开发者要赢利的话,重要的是:同一个游戏引擎,多个标题,基本的故事情节
26、类似。基于订阅的游戏是不断产生收入的最好方法。 丰富的社会交互: 不管一个游戏设计得多好,只要玩家找到了它的根本模式或者玩完了所有的游戏路径很快就会厌烦这个游戏。对于一个基于订阅的游戏,重要的是与别的玩家合作以增强所玩游戏的智力和随机性。在今天纷繁复杂的多玩家游戏中具有丰富社会交互的游戏证明是成功的。利用手机技术的优点: 巨额的手机技术研发费用都花在提高设备和网络的可用性和可靠性上面。因此,手机设备硬件和网络协议与桌面/控制台世界(如全球定位系统(GPS)扩展、条形码扫描仪、和短消息服务(SMS)/多媒体信息服务(MMS)通讯)有着非常大的差别。好的手机游戏应该利用那些更新的设备特征和网络基础
27、设备的优点。第 9 页1.4 需求分析所谓系统分析,就是指在整个系统开发工程中,解决“做什么”的问题,把要解决哪些问题,满足用户哪些具体的信息需求调查分析清楚,从逻辑上或是说从信息处理的功能需求上提出系统的方案,即逻辑模型,为下一阶段进行物理方案设计,解决怎么办提供依据。1.4.1 系统初步分析1.4.1.1 用户需求分析随着 Internet 的发展,进入信息时代后快速获得网络共享资源成为很简单的事情,人们对互联网也有了很大的依赖性。网络的普及化使得原本单人的游戏已经不能适应人们的需要,广大的游戏者迫切需要能够和身在异地的朋友一起享受游戏的乐趣。在这种环境下,网络游戏应运而生,越来越多的游戏
28、者投身到网络游戏中。这样带来的问题自然成为越来越多的游戏研究者将研究方向转为网络游戏的研究。据目前的网络游戏的调研来看,以运动休闲为主的运动类游戏正在受到越来越多玩家的支持和爱戴。但是此类网络游戏中,由 Java 开发的网络游戏仍然是一个空白页,但是它却是一个迫切需要填补的空白页。而 Java 由于其天生的语言特性(请见 1.2 节),很适合用于开发网络游戏,但由于系统环境的问题使得它一直以来未能用于游戏开发,而近来由于 Java 的发展,它已经摆脱了束缚,浮出了游戏开发的水面,若能在网络上出现高要求多人互动的 Java 游戏,它将是一项极为伟大的发展。这也正是现在许多玩家迫切要求的。1.4.
29、1.2 功能需求分析系统功能的需求指定系统必须提供的服务。通过需求分析应该划分出系统必须完成的所有功能。本作的功能模块主要包括游戏的引擎设计,游戏的界面设计。1. 游戏的引擎设计的需求分析:游戏引擎是游戏的灵魂,也就是这个游戏的框架,它的好坏直接决定着游戏的质量。它是控制所有游戏功能的主程序,包括画面的处理,人工智能的实现,接受玩家的设置,以及网络联机的实现等等。所以鉴定一个游戏的好坏,从内部设计的原因上说来,是从游戏的引擎设计体现出来的。一个游戏的引擎设计,直接关系到游戏设计的其他方面,诸如游戏的图形系统、声音系统及设计的物理模块等等各个方面。就如一台电脑需要 CPU 一样,游戏的引擎也第
30、10 页是直接牵制着整个游戏的设计。它的主要作用就是处理游戏中的事件,运行游戏中的图象,输出声音及画面,调整游戏的节奏,响应玩家的游戏监听事件等等。所以,游戏的引擎设计是必要的功能模块,而且游戏的引擎设计必须做好,以使得游戏更具有可玩性。游戏程序是一项精度要求很高的程序系统,因为其代码利用率很高。一个实时运行的最终作品,每秒都会运行成千上万行程序,绘图事件等都会以极高的频率在后台等待响应,若有丝毫的差别都将很容易导致程序在运行不久后可能出现严重错误,甚至死循环。因此,其逻辑设计应当相当严谨,需将所有可能发生的事件及意外情况考虑在设计中。2游戏界面设计的需求分析:作为一个游戏吸引玩家的重要方面,
31、游戏的界面要很漂亮,图形动画的设计是非常必要的。本作将采用模拟动画的方式将战争展现在玩家眼前。设计出丰富的战争环境,游戏中为了美观,适用性强,需要采用外部文件引入的图片贴图,而 Java 中提供了用于处理图片的功能包,使得解决静态或动态、画面背景、屏幕刷新的双缓冲等都有较好的解决方案。1.4.1.3 系统的可靠性和可用性需求分析可靠性需求定量地指定系统的可靠性。例如,游戏在运行过程中不能频繁发生错误而不得不终止游戏。可用性则与可靠性密切相关,它量化了用户可以使用系统的程度。例如,游戏的运行必须保证随时可以,不能在一段不使用的时间内,游戏产生不可预见的错误而致无法运行等等。1.4.2 数据流分析
32、数据流程分析主要包括对信息的流动、传递、处理、存储等的分析。数据流程分析的目的就是要发现和解决数据流通中的问题。通过对本系统的需求分析,确定了系统的基本功能。整个系统的数据流图如图 2-1 所示:1.5 本章小结引言和第一章中介绍了手机在无线应用方向的当今概况,J2ME 的相关内容,分析了J2ME 在手机软件开发中起的重要作用,描述了本论文的相关背景。第 11 页第二章 开发环境及相关技术的介绍2.1 开发环境操作系统:Microsoft Windows XP程序语言:Java 2开 发 包:Java(TM) 2 Standard Edition (5.0)Sun Micro. J2ME Wi
33、reless Tool Kit 2.2IDE: Eclipse 3.012.2 Java 语言特点1. 平台无关性Java引进虚拟机原理,并运行于虚拟机,实现不同平台之间的 Java接口。Java 的数据类型与机器无关。2. 安全性Java的编程类似 C+,但舍弃了 C+的指针对存储器地址的直接操作,程序运行时,内存由操作系统分配,这样可以避免病毒通过指针入侵系统。它提供了安全管理器,防止程序的非法访问。3. 面向对象Java吸收了 C+面向对象的概念,将数据封装于类中,实现了程序的简洁性和便于维护性,使程序代码可以只需一次编译就可反复利用。4. 分布式Java建立在 TCP/IP网络平台上,
34、提供了用 HTTP和 FTP协议传送和接收信息的库函数,使用其相关技术可以十分方便的构建分布式应用系统。第 12 页5. 健壮性Java致力与检查程序在编译和运行时的错误,并自动回收内存,减少了内存出错的可能性。Java 取消了 C语言的结构、指针、#define 语句、多重继承、goto 语句、操作符、重载等不易被掌握的特性,提供垃圾收集器自动回收不用的内存空间。2.3 关于 ECLIPSEEclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括 Java
35、 开发工具(Java Development Tools,JDT)。虽然大多数用户很乐于将 Eclipse 当作 Java IDE 来使用,但 Eclipse 的目标不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE),这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。这种平等和一致性并不仅限于 Java
36、 开发工具。尽管 Eclipse 是使用 Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C+、COBOL 和 Eiffel 等编程语言的插件已经可用,或预计会推出。Eclipse 框架还可用来作为与软件开发无关的其他应用程序类型的基础,比如内容管理系统。Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。2.4 关于 Wireless Tool KitWTK(Wireless Tool Kit)是 Sun公司针对 J2ME推出的用于手机和 Palm等移动设备的开发包,是除手机
37、厂商的专用开发包外唯一的手机模拟器开发包。它通用性高,开发出的应用程序可保证能运行在大部分设备上,而不像专用厂商具有一定的不兼容性。虽然它没有强大的功能和完善的调试手段,但它提供运行模拟器的最基本组件,是其他 IDE需集成采用的必备元素。2.5 Java Appication Manager手机中负责调配程序运行资源的管理后台是 Java Application Manager。它所使用的传输媒体可以是红外线、网络、以及其他可用来传输的媒体。Java Application 第 13 页Manager 会从网络上下载代表该 Application Suite 的 JAR 档,接着在手机上安裝此
38、MIDlet Suite,然后在手机开始执行该应用程序。2.6 本章小结:第二章介绍了 Java语言的特点、本程序的开发环境及其相关工具的原理和使用。第三章 程序结构、思想和相关技术3.1 本程序需要解决的主要技术问题1. 游戏程序是一项精度要求很高的程序系统,因为其代码利用率很高。一个实时运行的最终作品,每秒都会运行成千上万行程序,绘图事件、键盘事件都会以极高的频率在后台等待响应,若有丝毫的差别都将很容易导致程序在运行不久后可能出现严重错误,甚至死循环。因此,其逻辑设计应当相当严谨,需将所有可能发生的事件及意外情况考虑在设计中。2. 游戏中为了美观,适用性强,可能需要采用外部文件引入的图片贴
39、图,有关贴图,在 MIDP2.0中提供了用于增强游戏功能的 game包,使得解决静态或动态、画面背景、屏幕刷新的双缓冲等都有较好的解决方案。3. 玩家飞机的运行可以通过键盘响应事件控制,运行算法也要进行相关的设置,已免游戏过于简单。4. 游戏的地图不可能通过绘图来解决。否则,不仅难于控制和处理过多的元素,也会因过多的大型图片而不能限制程序的大小,失去手机上程序的原则和 Java的优势。5. Java是基于虚拟机的半解释型编译系统,其执行效率较 C+等完全编译后的程序会低很多,程序如果不进行精简和优化,将可能导致运行的不流畅。除开发过程中对结构上的控制、变量的使用、算法的优化等优化外,还可以使用
40、混淆器(Obfuscator)进行程序打包后的优化。6. 游戏的结束、开始、动态信息画面作为构成一个程序都是必不可少的重要部分。良好的用户界面更是吸引用户的硬指标,相关的美术构图和人性化设置也需要有一定的考虑。第 14 页以上相关技术细节和整体流程将分别在以下小节阐述。3.2 程序流程MIDlet suite是 MIDP应用程序的最小单位,JAM 负责将手机内的 MIDlet suite以图形化的方式呈现,让用户能够选取欲执行的 MIDlet suite,一旦选取了某个 MIDlet suite,操作系统就会激活 KVM执行里面的 MIDlet。MIDlet 及相关的支持类组成了 MIDP应用
41、程序的实际内容。而每个 MIDlet都必须继承 javax.microedition.midlet.MIDlet这个抽象类。在 MIDP规范中定义了 MIDlet的生命周期,以及可以存在的三种状态,包括Paused、Active 以及 Destroyed,每一个 MIDlet在任何时刻只可能处于其中的一个状态。这三种状态的转换关系如图 3-1所示:MIDlet 有三个状态,分别是 pause、active 和destroyed。在启动一个 MIDlet的时候,应用管理软件会首先创建一个 MIDlet实例并使得他处于 pause状态,当 startApp()方法被调用的时候 MIDlet进入 a
42、ctive状态,也就是所说的运行状态。在 active状态调用 destroyApp(boolean unconditional)或者pauseApp()方法可以使得 MIDlet进入 destroyed或者 pause状态。值得一提的是destroyApp(boolean unconditional)方法,事实上,当 destroyApp()方法被调用的时候,AMS通知 MIDlet进入 destroyed状态。在 destroyed状态的 MIDlet必须释放了所有的资源,并且保存了数据。如果 unconditional为 false的时候,MIDlet 可以在接到通知后抛出 MIDlet
43、StateChangeException而保持在当前状态,如果设置为 true的话,则必须立即进入 destroyed状态。本程序采用面向对象的设计模式,对游戏中的所有物体赋予对象的概念和属性。运行程序后允许用户选择执行选项菜单,在开始游戏后将先从外部文件载入地图文件,对消减状态(Destroyed)停止状态(Paused)运行状态(Active)StartApp()DestroyApp()呼叫 MIDlet的构造函数DestroyApp()PauseApp()图 3-1 MIDlet的流程第 15 页背景的所有物体进行绘图。在主程序运行的线程中,画面刷新将以一定的频率采用双缓冲技术对屏幕重绘
44、,实时反映整个游戏的进行状态。游戏开始后先绘制地图,并将各个对象实例化。在主程序运行的线程中,游戏中所有的对象都应该运行在同一个线程下。在屏幕重绘的主程序中,将在每次的循环中判断若干事件,以便程序进入相关的分支执行相关的反应代码。程序为需要完成独立功能的模块设置了单独的类。lzhhdm 类继承自Midlet,gameScrenn 类、MenuScreen 类继承自 GameCanvas,mybullets 继承自 Sprite类。载入程序后首先启动的是程序介绍的信息画面。点击 ok后调用 MenuScreen类实现菜单。如果选择进入游戏,则调用 gameScreen类,并且中止 MenuScr
45、een类中的线程运行,已提高运行速度。3.3 Canvas 类为了能有程序开发人员控制接口的外观和行为,需要使用大量的初级用户接口类,尤其在游戏程序中,几乎完全依赖的就是 Canvas抽象类进行绘图。从程序开发的观点看,Canvas类可与高级 Screen类交互,程序可在需要时在 Canvas中掺入高级类的组件。Canvas提供了键盘事件、指点杆事件(如果设备支持),并定义了允许将键盘按键映射为游戏控制键的函数。键盘事件由键代码指定,但这样控制游戏会导致缺乏通用性,并不是每个设备的键盘布局都适合游戏的操作。应当将键代码转换为游戏键的代码,以便硬件开发商能定义他们自己的游戏键布局。3.4 Gra
46、phics 类Graphics类提供了简单的 2D绘图功能。它具有 24位深度色彩的绘制能力,以三原色分别各占一个字节表示其颜色。程序只能在 paint()函数中使用 Graphics绘制,GameCanvas可调用 getGraphics()函数直接绘制在缓冲区上,可以在任何时间请求传输到前台。其对象会被传给 Canvas的 paint()函数,以便最终显示。3.5 MIDP1.0 技术下的绘制背景技术在没有 MIDP2.0前,进行游戏绘图一般需要手动编程使用双缓冲。需要在 paint()方法内将所想要画的图形画在一张预先准备好的背景上,等所有绘图操作都完成后再将背景的数据拷贝到实际的屏幕上
47、。Image 类提供了一个建立背景的静态方法createImage(int width, int height),再利用 getGraphics()方法取得属于这个背景的Graphics对象,所进行的绘图操作都会作用在背景上,等到全部的绘图操作完成后,再第 16 页调用 drawImage()方法将背景的数据复制到实际显示的屏幕上。这样的技术在绘制动画时特别有用。绘制动画时经常需要不断地更新画面,而更新画面的操作就是先将屏幕以 fillRect()的方式清除,再将下一张图片画在屏幕上,然而反复的清除及重绘会造成屏幕的闪烁现象(flicker),因此使用双重缓冲的好处就是在背景进行这个清除及重绘
48、的操作,再将完成的绘图拷贝到屏幕上,由于用户看不到清除的操作,因此就不会出现闪烁的现象了。不过在某些 MIDP的实现上已经加上了双重缓冲的支持,因此在处理前应先利用 Canvas类的 isDoubleBuffer()方法来判断。3.6 MIDP2.0 新增的 GameCanvas 包J2ME的流行促进几个运营商和制造商开发了一些支持游戏的类,但是,这却造成了游戏缺乏可移植性的问题,例如,很难将使用 Siemens的 Sprite类的游戏移植到 Nokia上。在 MIDP2.0版本发布后,这些游戏移植性问题初步得到了解决。MIDP2.0 新加入了GameCanvas、Sprite、Layer、L
49、ayerManager、TiledLayer 五个与游戏开发相关的类。其中 Layer 类一般不会直接用到。Game类的出现不仅降低了错误出现的几率,也使游戏代码变的更小,因为开发者不需要自己编写象 Sprite这种例子。下面将简要介绍 Game类。GameCanvas类继承自 Canvas,所以具有 Canvas所具有的功能,还额外增加了一些便于游戏设计的功能。比如: GameCanvas类直接提供了 getKeyStates(),使程序员可以在同一个线程自己侦测按键的状态。GameCanvas 类提供了 flushGraphics()的功能,实现了双缓冲技术。所谓的 Sprite,就是画面上独立移动的图形。Sprite类是继承自 Layer的用于存储多桢的基本可视元素。不同的 frame可交相显示,构成动态的效果。图片可翻转、颠倒、由一个主角图片就可以方便的得到所有方向的显示状态,相比原先只能使用 Canvas绘图,需要将所有方向的主角图象都绘制在 png图象中简化了许多。Sprite 也可以从整合的图象中读图,读图时将把大图分解为若干等宽等高的小图。每个小图按照其排列顺序有相应的序号,在程序中调用其序号,就可以绘制出相应的图片。本程序中的双方飞机、子弹、白云都由 Sprite继承得到。LayerManag