毕业论文-基于android系统的中国象棋手机游戏设计_第1页
毕业论文-基于android系统的中国象棋手机游戏设计_第2页
毕业论文-基于android系统的中国象棋手机游戏设计_第3页
毕业论文-基于android系统的中国象棋手机游戏设计_第4页
毕业论文-基于android系统的中国象棋手机游戏设计_第5页
已阅读5页,还剩35页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

JIANGXINORMALUNIVERSITY学士学位论文THESISOFBACHELOR(20062010年)基于ANDROID操作系统的中国象棋手机游戏CHINESECHESSAPPLICATIONBASEDONANDROIDMOBILEOS指导老师曹中_华姓名刘盛_旗学号0667110121学院软件学院专业软件工程摘要CNCHESS是运行在ANDROID平台上的一款支持双人联网对局、即时聊天、对弈记录的休闲棋牌类手机游戏。系统采用面向对象的编程思想进行构思与分析设计;使用UML构建软件模型;使用MVC架构模式实现系统的整体架构及各模块之间的接口设计;在系统的实践过程中还采用了部分GOF的设计模式进行编码与开发。本文详细系统地阐述了在ANDROID平台上,应用MVC分层架构模式及面向对象的软件开发思想对CNCHESS游戏系统的分析、设计及实现过程。在项目的实践过程中,主要用到了以下技术手机布局主要使用了XML设计,程序及其子模块的生命周期管理用到了ACTIVITY流程控制,数据储存方面使用的是轻量级数据库SQLITE、网络通讯部分使用的是XMPP即时通讯协议进行数据的传输、对弈的画面更新使用的是手机的2D图形编程。本论文的前半部分将简要介绍系统相关的行业信息及基础的技术知识,后半部分将对本人在系统各模块中所使用的关键技术的实现进行了全面的介绍。关键词联网对弈;中国象棋;手机游戏;ANDROID平台ABSTRACTCNCHESSISACHINESECHESSGAMETHATRUNNINGONTHEANDROIDPLATFORMITSUPPORTMANYOFTHEFEATURESSUCHASPLAYINGGAMESTHROUGHTHENETWORK,REALTIMECHAT,ANDPLAYCHESSRECORDSOFCASUALMOBILEGAMESTHECNCHESSGAMEISOBJECTORIENTEDPROGRAMMINGDESIGNANDANALYSISOFTHEIDEAOFTHINKINGBUILDSOFTWAREMODELSUSINGUMLUSEOFMVCARCHITECTUREPATTERNSTOACHIEVETHEOVERALLSYSTEMANDTHEINTERFACEBETWEENTHEMODULEDESIGNSINPRACTICETHESYSTEMALSOUSESSOMEOFTHEGOFSDESIGNPATTERNSTOCODINGANDDEVELOPMENTTHISPAPERSYSTEMATICALLYEXPOUNDEDINTHEANDROIDPLATFORM,THEAPPLICATIONOFMVCPATTERNANDHIERARCHICALSTRUCTUREOFOBJECTORIENTEDSOFTWAREDEVELOPMENTTHOUGHTSCNCHESSGAMESYSTEMANALYSIS,DESIGNANDIMPLEMENTATIONPROCESSPRACTICEINTHECOURSEOFTHEPROJECT,MAINLYUSEDINTHEFOLLOWINGTECHNOLOGIESCELLPHONESPRIMARILYUSEXMLLAYOUTDESIGN,PROCESSANDLIFECYCLEMANAGEMENTSUBMODULEUSESTHEACTIVITYPROCESSCONTROL,DATASTORAGEAREASUSINGALIGHTWEIGHTDATABASESQLITE,NETWROKCOMMUNICATIONSOMEUSETHEXMPPINSTANTMESSAGINGPROTOCOLFORDATATRANSMISSION,PUBLICDEBATEOFTHEFRAMEUSINGAMOBILEPHONE2DGRAPHICSPROGRAMMINGTHEFIRSTPARTOFTHISPAPERWILLBRIEFLYINTRODUCETHESYSTEMBASEDONRELEVANTINDUSTRYINFORMATIONANDTECHNICALKNOWLEDGE,THELATTERPARTOFEACHMODULEINTHESYSTEMIWILLBEINTHEKEYTECHNOLOGYUSEDINTHEREALIZATIONOFACOMPREHENSIVEINTRODUCTIONKEYWORDSNETWORKOFGAMESCHINESECHESSMOBILEGAMESANDROIDPLATFORM目录第1章绪论111问题的提出112相关研究综述1121ANDROID手机操作系统的发展历程1122国内外关于ANDROID手机应用程序的研究及开发现状213研究目标与内容2131研究目标2132研究主要内容2第2章ANDROID程序设计相关技术概述421XUL界面布局422ANDROID的ACTIVITY组件423SQLITE数据库524XMPP协议525ANDROID2D图形编程526MVC模式简介5第3章系统的分析与实现731系统分析7311系统功能分析7312系统流程分析8313系统数据流分析932系统数据库设计9321系统ER图9322数据库表设计1033面向对象的系统设计10331系统文件组织结构10331用例的设计11332类的设计12333系统交互模式的设计12第4章模块的实现1541MVC分层结构1642总体控制模块1743数据存储模块1844数据传输模块2045对局模块2246XML界面布局模块2447系统中关键技术的应用及实现24471SQLITE3的应用24472XML界面设计25473CNCHESS的2D图像编程25474对弈过程中双方棋盘上棋子的同步27475XMPP数据传输27476走棋规则的判断28第5章结束语3051后续研究展望30参考文献31致谢32第1章绪论11问题的提出随着3G移动网络应用的推广,手机游戏的规模、复杂程度日益增强;其技术手段、设计思想、系统体系结构都发生了深刻的变化。手机操作系统正朝着高处理能力、多功能、智能化的方向发展。近年来,网络文化市场发展很快,随着互联网的迅速普及、宽带的接入社区和家庭,我国网络游戏市场发展迅速并进入了一个高速增长期,并已经创造了较大的产值,带动了相关产业的发展。如今网络上的提供免费中国象棋游戏,大多数是单机版的,界面单一,功能单一。本系统将实现在网络上对战的中国象棋功能;还对在下棋界面美化,以及下棋中可能出现的意外进行了处理。这样中国象棋休闲游戏将不在是一个功能单一界面枯燥的游戏,而是一个较完善的休闲游戏。在国内外ANDROID手机应用开发如火如荼、日益盛行的大背景下,本人决定开发一款界面友好、操作简单,支持双人联网对局、数据记录、智能规则判断的手机休闲游戏。12相关研究综述近年来,国内外的专家学者以及一线的开发人员从理论、方法、技术等不同的角度对ANDROID手机操作系统进行了一定的研究。本小节将从ANDROID手机操作系统的发展历程、研究现状、程序开发设计简介四个方面分析总结国内外的相关研究结果。121ANDROID手机操作系统的发展历程ANDROID是GOOGLE于2007年11月5日宣布的基于LINUX平台开源手机操作系统名称,该平台由操作系统、中间件、用户界面和应用软件组成,号称是首个为移动终端打造的真正开放和完整的移动软件。表11ANDROID手机操作系统的发展阶段发展阶段阶段特征2007115ANDROID平台发布2008922TMOBILE2009年1季度G1销售100万台20093MWC华为发布ANDROID手机,MOTO,三星,LG计划2009年下半年推出ANDROID手机2009获得ORANGE,VODAFONE,O2,TELEFONICA支持2009进军上网本122国内外关于ANDROID手机应用程序的研究及开发现状ANDROID是基于LINUX内核的软件平台和操作系统,早期由GOOGLE开发,后由开放手机联盟OPENHANDSETALLIANCE)开发。它采用了软件堆层(SOFTWARESTACK,又名以软件叠层)的架构,主要分为三部分。低层以LINUX内核工作为基础,只提供基本功能;其他的应用软件则由各公司自行开发,以JAVA作为编写程序的一部分。另外,为了推广此技术,GOOGLE和其它几十个手机公司建立了开放手机联盟。ANDROID在未公开之前常被传闻为GOOGLE电话或GPHONE。大多传闻认为GOOGLE开发的是自己的手机电话产品,而不是一套软件平台。2010年1月,GOOGLE开始发表自家品牌手机电话的NEXUSONE,目前最好的是ANDROID21。13研究目标与内容131研究目标本项目主要研究的目标分为程序设计思想实践改进目标、ANDROID平台手机开发技术的研究目标以及对XMPP网络传输协议的使用与研究目标。(1)运用面向对象的编程思想及RUP统一过程,对CNCHESS中国象棋手机游戏的系统结构、过程、功能等要素进行可视化的描述,为ANDROID程序设计的可视化提供方法、技术上的支持,为系统的理论模型和软件建模提供参照。(2)本系统中使用了多种基于ANDROID平台的软件开发技术,根据要实现的系统功能,系统需要使用到的技术及技术研究的目标主要有手机游戏用户界面的人性化、个性化界面布局,给用户以良好的游戏体验;移动设备上的图形编程,提供流畅靓丽的游戏过程界面;使用文件、SQLITE等数据存储方式,提供游戏配置保存,游戏过程保存、游戏过程回放、游戏结果记录等功能,方便用户查看;(3)使用XMPP即时通讯协议传输数据,提供即时聊天的以及在线探测的功能,实现游戏的实时性。132研究主要内容项目研究的内容主要有以下四大块第一部分是手机游戏的界面设计和背景音效的设计。和PC上的游戏开发有些许不同,手机游戏更加的注重用户体验,一个人性化的、时尚靓丽的游戏界面和优美个性化的音效设计是一个成功的手机游戏要达到的基本要求。第二部分是手机之间的通信模块设计。3G时代,手机通信受流量的限制很大,所以必须尽可能的使用简洁的通信协议,减少数据的流量,减少用户的通讯资费;再者,双人对局这样的在线游戏,必须体现其即时性,在一方因为电话打入或其他原因导致游戏挂起或掉线时,另一方能及时得知道对方的状态,以便做出处理。另外,为了增加游戏的互动性,项目提供了即时聊天的功能。第三部分是对局智能程序的设计。在没有朋友在线的情况下,可以和设计好的AI(ARTIFICIALINTELLIGENCE)算法进行游戏。人工智能程序设计是一项对算法要求很高的程序设计,特别是在手机这种硬件资源紧缺的环境中,更是需要一个高效的算法来提供强大的AI对局支持。第四部分是逻辑控制模块的设计。当有紧急事件(如电话打入,电池没电等)发生时,需全局模块对当前的游戏状态进行保存或退出等处理,并发送相关信息给对局的伙伴;用户通过触摸屏进行走棋,棋子的走动规则由软件进行智能规则判断;对局结束,软件将对对局的过程及结果使用与国际接轨的棋谱记录格式(PGN,FEN)进行记录,在对局结束后,用户可用软件读入PGN格式的对局过程文件,进行战局的回放。软件采用面向对象的编程思想进行构思设计,使用UML设计软件的模型,采用了部分GOF的设计模式进行编码与开发。第2章ANDROID程序设计相关技术概述ANDROID作为一个移动设备的平台,其软件层次结构包括了一个操作系统(OS),中间件(MIDDLEWARE)和应用程序(APPLICATION)。根据ANDROID的软件框图,其软件层次结构自下而上分为以下几个层次图21ANDROID系统架构21XUL界面布局XUL是一种基于XML的语言,因此需要对XML(特别是XML名称空间)很熟悉。XUL是英文“XMLUSERINTERFACELANGUAGE”的首字母缩写。顾名思义,它是一种应用XML来描述使用者界面的标示语言。22ANDROID的ACTIVITY组件ACTIVITY,一般代表手机屏幕的一屏,相当于浏览器的一个页面。在ACTIVITY中添加VIEW,实现应用界面和用户交互。一个应用程序一般由多个ACTIVITY构成,这些ACTIVITY之间可互相跳转,可进行页面间的数据传递。每个ACTIVITY都有自己的生命周期。23SQLITE数据库在ANDROID平台上,集成了一个嵌入式关系型数据库SQLITE。SQLITE是支持结构化查询的轻量级数据库,能很好得适应于移动设备的应用。ANDROID提供了一个名为SQLITEDATABASE的类,该类封装了一些操作数据库的API,使用该类可以完成对数据进行添加CREATE、查询RETRIEVE、更新UPDATE和删除DELETE操作这些操作简称为CRUD。24XMPP协议1什么是XMPPXMPP(可扩展消息处理现场协议)的前身是JABBER,一个开源形式组织产生的网络即时通信协议。具有即时信息传输以及在线现场探测的功能。2XMPP的基本网络结构XMPP中定义了三个角色,客户端,服务器,网关。通信能够在这三者的任意两个之间双向发生。服务器同时承担了客户端信息记录,连接管理和信息的路由功能。网关承担着与异构即时通信系统的互联互通,异构系统可以包括SMS(短信),MSN,ICQ等。基本的网络形式是单客户端通过TCP/IP连接到单服务器,然后在之上传输XML。3XMPP通过TCP传输的数据XMPP传输的即时通讯指令的逻辑与以往相仿,只是协议的形式变成了XML格式的纯文本。XMPP的核心部分就是一个在网络上分片断发送XML的流协议,这个流协议是XMPP的即时通讯指令的传递基础。25ANDROID2D图形编程1、SIMPLEGRAPHICSINVIEW就是直接使用ANDROID已经实现的一些画图操作,比如说IMAGES,SHAPES,COLORS,PREDEFINEDANIMATION等等。这种方式只能画静态或者极为简单的2D图画,对于实时性很强的动画,高品质的游戏都是没法实现的。2、CANVAS首先我们要明白这个CANVAS是一个2D的概念,是在SKIA中定义的。也就是说在这个方式下还是说的画2D图形。26MVC模式简介整个系统采用了MVC模式进行设计。MVC模式是一种流行的软件设计模式,它把系统分为3个模块模型(MODEL)、视图(VIEW)和控制器(CONTROLLER)。各个模块的功能说明参见表21表21MVC的三个模块MVC模块描述模型代表应用程序状态和业务逻辑视图提供可交互界面,向客户显示模型数据控制器响应客户的请求,根据客户的请求来操纵模型,并把模型的响应结果经由视图展现给客户各个模块之间的相互作用如图22所示。采用MVC模式有很多好处一是能将显示、逻辑和数据分开,某一方面的改变不会影响另一方面;其次是可以在不更改视图显示的情况下,更改控制器,以达到更改视图与用户交互的响应模式的目的。图22MVC模型图第3章系统的分析与实现游戏对用户界面的要求较高,需达到人性化美观大方、便于操作,个性化游戏界面时尚靓丽、别具一格,最好能做到自定义皮肤之类的。本游戏是使用即时通讯协议进行通信的,所以,实时的游戏效果、即时聊天以及在线探测是必须做到用户体验良好的。数据存储方面,需存储游戏的配置信息、对局的胜负信息、对局的过程信息。31系统分析本系统的定位是CNCHESS中国象棋手机游戏是运行在ANDROID开源手机操作系统平台上的支持双人联网对战的一款手机游戏。由于对国际国内3G移动应用的前景看好,另外也对游戏开发有很大的兴趣,决定开发一款基于ANDROID手机操作系统的中国象棋手机游戏。结合当前移动开发的形式,初步构想之后,定下“基于ANDROID手机操作系统的中国象棋游戏应用”应该是这样一款休闲游戏以3G方式连入互联网;支持双人之间的游戏互动;支持即使聊天以及在线探测;支持游戏过程记录及回放;支持人机对战;游戏界面布局人性化、个性化;支持紧急事件处理(如电话打入、电池没电等)。可能的话,进行WIFI编程,实现“局域网”对局。311系统功能分析本系统的基本功能主要有三大块即时聊天方便玩家的交流学习;象棋对弈游戏的联网互动以及即时性,是本程序与一般的象棋游戏的不同;战绩统计用于统计玩家的对弈胜负情况。详细的系统功能分析图如图31所示。图31CNCHESS系统功能结构图本系统的执行流程较简单,进入系统后有五个选项联网对局;XMPP设置;查看胜负情况;查看开发者信息及用户帮助信息;退出游戏。在联网对局前,XMPP连接设置必须是已经配置好的,否则无法连接JABBER服务器,不能进入对局界面。系统主要的输入输出及模块间的调用情况用IPO图表示如图32图32CNCHESSIPO图(输入一处理一输出图)312系统流程分析系统流程分析是软件工程图表(例如流程图、判定表等)辅以必要的说明来表示本程序的逻辑流程。本系统采用XMPP协议进行网络的连接、数据的交换。站在用户的角度来看,用户之间的信息交流是端对端的;但是站在程序设计开发者的角度来看,数据其实是要经过JABBER服务器的。从设计开发者的角度描述系统的数据交互模式,如图33。用户系统JABBER服务器输入信息显示信息发送信息接收信息互联网图33系统交互模式图313系统数据流分析CNCHESS手机游戏系统需要储存的主要数据有XMPP网络连接的配置信息以及走棋的胜负信息。系统的数据流图如图34所示。启动游戏开始游戏游戏设置查看战绩系统开发信息及帮助文件退出游戏用户输入网络连接配置表配置信息对局胜负信息对局产生的胜负信息查询到的胜负信息XMPP连接配置信息退出系统确认退出信息需要保存的信息退出指令图34系统数据流图32系统数据库设计321系统ER图系统使用SQLITE轻量级数据库进行数据的储存和管理。用户可根据自己的需要进行XMPP网络连接的配置以及胜负情况的查看和清空。系统的ER图如图35所示。图35系统ER图322数据库表设计本程序采用轻量级数据库SQLITE存储管理数据,数据库名称为DATASDB。DATASDB数据库含有两张表,两张表的名称以及字段属性等定义如下SCORETABLE(ID,WINNING,FALLING,PEACE),对局得分表主要用来储存对局的胜负信息;SETTINGSTABLE(ID,HOST,PORT,SERVICE,PARTNERED,USERID,USERPWD),网络连接配置表主要用来储存XMPP网络连接配置。33面向对象的系统设计本系统使用面向对象的开发思想、UML建模方法、MVC三层架构、GOF的部分设计模式编码设计开发,便于后续的软件扩展。下面将从系统文件组织结构,系统用例图,系统类图以及系统三个角度对系统进行设计方面的说明。331系统文件组织结构一个ANDROID程序由ANDROIDLIBRARY、SRC、REFERENCEDLIBRARIES、RES、ANDROIDMANIFESTXML组成。其中ANDROIDLIBRARY为ANDROID系统类库,SRC内为程序员的代码包,RESERENCEDLIBRARIES为第三方开发包,RES为程序所要用到的资源(如图片,音视频文档,界面布局XML文档等)存放的文件夹,ANDROIDMANIFESTXML为程序的主配置声明及版本说明文件。本系统的简要文件组织结构如图36所示。图36项目文件组织结构331用例的设计系统的用例主要有三大类游戏逻辑及流程控制类,走棋及聊天类,网络连接类。以下为系统的详细用例图,各用例作用范围及相互间的关系如图37所示。图37系统用例图332类的设计根据系统用例图,站在类的功能角度进行分析设计,CNCHESS程序的类主要分以下五种界面显示类、逻辑及流程控制类、数据管理类、网络连接类、对弈控制类。各种类的JAVA类主要功能说明如下界面显示类主要用来实现游戏的UI界面布局以及屏幕的刷新等功能,如SETTINGSDIALOG、VIEWSCORE、CHATDIALOG等类;数据管理类为保持数据的安全性、完整性及一致性,所有的类必须通过数据管理类进行数据的存取,如SETTINGSMANAGER、DATAMANAGER等类;逻辑及流程控制类主要负责协调各模块之间的调用及流程的跳转,传递模块之间的信息等功能,如CNCHESS、STARTGAME等类;网络连接类用于连接网络,对需要发送的数据进行加密解密,发送数据,状态监听,数据接收等功能,如CONNECTDIAL、OGXMPPCLIENT等类;对弈控制类主要为对弈过程中各面向对象的抽象模型,也进行必要的数据处理,如BOARDVIEW、UMPIRE等类。333系统交互模式的设计序列图主要用于按照交互发生的一系列顺序,显示对象之间的这些交互。序列图的主要用途之一,是把用例表达的需求,转化为进一步、更加正式层次的精细表达10。用例常常被细化为一个或者更多的序列图。序列图除了在设计新系统方面的用途外,它们还能用来记录一个存在系统(称它为“遗产”)的对象现在如何交互。当把这个系统移交给另一个人或组织时,这个文档很有用。用例VIEWSCORE的顺序图简要的说明了用户是如何与SQLITE数据库进行交互,看到自己的战绩这一事件的一、用户按下查看战绩的按钮(VIEWSCORE),系统得知这一指令,发出数据请求给SQLITE管理类,数据库管理类查询到数据后,将数据返回给系统查看类,系统查看类将战绩数据显示在手机屏幕上;二、用户发出清除战绩请求,逻辑控制类将这一请求信息发送给SQLITE管理类,管理类清除数据后,将结构返回给逻辑控制类,逻辑控制类发送屏幕更新指令,用户看到屏幕显示数据已更新。USERVIEWSCOREWINDOWSSQLITEDATBASEVIEWSCOREQUERYSCOREDATSCOREDATCLEARSCORERESETHESCOREDAT图38VIEWSCORE用例的顺序图网络连接设置用例SETTING的顺序图一、用户发出查看连接配置请求,SETTINGSDIALOG显示类请求数据库管理类去数据库读取数据,数据库管理类读取到数据后,将数据返回给显示类,显示类显示用户请求的配置信息;二、用户输入新的XMPP网络连接配置信息,SETTINGSDIALOG显示类请求添加或者更新网络配置信息,SQLITE管理类获知更新请求后更新数据库。USERSETINGSDIALOGWINDOWSSQLITEDATBASEVIEWSETINGSQUERYSETINGSDATSETINGSDATINPUTSETINGSUPDATESETINGSDAT图39SETTING用例的顺序图游戏对局用例STARTGAME涉及到相关的类较多,如图310所示一、用户按下开始游戏键,系统提示是否要联网游戏,用户确认“是”后,系统读取XMPP配置信息建立手机到服务器端的网络连接;若用户确认“否”,则系统退回到游戏主界面(此时系统未连上互联网);二、用户选择聊天菜单,STARTGAME进行相应的逻辑处理,启动聊天对话框;用户输入聊天信息,按下发送按钮,消息发送到对方的服务器帐号,与此同时,在用户自己的聊天记录单里面显示;三、用户进行走动棋子或者悔棋等请求信息,STARTGAME接收到按键事件或者触摸屏事件后,将相应的信息转交XMPPCLIENT进行信息的发送;XMPPCLIENT还负责客户端监听,当有对方有走棋等信息发送过来时,XMPPCLIENT将分辨是否为CNCHESS程序格式的信息并进行解码解包之后将信息转交给STARTGAME,STARTGAME对转交过来的信息进行处理。USERCONECTOSERVERWINDOWSTARTGAMEWINDOWSQLITEDATBASECHATDIALOGWINDOWPRESSTARTGAMEBUTONCONFIRMTOSTARTYES,TARTREADSETINGSINFORMATIONSETINGSINFOSETINGSINFOENTERCHATMESAGECHATMESAGEXMPCLIENTCHATMESAGERECIVEDMESAGERECIVEDMESAGEMOVECHESCHESMOVEINFORMATIONCHESMOVEINFORMATIONREQUESTREQUESTINFORMATIONANSWERINFORMATION图310STARTGAME用例的顺序图第4章模块的实现需求分析阶段回答了目标软件系统“要做什么”的问题,而软件设计阶段则需要回答目标软件系统“要怎么做”以实现用户需求的问题12。在CNCHESS手机游戏系统的软件设计建模阶段,主要是以需求分析阶段的成果(需求分析模型)作为输入,进行系统的体系结构设计、类的详细设计和用例实现设计。总体来说,CNCHESS系统的软件设计建模阶段是对分析建模结果的进一步精化和调整。图41CNCHESS的项目开发流程项目要实现的模块主要有四部分。第一部分是手机游戏的界面设计和背景音效的设计。和PC上的游戏开发有些许不同,手机游戏更加的注重用户体验,一个人性化的、时尚靓丽的游戏界面和优美个性化的音效设计是一个成功的手机游戏要达到的基本要求。第二部分是手机之间的通信模块设计。3G时代,手机通信受流量的限制很大,所以必须尽可能的使用简洁的通信协议,减少数据的流量,减少用户的通讯资费;再者,双人对局这样的在线游戏,必须体现其即时性,在一方因为电话打入或其他原因导致游戏挂起或掉线时,另一方能及时得知道对方的状态,以便做出处理。另外,为了增加游戏的互动性,项目提供了即时聊天的功能。第三部分是对局智能程序的设计。在没有朋友在线的情况下,可以和设计好的AI(ARTIFICIALINTELLIGENCE)算法进行游戏。人工智能程序设计是一项对算法要求很高的程序设计,特别是在手机这种硬件资源紧缺的环境中,更是需要一个高效的算法来提供强大的AI对局支持。第四部分是逻辑控制模块的设计。当有紧急事件(如电话打入,电池没电等)发生时,需全局模块对当前的游戏状态进行保存或退出等处理,并发送相关信息给对局的伙伴;用户通过触摸屏进行走棋,棋子的走动规则由软件进行智能规则判断;对局结束,软件将对对局的过程及结果使用与国际接轨的棋谱记录格式(PGN,FEN)进行记录,在对局结束后,用户可用软件读入PGN格式的对局过程文件,进行战局的回放。软件采用面向对象的编程思想进行构思设计,使用UML设计软件的模型,采用了部分GOF的设计模式进行编码与开发。41MVC分层结构在CNCHESS系统的设计建模阶段,是回答如何实现系统功能的问题,主要完成软件体系结构设计和详细设计两个方面的工作。软件体系结构设计是高级设计,主要包括以下步骤(1)体系结构的层次划分。(2)体系结构的子系统划分。(3)建立三层体系结构与类之间的映射关系。详细设计中首先要详细描述每一个类,包括类的属性、操作、类之间的关系,同时对系统用例进行设计。详细设计包括如下内容(1)设计实体类的属性和操作。(2)设计边界类的功能组成和操作。(3)设计类之间的关系。(4)构造设计类图模型。(5)借助交互图实现用例设计。(6)数据模型的设计。(7)实现模型的设计。(8)设计建模的评审。本系统使用MVC设计模式13进行体系的基础架构,如图42所示模型(M)XMPPCLIENT、UMPIRE、MANAGER类视图(V)DIALOG、VIEW类控制器(C)CNCHESS、STARTGAME类客户根据客户的请求来操纵模型数据查询通知数据变化客户请求控制视图显示客户请求数据请求响应图42CNCHESS的MVC三层架构ANDROID应用程序的一般架构为VIEWSCONTENTPROVIDERSRESOURCEMANAGERNOTIFICATIONMANAGERACTIVITYMANAGER,你可以选择其中的若干项作为你应用的架构元素。系统的项目文件组织结构如图43所示,其中源代码包中的VIEW类和DIALOG类以及RES资源文件夹中的所有XML文件,充当视图的角色,负责手机界面的显示和与用户的交互;CNCHESS,STARTGAME两个类充当“”的角色,重要控制程序界面的切换和信息的分发;BOARDVIEW,UMPIRE,XMPPCLIENT分别是棋盘类、裁判类、信息收发类,充当模型的角色,分别负责棋盘模型的显示与更新、裁判对象模型的建立、即时信息通信模型的建立;DATAMANAGER,SETTINGSMANAGER两个类负责与SQLITE数据库的沟通,分别负责战绩胜负次数、XMPP联接设置的数据存取。图43CNCHESS的文件组织结构42总体控制模块软件体系结构是软件在设计构成上基本的、可供设计选择的形态和总体结构,本质上,它是对软件需求的一种抽象解决方案。在引入了体系结构的软件开发之后,CNCHESS中国象棋手机游戏系统的构造过程变为“问题定义软件需求软件体系结构设计软件详细设计软件实现”。本系统的总体控制模块主要有CNCHESS以及STARTGAME。CNCHESS用于控制各子模块(ACTIVITY)的启动、休眠以及消亡;例如,当用户按下“开始游戏”按钮时,STARTGAME内置的监听器STARTGAMESETONCLICKLISTENER将获取ONCLICK事件并调用SHOWSTARTGAME函数,启动对弈相关的模块。STARTGAME属于对局子模块,用于协调对局过程中对各中系统信息进行逻辑判断、消息分发,控制、调用、协调各二级子模块的运行。依据上一阶段中UML设计出来的模型及相关的文档,对系统的各类进行细化后,得出系统各模块的类以及各类之间的相互关联关系。下面将详细介绍各类模块作用以及类之间的相互关联性。关于总体流程控制类CNCHESS,如图44所示,各类相关作用简介如下负责启动游戏,控制协调各模块的运行;STARTGAME负责启动对局模块以及对局时候各对局子模块的相互协调;SETTINGSDIALOG负责游戏网络配置的UI显示以及数据获取、数据储存等;VIEWSCORE负责游戏胜负战绩的UI显示以及管理功能;COMPANYINFO负责游戏开发商信息的显示以及用户帮助文档的UI显示;EXITGAMEDIALOG负责结束游戏相关进程、线程,保存相关游戏数据,安全退出游戏。图44总体控制类及相关类的联系图图45对弈流程控制模块与网络通信模块联系图关于对弈流程控制类STARTGAME与通信模块的组织联系图,如图45所示。对弈流程控制主要作用为协调各对弈子模块的通信与调用。与对弈流程控制有关的模块有网络连接部分中建立连接以及数据发送接收的类,负责数据存取的MANAGER类,用于聊天的CHATDIALOG窗体类,走棋、棋盘同步更新模块的类、请求回复窗体类等。43数据存储模块数据存储模块有四个类,分为储存控制类和界面信息显示两种,说明如下类SETTINGSDIALOG、VIEWSCORE用来做用户UI界面输入设置等信息的获取和查看、清除对局胜负情况;类DATAMANAGER与SETTINGSMANAGER是数据管理类。下面就DATAMANAGER函数简要介绍一个数据管理类是怎样实现的1变量设置管理类中有属性为PRIVATE的变量,存取都必须通过函数内置的GET、SET函数进行;2判断表是否存在管理数据,必须先是有你需要管理的表,ISSCORETABLE函数通过系统API中的QUERY函数对系统表SYSOBJECT进行查询,若系统表中没有所要查找的对象,则需建立SCORETABLE表;3表的创建与删除、记录的添删修数据的存取都是通过系统API接口中的EXECSQL函数来完成的,例如当需要删除SCORETABLE这张表,语句为DBEXECSQLSQL,DB为所要操作的数据库的句柄,SQL为所要执行的语句。MANAGER的这两个类有些类似JAVABEAN,是为了保证数据的安全、完整、一致,其他类必须通过数据库MANAGER类才能与SQLITE数据库进行沟通,完成对数据的操作。实践编程难点在类UMPIRE、MANAGER,由分析设计的结果生成各模块的详细编码单元以及各类的模型。UMPIRE是裁判员类,主要用于判断棋子走动是否规则、对弈的胜负结果。系统源码包中,带MANAGER后缀的都是属于数据管理相关类。MANAGER类主要调用系统API如ANDROIDDATABASE或者ANDROIDDATABASESQLITE进行数据的存取。如图46所示,各类作用相关作用如下图46查看战绩、连接设置以及走棋模块的类图本程序采用轻量级数据库SQLITE3存储管理数据,数据库名称为DATASDB。DATASDB数据库含有两张表,SCORETABLE表用来储存对局的胜负信息,SETTINGSTABLE用来储存XMPP网络连接配置。表41SCORETABLE存储对局的胜负信息字段含义数据类型是否为空初始值ID记录的编号INT否0WINNING获胜次数INT否0FALLING失败次数INT否0PEACE平局次数INT否0表42SETTINGSTABLE存储XMPP的连接设置字段含义数据类型是否为空初始值ID(PK)记录的编号INT否0HOST服务器地址STRING否TALKGOOGLECOMPORT服务器端口INT否5222SERVICEJABBER服务提供商STRING否GMAILCOMPARTNERID对手GMAIL帐号STRING否EXAMPLEGMAILCOMUSERID用户GMAIL帐号STRING否EXAMPLE2GMAILCOMUSERPWD用户密码STRING是12345644数据传输模块数据传输模块有两个类,很多算法及技术难点都需要用到第三方开发包SMACKJAR中的XMPP组件及其API完成9,模块说明如下CONNECTDIALOG用来连接或者断开XMPP网络连接,当连接上服务器后,启动对局模块,进行游戏;XMPPCLITE接受STARTGAME模块转交过来的数据,在信息分类、格式化、加密后,发送给网络中的JABBER服务器;同时,监听服务器发送过来的CNCHESS格式化数据,解密、解包分类后转交给STARTGAME模块;另外,也监听对手的在线状态等信息,以便在发生突发情况时进行相应的处理,从而真正的达到即时游戏的效果。系统在进行联网对局前,必须对网络连接进行有效的配置。游戏的网络连接配置UI界面以及各配置项的说明如图47及表43所示,配置信息的数据存储流程图如图47所示。图47SETTINGSDIALOG对话框输入项游戏连接配置对话框各输入项的详细定义如表43所列。表43XMPP设置界面各项目详细定义标识名称数据类型数据值有效范围输入媒体安全保密条件USERID用户GMAIL帐号STRINGGMAILCOMSETTINGSDIALOGSQLITE限制访问PASSWORD用户密码STRINGSETTINGSDIALOGSQLITE限制访问、MD5加密PARTNERID对方GMAIL帐号STRINGGMAILCOMSETTINGSDIALOGSQLITE限制访问HOST提供IM服务的主机STRINGTALKGOOGLECOMSETTINGSDIALOGSQLITE限制访问PORT提供IM服务主机的端口号INT5222SETTINGSDIALOGSQLITE限制访问SERVICE所用的服务类型STRINGGMAILCOMSETTINGSDIALOGSQLITE限制访问系统使用SQLITE数据库,若无游戏配置信息或者配置信息无效,系统将提示进行正确的网络连接配置,并对正确的配置进行存储。配置信息的存储数据流程图如图48所示。用户XMPP设置处理SQLITE数据库输入数据存入数据查看数据读取数据图48XMPP网络连接设置数据流程图为保证用户手机之间数据传输中各类数据的区分,系统在数据发送前需对各类数据信息进行一定的格式化,待数据信息到达对方的手机后,系统再进行相应的解包。另外,为保证数据在网络间传输的安全性,在手机发送信息至互联网这一段使用了SMACKJAR类库中的加密函数。用户聊天对话框聊天信息的输入与显示处理XMPP客户端聊天信息的发送与接收处理格式化数据格式化数据互联网输入信息未格式化聊天信息解包后的聊天信息显示信息图49CHAT聊天模块数据流程图45对局模块对局模块是本系统设计编码中较复杂,内容比较多的一个模块。主要有以下子模块1STARTGAME用来启动对局、网络连接以及对各局子模块进行协调;2UMPIRE裁判类,定义走棋规则,用来控制走棋的顺序以及对弈双方的同步,判定对局的胜负;3ANSWERDIALOG回话类,回答对方的对局请求等信息;4CHATDIALOG对话聊天类,走棋的过程中,用来启动对话框以和对方进行即时聊天;5RESTOREPOINT用来记录游戏过程中的一定走棋记录,创建还原点,以方便悔棋时,棋盘上棋子的回滚;6COMPANYINFO用来显示开发商信息以及用户帮助信息的UI类;7ERRORDIALOG用来显示游戏过程中出现的错误信息;8EXITGAMEDIALOG用来结束游戏进程,包括游戏相关的各线程;9SMACKJAR第三方开发包,提供XMPP服务接口,数据加密等功能。对局模块主要处理的是用户之间对弈的过程同步、规则控制等信息。用户走棋,产生走棋信息,系统捕获到按键事件或者触摸屏事件后,会进行数据的分类以及格式化,然后加密发送到对手的手机中。在接收到对手发来的走棋信息时,系统则先通过SMACKJAR类库进行解密,然后解包,进行走棋信息的逻辑处理,最后通过界面显示类呈现于用户的手机屏幕。用户对局界面显示处理XMPP客户端聊天信息的发送与接收处理格式化数据格式化数据互联网走棋信息走棋数据对方棋子移动数据棋子移动信息对局数据逻辑处理走棋数据对方棋子移动数据图410走棋模块数据流程图对弈过程中,可打开聊天框与对手进行即时聊天。聊天框如图411所示。对局的棋盘界面以及菜单的设置显示如图412所示。图411CHATDIALOG对话框输入项图412STARTGAME对弈界面46XML界面布局模块CNCHESS系统使用XML进行游戏界面的基础布局1,主要有以下布局界面,各界面的布局内容以及与各JAVA类的映射关系为1ANSWERDIALOGBOXXML回复对话框的界面布局;2CHATDIALOGBOXXML聊天对话框的界面布局;3COMPANYINFOXML显示开发商信息以及用户帮助文件;4ERRORDIALOGXML错误信息提示框布局;5EXITGAMEXML退出游戏提示框;6MAINXML游戏主界面布局;7SETTINGSXML游戏XMPP连接配置界面布局;8STARTGAMEXML游戏对局界面布局;9SURE_CONNECTXML确认进行网络连接对话框布局;10TOCONFIRMXML确认回复对方请求的对话框布局;11VIEWSCOREXML查看战绩界面布局。图413为RES文件夹下LAYOUT(界面布局资源)的文件组织结构。图413XML界面布局文件47系统中关键技术的应用及实现471SQLITE3的应用SQLITE是集成在ANDROID平台上的嵌入式关系型数据库。它是一个支持结构化存储、查询轻量级开源数据库。SQLITE3支持的数据类型有NULL、INTEGER、REAL浮点数字、TEXT字符串文本和BLOB二进制对象数据类型,虽然它支持的类型虽然只有五种,但实际上SQLITE3也接受VARCHARN、CHARN、DECIMALP,S等数据类型,只不过在运算或保存时会转成对应的五种数据类型。在ANDROID系统,为我们提供了一个名为SQLITEOPENHELPER的类,该类用于对数据库版本进行管理,该类是一个抽象类,必须继承它才能使用。为了实现对数据库版本进行管理,SQLITEOPENHELPER类有两种重要的方法,分别是ONCREATESQLITEDATABASEDB和ONUPGRADESQLITEDATABASEDB,INTOLDVERSION,INTNEWVERSION。在项目的实现过程中DATAMANAGERJAVA和SETTINGSMANAGERJAVA两个类都是通过调用ANDROID的SQLITEOPENHELPER类对SQLITE数据库进行数据库以及其中的数据进行创建、修改和删除。472XML界面设计在本系统的软件设计开发过程中,XML的布局是最先开始的。ANDROID的界面1,需要写在RES/LAYOUT的XML里面,一般情况下一个XML对应一个界面。做ANDROID的界面有点像写HTML连注释代码的方式都一样,要先给ANDROID定框架,然后再在框架里面放控件,ANDROID提供了几种框架,ABSOLUTELAYOUT,LINEARLAYOUT,RELATIVELAYOUT,TABLELAYOUT,FRAMELAYOUT,FRAMELAYOUT里面只可以有一个控件,并且不能设计这个控件的位置,控件会放到左上角LINEARLAYOUT里面可以放多个控件,但是一行只能放一个控件TABLELAYOUT这个要和TABLEROW配合使用,很像HTML里面的TABLEABSOLUTELAYOUT里面可以放多个控件,并且可以自己定义控件的X,Y的位置RELATIVELAYOUT里面可以放多个控件,不过控件的位置都是相对位置界面的布局好像还可以直接引用一些VIEW,如SCROLLVIEW等框架的XML如下ANDROIDID“ID/WIDGET36“ANDROIDLAYOUT_WIDTH“FILL_PARENT“ANDROIDLAYOUT_HEIGHT“FILL_PARENT“上面代码中以ANDROID开头,表示控件的属性,FILL_PARENT是系统自带参数,表示最大的宽或高,还有一个WRAP_CONTENT,表示刚好合适的宽或高。除了上面的三个属性外,还有一些其他的属性,如ANDROIDBACKGROUND“FF0000FF”,设置框架的背景色,ANDROIDRIENTATION“VERTICAL”用来设置这个框架里面的走向属性。框架弄好,就可以在里面添加控件了,控件的基本写法也和框架一样,后面用到的时候将具体研究各个控件的细节。473CNCHESS的2D图像编程本系统的2D图像编程主要用于对局模块中棋盘、棋子、选择框、提示信息等图像元素的更新。SGL编程是本系统设计中的难点,在系统的开发过程中主要使用了ANDROID系统类库中的2D图形库接口2,达到了预期的效果,实现了项目的目标。通过使用ANDROID提供的2D画图API,程序员能一笔一划或者使用GRAPHIC来画所需要的东西了,要画什么要显示什么都完全可控。这种方式根据环境还分为两种一种就是使用普通VIEW的CANVAS画图,还有一种就是使用专门的SURFACEVIEW的CANVAS来画图。两种的主要是区别就是可以在SURFACEVIEW中定义一个专门的线程来完成画图工作,应用程序不需要等待VIEW的刷图,提高性能。前面一种适合处理量比较小,帧率比较小的动画,比如说象棋游戏之类的;而后一种主要用在游戏,高品质动画方面的画图。本系统使用的是前一种图像处理方式,系统棋盘棋子以及对局信息的绘制、棋盘的显示更新等图像处理部分主要使用了系统API中的ANDROIDGRAPHICS类库进行处理。在本项目中,BOARDVIEW类主要是做棋盘模型的构建、更行以及图像方面的处理工作。下面简要介绍下在本项目的开发中,是如何构建棋盘模型以及如何实现棋盘图形的重绘。1模型构建棋盘的模型

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论