版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、毕业设计(论文) 题题 目目: 基于 android 数独游戏设计 基于 android 数独游戏设计 摘摘 要要 移动互联网时代的到来极大的改变了我们的生活,而 android 是一种以 linux 为基 础的开放源码操作系统迅速占领了智能机操作系统,所以在 android 环境下开发显得尤 为必要。android 是开放性体系架构,不仅具有非常好的开发、调试环境,而且还支持各 种可扩展的用户体验,包括丰富的图形组件、多媒体支持功能以及强大的浏览器。因此, 对于软件从业人员来说,android 平台具有无限的吸引力。 本文就在分析讨论 android 手机软件开发技术原理的基础上,为用户开发
2、出基于 android 平台的数独游戏的软件。通过对 android 系统架构和应用开发进行初步研究, 设计一款数独游戏。在对系统进行详细需求分析的基础上,确定了系统的功能和性能要 求,对游戏的开机动画,菜单界面、屏幕绘制、时间控制、布局算法等进行了设计。 本文详细介绍了在 android 平台上以 java 为语言编写游戏的过程,最终实现了一个 界面友好、操作简单的手机益智游戏。 关关键键词词:android 数独 智能机 the design of sudoku game based on android abstract arrival of the mobile internet er
3、a has greatly changed our lives, and android is a linux- based system quickly occupied the smartphone operation system, android development is particularly necessary under the circumstances. androids biggest feature is its open architecture, not only has a very good development and debugging environ
4、ment, but also supports a variety of scalable user experience, including rich graphical components, multimedia support, and powerful browser. therefore, for software professionals, android platform has unlimited appeal. in this thesis, the analysis and discussion of android mobile phone software dev
5、elopment technology provide users with better platform to the sudoku based on android meteorological software. through the android system structure and application development for preliminary research, we designed a sudoku game. in the system based on the analysis of the detailed requirements, we de
6、sign the game in the game menu interface, the screen rendering, time control and layout algorithm. this thesis describes the whole development process of android based smart phone game using google android sdk. finally, we have the software with friendly interface and simple operation. key words: an
7、droid ; sudoku ; smartphone 目 录 摘 要.i abstract.ii 第一章 绪论.1 1.1 研究背景.1 1.1.1 手机游戏的发展以及特征1 1.1.2 数独游戏背景2 1.2 android 手机游戏的市场价值.2 1.3 本文主要工作及章节结构.3 第二章 android 平台概述.4 2.1 android 系统简介.4 2.2 android 系统特性.4 2.3 android 操作系统框架结构.5 2.3.1 应用程序6 2.3.2 应用程序框架6 2.3.3 库与运行环境7 2.3.4 内核7 2.4 android 应用程序构成.8 2.4.
8、1activity8 2.4.2 broadcast receiver9 2.4.3 service10 2.4.4 content provider10 2.5 android 应用程序的生命周期.11 第三章 数独游戏的设计.13 3.1 游戏功能简介.13 3.2 游戏策划以及准备工作.14 3.3 游戏的架构.16 3.3.1 各类的介绍16 3.3.2 游戏的框架简介18 第四章 基于 android 平台数独游戏的实现.19 4.1 欢迎界面的设计和实现.19 4.1.1 主类 klsdactivity 实现19 4.1.2 欢迎界面 welcomeview 类的实现20 4.1.
9、3 welcomeviewdrawthread 类和 welcomeviewgothread 类的实现21 4.1.4 helpview 类和 aboutview 类的实现22 4.2 游戏界面相关类的实现.23 4.2.1 游戏界面 gameview 的实现24 4.2.2 时间线程 timethread 的实现25 4.3 数独算法类的实现.25 4.3.1 数独算法基本逻辑26 4.3.2 检测填充结果27 4.4 游戏的测试和运行.29 4.4.1 游戏测试概述29 4.4.2 测试环境30 4.4.3 游戏运行结果31 第五章 总结和展望.35 5.1 总结.35 5.2 展望.35
10、 参考文献.36 致 谢.37 第一章 绪论 1.11.1 研究背景研究背景 1.1.1 手机游戏的发展以及特征 手机游戏,是指用户运行在移动终端的应用程序,具有网络连接功能,能 够满足用户随时随地进行游行的需求,它需要一定的硬件环境和一定的系统环 境作为其运行的基础。手机游戏吸引用户最大的特点就是其便利性,由于其是 移动终端,所以用户可以随时随地进行游戏。正是因为其便利性,手机游戏市 场有了很大的发展。在美国,手机游戏作为美国手机用户最喜欢的移动应用之 一,在iphone和android等智能终端推出后发展迅速。 手机游戏常见的特征可以总结如下: 1.庞大的潜在用户群:全球在使用的移动电话已
11、经超过 10 亿部,而且这个 数字每天都在不断增加。在除美国之外的各个发达国家,手机用户都比计算机 用户多。手机游戏潜在的市场比其他任何平台,比如 playstation 和 gameboy 都要大。 2.便携性与移动性:在控制台游戏时代,gameboy 热销的一个原因就是便 携性人们可以随时随地沉浸在自己喜欢的游戏中,还可以随时随地抢购自 己喜欢的装备或宠物。和游戏控制台或者 pc 相比,手机虽然可能不是一个理想 的游戏设备,但毕竟人们总是随时随身携带,这样手机游戏很可能成为人们消 遣时间的首选。手机便携性、移动性的特征更能满足用户随时随地玩游戏的需 求,用户利用排队、等车的时间进行游戏,手
12、机游戏碎片化的特性凸显。调查 显示,29.8%的用户在用手机玩游戏以后电脑端玩游戏的时间减少,手机游戏已 经开始抢夺电脑游戏时间。22.4%的用户手机游戏时间越来越长,仅有 10%的用 户时间变短,手机游戏已逐渐成为一种普遍的娱乐方式。 3.支持网络:因为手机是网络设备,在一定限制因素下可以实现多人在线 游戏。随着移动网络的发展,移动游戏也越来越多的被大家接受,对于之前长 期通知市场的掌机来说造成了不少的冲击。市场研究公司 idc 和 app annie 报 告显示 2013 年第一季度 ios 和 android 平台游戏业务营收是掌机的 3 倍。 1.1.2 数独游戏背景 数独的前身为“九
13、宫格” ,最早起源于中国。但当时的算法比现在的更为复 杂,要求纵向、横向、斜向上的三个数字之和等于 15,而不是数字不能重复。 儒家典籍易经中的“九宫图”也是来源于此。 到了 18 世纪末,瑞士数学家莱昂哈德欧文又发明了一种叫做“拉丁方块” 的游戏,之后不久,美国的一家数字逻辑游戏杂志开始刊登这类游戏,使此类 游戏得到良好发展,之后又在日本得到了广泛的传播。2004 年,第一个“数独” 游戏被刊登上了英国泰晤士报的封面,此时开始数独游戏才真正为世界所 知晓。 数独游戏的规则很简单,只需要在空格处填写19的数字,并保证每个数字 在每个九宫格内只出现一次,而一般的游戏过程是系统随机生成一个棋局,然
14、 后玩家需要在空白处填上相应的数字使其满足游戏规则。由于此类游戏操作简 单,不需要特定的语言基础,也不需要进行数字运算且可玩性高、锻炼思维、 开发大脑,所以很快风靡全球。 1.21.2 androidandroid 手机游戏的市场价值手机游戏的市场价值 android 是 google 开发的基于 linux 平台的开源手机操作系统。它包括操 作系统、用户界面和应用程序移动电话工作所需的全部软件,而且不存在 任何以往阻碍移动产业创新的专有权障碍2。google 与开放手机联盟合作开发 了 android,这个联盟由包括中国移动、摩托罗拉、高通、宏达电和 t-mobile 在内的 30 多家技术
15、和无线应用的领军企业组成。google 通过与运营商、设备 制造商、开发商和其他有关各方结成深层次的合作伙伴关系,希望借助建立标 准化、开放式的移动电话软件平台,在移动产业内形成一个开放式的生态系统。 android平台上的游戏相比应用软件,不需要进行严格的市场细分,不需要 针对目标用户量身定制。这是因为游戏玩家的核心需求是统一的,那就是:娱 乐与打发时间(乃至更高层面的竞技需求和群体认同需求),这种需求附着于特 定的社会发展阶段,不受地域的限制,甚至于能够穿透文化壁垒。因此,绝大 多数种类的游戏都具备传染性与普适性,每一个售出的游戏都将会点燃周围潜 在玩家的激情,最终吞噬整个需求市场。由此可
16、知,几乎每一个android手机用 户都是游戏的需求者,都是潜在的顾客,现今的1000多万android用户不过是冰 山一角,随着android手机市场进一步壮大,游戏的市场容量将具备更大的增长 空间3。 1.31.3 本文主要工作及章节结构本文主要工作及章节结构 整篇论文共分为六个部分,其主要内容安排如下: 第一章 引言。介绍论文的研究背景、目的和意义。包括课题的背景资料 简介、国内外研究现状和发展趋势、深入地介绍了课题研究的价值。 第二章 android 平台概述。这部分主要是介绍了智能手机系统现状、 android 的功能特征、android 系统的特点以及 android 的体系结构。
17、 第三章 数独游戏的设计。对游戏相关策划,功能以及架构进行介绍。 第四章 数独游戏的实现。这部分主要介绍了游戏的界面、游戏中的逻辑 处理以及该游戏今后的改进和优化。 第五章 总结和展望。对整篇论文加以总结与回顾以及对未来的展望。 第二章 android 平台概述 本章将介绍android 这个基于linux开发平台,首先我们会介绍 android 操作系统,然后讲述其特性,接着讲述其系统框架,其次我们会重点介绍其应 用程序的构成模块,最后会介绍其生命周期。 2.12.1 androidandroid 系统简介系统简介 android 是谷歌公司发布的手机操作系统,它是基于linux 平台的开源
18、手 机操作系统,谷歌公司将要把其打造为基于移动终端的真正开放的移动软件平 台,不仅拥有移动电话所需要的工作软件,而且在专利权方面能够不侵犯他 人权利去推动移动互联网的创新。 谷歌公司为了开发android,与开放手机联盟进行了合作,手机开放联盟由 全球30 多家移动开发和手机应用的领先企业组成。谷歌公司不仅仅和运营商达 成了合作关系、而且与设备制造商以及开发商保持长期合作,目的就在于利用 其优势建立移动软件平台,其特点是标准化、开放式的。android是谷歌公司未 来企业战略的一部分,其目的是为了在任何时候任何地点能够提供信息 4。 2.22.2 androidandroid 系统特性系统特性
19、 android系统特性如下所示: 1.应用框架:android系统组件,用于开发流程,两个特性:可重用性和可 替代性。 2.dalvik 虚拟机:在android系统中, dalvik虚拟机是一种java 虚拟机, 是google公司自主开发,其代号为dalvik,占用资源比较小,运行效率比较高。 3.集成浏览器:引擎 webkit,其特性是开源。 4.优化图形:强大的自定义二维图形库。基于opengl es 1.0 标准的3d 图 形功能,在移动3d 开发中有着至关重要的地位。 5.sqlite 数据库:sqlite 提供结构化的数据存储。它是一款轻型免费的 且开源的数据库,设计目标是嵌入
20、式的。它具备占用资源低、需要的内存空间 少、处理速度较快,并且还支持事务处理功能等优点。 6.多媒体支持:支持各种通用的音视频和静态图像格式 (mpeg4、mp3、jpg、png、gif、aac、h.264、amr)。 7.gsm 技术:(依赖硬件)global system for mobile communications,全 球移动通讯系统,俗称全球通,是第二代移动通信技术,其开发目的是让全球各 地可以共同使用一个移动电话网络标准,让用户使用一部手机就能行遍全球。 8.蓝牙,edge,3g,and wi-fi:(依赖硬件)蓝牙和wi-fi 都是一种短距离 的无线连接技术,在短距离内可以实
21、现话音和数据的无线传输。edge(enhanced data rate for gsm evolution),是增强型数据速率gsm 演进技术。 9.camera,gps,compass,and accelerometer:(依赖硬件)gps(global positioning system),即全球定位系统。它是一个由覆盖全球的24 颗卫星组 成的卫星系统。compass是一个开放源代码的java 搜索引擎框架。 10.强大的开发环境:包括一个设备模拟器,调试工具,内存和性能检测, 以及eclipse 11.ide 的开发插件。eclipse集成开发环境。 2.32.3 androidan
22、droid 操作系统框架结构操作系统框架结构 android 作为一个开源的移动设备的平台,其软件层次结构自上而下分为 四个层次,分别是:应用程序(application)、应用程序框架(application framework)、各种库(libraries)和android 运行环境(runtime)、linux 内核 (linux kernel)。 图 2.1 google 手机操作系统平台-android 的架构模型 2.3.1 应用程序 突破传统思维,提供更好的用户体验。android 将会移植一系列的核心应 用,包括e-mail 客户端,sms 程序,日历,gps 地图,浏览器,联
23、系人等等。 所有的应用程序都是由java语言完成的。应用程序是无界限的,可以在平 等条件下创建,还可以轻松地嵌入web,可以并行运行5。 2.3.2 应用程序框架 android 应用程序由一个或多个组件组成,android 的应用程序框架为应 用程序层的开发者提供apis,它实际上是一个应用程序的框架。由于上层的应 用程序是以java 构建的,因此本层次提供的首先包含了ui 程序中所需要的各 种控件: 例如:views(视图组件)包括lists(列表),grids(栅格),text boxes(文 本框),buttons(按钮)等。甚至一个嵌入式的web 浏览器。 一个 android 的应
24、用程序可以利用应用程序框架中的以下几个部分: activity(活动),broadcast receiver(广播接收者),service(服务), content provider(内容提供者) 2.3.3 库与运行环境 android 包含一套c/c+库,能被系统中不同的组件使用。这些功能通过 android应用框架展现给开发人员。下面列出一些核心库: (1)system c library:从bsd 继承来的标准c 系统函数库,也是系统中最 为底层的库,是专门为基于嵌入式linux 的设备制定的。 (2)media framework:该库支持多种常用的音频、视频格式的回放和录制, 同时
25、支持静态图片文件,包括mpeg4、h.264、mp3、aac、amr、jpg 和png 等。 (3)surface manager:用于管理不同应用对图形显示子系统和2d 和3d 图 形层的访问。 (4)webkit:一个时尚的web 浏览器引擎,为android 浏览器和内嵌的web view 提供实现。 (5)sgl:隐藏的2d 图形引擎。 (6)3d libraries:基于opengl es 1.0 apis 实现的库,该库可以使用硬 件3d 加速,或者高度优化的3d 软加速。 (7)freetype:位图和向量模式的字体绘制。 (8)sqlite:一个强大的,轻量的关系型数据库引擎,
26、用于所有的应用。 android 运行时android 包含一组核心库,提供了java 语言核心库内的大 部分功能。android运行环境主要指的是虚拟机技术dalvik。dalvik虚拟机 依赖linux kernel来实现一些潜在功能,例如线程和底层内存管理。dalvik虚 拟机和一般java虚拟机(javavm)不同,它执行的不是java标准的字节码而是 dalvik可执行格式(.dex)中执行文件,该格式的文件经过优化占用很小的内存。 在执行的过程中,每一个应用程序即一个进程(linux 的一个process) 。二者 最大的区别在于java vm 是以基于栈的虚拟机(stack-ba
27、sed),而dalvik是基于 寄存器的虚拟机(register-based)6。显然,后者最大的好处在于可以根据硬 件实现更大的优化,这更适合移动设备的特点。每个android应用程序都在 dalvik vm的一个实例中运行,这个实例驻留在一个由linux内核管理的进程中。 2.3.4 内核 android使用linux2.6 内核来提供系统的核心服务,例如:安全机制,内 存管理,进程管理,网络堆栈。android更多的是需要一些与移动设备相关的驱 动程序。其主要的驱动有:显示驱动(display driver)、flash内存驱动(flash memory driver)、照相机驱动(ca
28、mera driver)、音频驱动(audio driver)、 wi-fi驱动(camera driver)、键盘驱动(keyboard driver)、蓝牙驱动 (bluetooth driver)、binder ipc驱动(android一个特殊的驱动程序,具有单 独的设备节点,提供进程间通讯的功能)7。 2.42.4 androidandroid 应用程序构成应用程序构成 android应用程序与其他很多计算机平台的应用程序不同,他们没有唯一的 启动入口,一个android应用程序是由多个不同组件组合而成,组件间通过 intent实现通信。android系统的基本组件包括activit
29、y、service、broadcast receiver和content provider等,要实现组件间通信,还需要intent消息组件。 并不是每个android应用程序都必须具备这四个组件,很多时候只需要这四种中 的某几种就可以了。除此之外,应用程序的所有组件还都必须在 androidmanifest.xml中声明8。这是一个xml配置文件,这个配置文件用于定 义应用程序的组件、组件的功能及必要条件等。这个配置文件是任何一个 android应用程序所必需的。 2.4.1 activity activity 可以说是开发人员最常用的组件,同时也属于android 最基本的 组成部分之一。a
30、ndroid 程序中,一般一个activity 代表手机屏幕上的一屏。 举例来说,如果将手机比作一个浏览器,那么一个activity 就相当于一个网页。 在activity 中,可以添加多个视图,然后为这些视图添加一些事件处理。这些 视图可以是按钮、文本框、列表等。可以看到,activity 的概念和网页的概念 相当类似。一般一个android 应用是由多个activity 组成,同时这些activity 相互之间可以进行跳转,例如,按下某个activity 中的button 按钮后,可能 会跳转到一个其他的activity。不过和网页跳转稍有不同,activity之间的跳 转可以有返回值,例
31、如,在activity a 跳转到activity b 后,那么当 activity b运行结束时,可能会返回给activity a 一个值。在多个activity 交流的过程中,这种返回机制是相当实用的。当用户进入一个新的屏幕时,之 前的屏幕会转入暂停状态,并且保存在历史堆栈中。正是由于历史堆栈的存在, 用户可以通过返回操作,返回到之前打开过的所有屏幕。android默认的是将应 用程序从开始到当前的每一个屏幕都保存到堆栈中,不过与此同时,android还 提供了很方便的机制,让开发人员自定义某个屏幕是否需要保存到历史堆栈。 activity 的跳转实现,必须借助于intent 类。因此in
32、tent 在android 应用中 占据的地位是极其重要的。简单来说,一个intent 就是对一个将要执行的操作 请求的抽象描述。 intent 的描述,主要包含有两个数据结构:动作(action)和动作对应的数 据(data)。动作有很多种,系统中最常见的动作类型有:main(表明该activity 是应用程序的入口)、view、pick、edit 等等;而动作对应的数据一般以uri 的形式表示,例如:要查看某一个网页,则需要创建intent,它的动作类型为 view,对应的数据应该是该网页的网址。值得一提的是,有一个类叫 intentfilter,它是intent的相关类。如果说inten
33、t是一个有效的操作请求, 那么一个intentfiler则用于描述一个activity(或者intent receiver等)能够 接收哪些intent的请求。比如系统浏览器的activity用于查看某一个网页,那 么它用于接收intent的intentfilter,要定义类型为view的动作并且能够过滤 表示一个网页网址的 uri。通常intentfilter要被注册在androidmanifest.xml文件中。 activity 之间的跳转正是通过解析各种intent 来实现的。例如一个activity 调用startactivity(intent)方法,希望跳转到其他的activity
34、 时,会触发系 统的intent 解析过程,在所有安装的应用程序中已注册的intentfilter 中查 找,并最终挑选出能够匹配intent 的activity。然后这个新的activity 因为 接收到intent 的请求而开始运行,完成activity 的跳转。这种跳转机制提供 了两个关键好处: (1)操作请求被intent 封装起来,方便activity 重复利用。 (2)相互跳转的多个activity 之间实现了松耦合。只要intentfilier 保持 不变,一个ctivity 可以随意修改,而不用担心其他activity 找不到它。 2.4.2 broadcast receive
35、r 应用程序可以通过broadcast receiver 监听一个外部的事件,并做出响应。 例如,当应用程序需要对电话呼入这个外部事件做出反应时,可以利用 broadcast receiver 进行处理。再如,当一个后台下载任务成功的事件发生时, 需要提示用户下载完成,仍然可以利用broadcast receiver 来进行处理。 broadcast receiver不能生成ui,也就是说对于用户来说是透明的,用户 是看不到的。broadcast receiver只能通过notificationmanager来通知用户这 些事件发生了。broadcast receiver既可以在android
36、manifest.xml中注册,也 可以在运行时的代码中使用context.registerreceiver()进行注册。注册完成 之后,当事件来临的时候,即使程序没有启动,系统依然可以根据定义,自动 启动程序。各种应用也可以通过使用context.sendbroadcast()将它们自己的 intent broadcast广播给其他应用程序。 2.4.3 service service是一种程序,它可以运行很长时间,但是它却没有用户界面,不可 交互,而且不能自己运行。它需要通过某一个activity或者其他的context对象 来调用12。最常见的例子,比如说用户正在运行一个音乐播放器的程序
37、,此时 如果想浏览网页,那么,在用户导航到android的浏览器以后,虽然进入了浏览 器屏幕,但是歌曲的播放并没有停止,而是在后台继续播放着。其实播放的动 作正是由播放音乐的service执行着。当然,如果需要的话,service也是可以 停止。通过startservice(intent service)可以启动一个service,通过 context.bindservice()可以绑定一个service。 2.4.4 content provider 对于数据存储,android与其他的操作系统有一点不太一样,即数据在 android程序中都是私有的,这些数据包括文件类型和数据库类型以及其他
38、类型 的数据。这样系统和应用程序的数据就各自独立起来,以避免受到某些不正常 程序或是病毒的影响。不过这并不代表各应用程序之间就因此而无法进行数据 交换了。当某个应用程序希望与其它的应用共享其数据时,android提供的 content provider就可以发挥作用了。在实现content provider的抽象接口以 后,程序便可以将自己的数据暴露出去,其他程序只要有权限,就可以通过这 一套标准而统一的接口,读取或是删除该程序的数据13。 2.52.5 androidandroid 应用程序的生命周期应用程序的生命周期 android 应用程序一个完整的生命周期是从应用程序的创建到结束的全过
39、 程,与其他系统不同,android 应用程序的生命周期是不受进程本身控制的, 而是由android 系统来决定的,android 系统会根据应用程序对用户的重要性 及当前系统的负载来决定生命周期的长短。android 系统的各个进程重要程度 如图2.2 所示。 前台进程可见进程服务进程后台进程空进程 关键优先级高优先级低优先级 图 2.2 android 应用程序进程优先级 (1)前台进程,是android 系统中最重要的进程,是与用户正在进行交互的 进程。有以下四种情况:activity 正在与用户进行交互;进程被activity 调 用,而且这个进程正在与用户进行交互;进程服务正在执行声
40、明中的回调函数, 如oncreate()、onstart()、ondestroy();进程的broadcast receiver 在执行 onreceive()函数。android 系统在多个前台进程同时运行时,可能会出现资源 不足的情况,此时会清除部分前台进程,以保证主要的用户界面能够及时响应。 (2)可见进程,是指部分应用程序界面能够被用户看见,却不在前台与用户 进行交互,不影响界面事件的进程。如果应用程序进程包含一个服务,且这个 服务正被用户可见的activity 调用,则此进程同样被视为可见进程。android 进程一般存在少量的可见进程,只有在特殊情况下,android 系统才会为保
41、证 前台进程的资源而清除可见进程。 (3)服务进程,服务进程是指包含已启动服务的进程。该进程没有用户界面 并在后台长期运行。除非android 系统不能保证前台进程和可见进程所必要的 资源,否则不会强行清除服务进程。 (4)后台进程,后台进程是指不包括任何已经启动的服务,而且没有任何用 户可见的activity 的进程。android 系统中一般存在数量较多的后台进程,在 系统资源紧张时系统将会优先清除用户较长时间没有见到的后台进程。 (5)空进程,空进程是不包含任何活跃组件的进程,空进程在系统紧张时会 被首先清除。但为了提高android 应用程序的启动速度,android 系统会将空 进程
42、保存在系统内存用,在用户重新启动该程序时,空进程会被重新使用。 当两个应用程序具有相同的优先级时,处于较低优先级且运行时间最长的 进程将会首先被终止。进程的优先级也受到进程间依赖性的影响,如果一个应 用程序依赖于第二个应用程序所提供的服务或者内容提供器,那么第二个应用 程序至少会拥有与它所支持的这个应用程序相同的优先级。进程的优先级取决 于所有组件中优先级最高的部分,进程的优先级会根据其他进程的依赖关系而 变化。 第三章 数独游戏的设计 3.13.1 游戏功能简介游戏功能简介 数独游戏的规则很简单,只需在空格处填入 19 的数字,并保证每个数 字在每个九宫格内只能出现一次,且每个数字在每一行、
43、每一列也只能出现一 次,而一般的游戏过程是系统随机生成一个棋局,然后玩家需要在空白处填上 相应的数字使其满足游戏规则。游戏框架如下图所示: 点击图标 开机动画 计时区域 提示暂停 游戏区域 退出游戏 功能区域 开始游戏 菜单界面 帮助游戏关于游戏 退出换题 图3.1 游戏框架图 该游戏的运行步骤如下。 1.启动游戏后首先进入的便是欢迎界面的动画,在欢迎界面中,“点击屏 幕继续”闪动,达到提示的效果。 2.在游戏界面点击屏幕,便进入菜单界面。 3.在菜单界面单击“关于游戏”菜单可进入“关于”界面,在“关于”界 面中介绍了该游戏的目标平台及开发日期。 4.在菜单界面单击“帮助游戏”菜单可进入“帮助
44、”界面,在“帮助”界 面介绍了游戏的基本规则。 5.在菜单界面单击“开始游戏”菜单可进入游戏界面。 6.当在游戏过程中单击“暂停”按钮时,便进入暂停状态。 7在游戏过程中随时可以通过“换题”按钮来更换题目。 8.当玩家单击“放弃”按钮时,会提示玩家是否真的需要退出游戏,然后 根据玩家的选择进行操作。 9.当玩家单击“提示”按钮时,界面上会出现一个红心表示当前可以提示 玩家输入数字,此时再单击空白处,便会自动填上正确答案。 10.当玩家将界面中所有的空白全部填满数字时,系统会自动判断所填写的 数字正确与否,当有错误时,会出现游戏失败界面;当全部填写正确时,会出 现游戏胜利界面。 11.在胜利或者
45、失败状态时,玩家可以通过点击屏幕任意位置返回欢迎界面。 12.在菜单界面单击“退出游戏”便可退出该游戏。 3.2 游戏策划以及准备工作游戏策划以及准备工作 3.2.1欢迎界面的策划 欢迎界面的主要实现的是开机动画以及菜单选项的功能。在开机动画上准 备实现动态效果,利用图片刷帧进行实现。 在菜单界面实现游戏的功能选择,菜单界面就是一张图片,鼠标点击相应 的区域实现相应的功能。在这里运用到坐标系,如下图所示 图3.2 菜单界面 手机屏幕分辨率是480320,所以横纵坐标如图所示。 当点击的区域坐落于60 x260,135y180区域内,则进行开始游戏功能。 当点击的区域坐落于60 x260,180
46、y230区域内,则进行关于游戏功能。 当点击的区域坐落于60 x260,230y280区域内,则进行帮助游戏功能。 当点击的区域坐落于60 x260,280ywelcomeview.bitmapsid.length-1) welcomeview.drawindex = welcomeview.bitmapsid.length-10; if(welcomeview.drawindex%5 = 0) welcomeview.drawstring = !welcomeview.drawstring; try thread.sleep(sleepspan);/睡眠 catch(exception e)
47、 e.printstacktrace();/打印异常信息 分析该类的run() 方法,控制drawindex的值,每次循环将欢迎界面的 drawindex 加1,然后判断是否到达数组的最后,当到达最后时,将其减10,然 后继续进行循环。同时,判断drawindex是否为5,这样每循环5次改变 drawstring的值,从而实现文字的闪动效果。 4.1.4 helpview 类和 aboutview 类的实现 游戏中关于游戏帮助和游戏说明,我们分别通过helpview类和aboutview类 的实现。helpview类和aboutview类都是通过ondraw()方法来绘制界面。由于这 两个类在
48、很大程度上是相似的,所以下面只分析helpview类,代码如下所示: public helpview(klsdactivity activity) super(activity); this.activity = activity;/得到activity的引用 surfaceholder = this.getholder();/获得surfaceholder getholder().addcallback(this);/添加callback接口的实现 helpbitmap = bitmapfactory.decoderesource(getresources(), r.drawable.hel
49、p); public void ondraw(canvas canvas) /绘制方法 canvas.drawcolor(color.white);/背景色 canvas.drawbitmap(helpbitmap, 0, 0, null);/绘制图片 public boolean ontouchevent(motionevent event) /键盘监听方法 if(event.getaction() = motionevent.action_down)/屏幕被按下 double x = event.getx(); double y = event.gety();/得到坐标 if(x270 r
50、eturn super.ontouchevent(event); public helpview(klsdactivity activity) 为“帮助”界面的构造器,在 构造器中先得到activity 以及surfaceholder的引用,然后添加callback 接口 的实现并对图片资源进行初始化。 ondraw()为重写的绘制方法,在该方法中,首先绘制白色背景,然后将 帮助界面的背景图片绘制到指定位置。 ontouchevent()为重写的键盘监听方法,当玩家点击屏幕时,会调用该 方法来处理玩家的屏幕事件,在“帮助”界面中该方法实现比较简单,只是判 断玩家点击的是否为返回按钮即可。当玩家
51、点击返回按钮时,需要向activity 发送handler 消息通知控制器切换屏幕。 4.24.2 游戏界面相关类的实现游戏界面相关类的实现 游戏界面实现游戏展示,计时界面展示,以及功能按键。流程图如下图所 示: 开始 生成数独 填数区域 换题 提示 提示暂停计时 暂停填数 检测 退出 结束 是 否 是 否 是 否 是 否 图 4.2 游戏界面流程图 4.2.1 游戏界面 gameview 的实现 首先理解下gameview的运行思路,gameview在初始化时候读取相关图片信 息,包括背景图片,数独背景框图片等等,在初始化同时,启动 gameviewdrawthread线程进行刷帧,time
52、thread 线程来更新界面中的时间。当 玩家点击背景框空白位置,需要绘制数字键盘时,会启动drawkeythread 线程 绘制数字键盘。当玩家点击按钮时候,相关方法会被调用。以上的过程都需要 klsdactivity的参与管理。 gameview 同样继承自surfaceview 类,其关键也是实现ondraw()方法。 ondraw()方法分别绘制游戏界面背景图片,数字背景框,选题提示等等按钮, 时间显示区域等。drawkey()方法实现了数字键盘的绘制,保证在点击空白框时 候有圆盘数字选框出现。通过surfacecreated()和surfacedestroyed()两 个方法负责相关
53、线程的启动和调用工作。 4.2.2 时间线程 timethread 的实现 timethread线程主要用来更新界面中的时间,作为数独游戏玩家计时功能, 代码如下: public class timethread extends thread gameview gameview;/声明gameview的引用 boolean flag=true;/循环标志位 public timethread(gameview gameview)/构造器 this.gameview=gameview;/得到gameview的引用 public void run()/重写的run方法 while(flag) ga
54、meview.time+;/时间自加 try thread.sleep(1000);/睡眠一秒种 catch(exception e)/捕获异常 e.printstacktrace();/打印异常信息 timethread 类的实现比较简单,只需每隔一秒钟通过gameview.time自加 更改一下gameview 中表示时间的属性即可。 public timethread(gameview gameview) 为时间线程的构造器,在构造器 中先得到gameview的引用。然后重写run()方法,通过时间的自加,实现一秒钟 功能。 4.34.3 数独算法类的实现数独算法类的实现 数独算法类主要
55、实现数独的生成以及填入数字的检测功能,流程图如下: 开始 生成数独 填入数字 符合规则 游戏成功 结束 是 否 图 4.3 welcomeview 类功能流程图 4.3.1 数独算法基本逻辑 本节将对数独算法类shudusuanfa.java 进行解释,该类基本上是数学计算, 通过一定的算法产生所需要的数独数组,通过特定的接口供其他类使用。 该类的目的是创建一个二维数组来表示数独矩阵。使矩阵的每行、每列、 每块都没有重复的数字。算法的简单思路是先随机取出一个09 的数字,然后 检查其所在的行、列、块是否都符合要求。当符合要求时继续填充下一个,而 当不符合要求时,再次随机取出一个没有取出过的数字
56、,再判断。当9 个数字 都取出过后还没有找到符合要求的数字时,进行回退处理,即将最后一个取出 的符合要求的数字进行重新取值,直到所有数字全部填充完毕。 在求解数独时候,运用到回溯法,将所有的解(问题的解空间)按照一定 结构排列,再进行搜索。一般解空间构造成为为树状结构,用深度优先的策略 搜索,一般有两种方式: 1.只需要一个解的话,找到解即停止。 2.需要求出所有解,则需做“树的遍历”找到所有解。 回溯法的基本做法是搜索,或是一种组织得井井有条的,能避免不必要搜 索的穷举式搜索法。这种方法适用于解一些组合数相当大的问题。 回溯法在问题的解空间树中,按深度优先策略,从根结点出发搜索解空间 树。算
57、法搜索至解空间树的任意一点时,先判断该结点是否包含问题的解。如 果肯定不包含,则跳过对该结点为根的子树的搜索,逐层向其祖先结点回溯; 否则,进入该子树,继续按深度优先策略搜索。 回溯法是一种搜索算法,其基本思路是:在一个问题中,根据题意给出的 边界条件划定出所有可能解的范围(称为可能解) ,根据题意确定出约束条件。 利用程序顺次在所有可能解中搜索时按照深度搜索的方式进行。即在第一层选 定一个满足约束条件的解,然后以该可能解为出发点,搜索第二层的一个可能 解(试探) 。如果搜索到第二层的一个可能解,则继续搜索第三层得一个可能解。 依次类推,直到所有层得可能解都被找到,则得到了该问题的一个完整解。
58、如 果第二层所有的肯可能解都不满足约束条件,则返回第一层,放弃原有的可能 解,使用第一层的下一个可能解(回溯) 。一次类推,寻找第二层的一个可能解。 回溯法相对于其他穷举的特点在于,不必把问题的每一层的所有可能解都 遍历一遍,只要当前的可能解不满足约束条件就抛弃该解,寻求下一个可能解, 而不必求解其余的下层解。当当前层得所有可能解都不满足约束条件,则回溯 到上一层,抛弃上一层的当前可能解。 从以上分析中结合数独问题的规则,得出数独问题的约束条件为: 每一格的数值范围仅限 1-9 每一格内的数字在当前行不允许重复 每一格内的数字在当前列不允许重复 每一格内的数字在当前小宫格内不允许重复 由此,回
59、溯法通过约束条件的筛选,在所有解中除掉不可能的解,从而获 得问题的一个或者全部解。 4.3.2 检测填充结果 根据数独游戏的规则,玩家填充 81 个宫格之后,要满足所有行,所有列 和所有小九宫格内不能出现重复的数字,并以此为条件进行检测。 列检测 首先对各列进行检测,提供了检测列内 9 个数字是否有重复数据的方法 checkline (),该方法以此遍历列中的 9 个数字,当遍历到某个数字时, 检测该数字后面的数字是否出现重复。比如,当检测到第 3 个数字是 7 时,则 检测第 4-9 个数字是否出现 7,如果出现重复则停止检测,只有既可以避免重 复检测,又可以避免遗漏。 public boo
60、lean checkline(int col)/ 检查列是否符合要求 for(int j = 0;j 8;j+) if(njcol = 0) continue; for(int k =j + 1;k 9;k+) if(njcol = nkcol) return false; return true; 行检测 类似于对列数据的检测,还需要对每行进行检测,因此程序提供了对行数 据的检测方法 checkrow (),该方法代码如下: public boolean checkrow(int row)/检查行是否符合要求 for(int j = 0;j 8;j+) if(nrowj = 0) conti
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 教师开学前军训心得体会5篇
- 物流设施与设备第二章航空管道
- 债务偿付质押合同(2篇)
- 公共事业投资合作协议书(2篇)
- 河南省安阳市第六十二中学2022年高三语文下学期期末试卷含解析
- 2025年Γ-球蛋白三类项目合作计划书
- 上海写字楼租赁合同范本
- 幼儿园房屋租赁合同书范本
- 小吃街摊位租赁合同
- 长期租赁合同范本
- DL-T5704-2014火力发电厂热力设备及管道保温防腐施工质量验收规程
- 三年级上册数学教案 - 6.2整理与提高(解决问题-灯市) 沪教版
- 东华医院信息平台解决方案-药房流程接口
- 通力电梯KCE电气系统学习指南
- 风电场岗位任职资格考试题库大全-下(填空题2-2)
- 九年级数学特长生选拔考试试题
- 幼儿园交通安全宣传课件PPT
- 门窗施工组织设计与方案
- 健身健美(课堂PPT)
- (完整版)财务管理学课后习题答案-人大版
- 锚索试验总结(共11页)
评论
0/150
提交评论