吃豆子(Packman)
ZLYD团队总结--吃豆子(Packman)
一、设计主要内容
玩家可以通过键盘或鼠标控制游戏区。游戏采取分数和血量制,当血量用尽时游戏结束,游戏以最终玩家获得的分数来判断玩家水平的高低。使用IEDA和JDK1.6工具,操作系统为WINDOWS,采用面向对象方法完成,包括总体设计、详细设计、编码实现、测试。
二、需求分析
- 吃豆子游戏是一种古老而又有趣的游戏, 游戏软件不计其数, 网上就有好多关于实现的复杂算法和设计, 其难度让一般初学者望而却步。开发的出来的吃豆子游戏是一种内容丰富,画面优美,益智类游的戏,并且不受网络的限制,让人们能够在任何时刻通过体验游戏,达到身心愉悦、放松心情。
- 通过本游戏的设计,综合自己在校期间所学的理论知识,设计开发吃豆子游戏,使自己熟悉应用系统的开发过程,培养独立思考能力,检验学习效果和动手能力,初步掌握软件工程的系统理论,进一步巩固和加强自身对java基础知识的理解,提高自己的编程水平,从而达到理论与实践相结合的目的。
三、总体设计
1.文件构成
吃豆子游戏的程序由文件Wall.java、Gold.java、Player.java、Enemy.java、Ticker.java、和Packman.java六个文件组成。
- Wall.java:包含名为Wall的public类,其主要功能为根据墙的位置,绘制其图形。并通过其中的方法。返回墙壁的位置等属性。
- Gold.java:包含名为Gold的public类,其主要功能为根据豆子的位置,绘制其图形,包括体积大和体积小的两种类型。并通过其中的方法,返回豆子的位置等属性。
- Player.java:包含名为Player的public类,其主要功能为初始化吃豆者的位置,张合角度以及前进速度。通过draw方法根据吃豆者在运动过程中的角度变化,以及移动后的位置坐标绘制吃豆者;通过move方法计算吃豆者的位置;通过ChangeDirection方法改变吃豆者的运动方向;通过stop方法令吃豆者停止运动;通过dead方法令游戏结束。
- Enemy.java:包含名为Enemy的public类,其主要功能为根据位置,状态初始化敌人。通过move方法确定敌人的移动方式,包括正常状态和失去放抗能力两种情况;通过draw方法绘制敌人。
- Ticker.java:包含名为Ticker的线程类,控制游戏的起始。
- Packman.java:包含名为Packman的public类,其主要功能为初始化图形界面的布局,声音的播放,确定游戏规则。
- Pac-Man.html:这是引用Applet的HTML文件。

2.系统功能要求
1 按空格键,使游戏开始。
2 通过方向键控制吃豆者的运动方向,直到吃光所有的金豆子。
3被敌人碰到按百分比掉血。
4吃到大的金豆子后,敌人在一段时间内失去攻击能力,这个时候,吃豆者可以吃掉敌人。
5敌人被吃掉之后被关进图中牢笼中,一段时间重生。
6吃豆人吃到水果后回血,当血量降到百分之零以下游戏结束。

3.类图

三、详细设计
1.Enemy类
1 成员变量
Al_time:int
Colour:int
Enemy:Rectangle
alarm:boolean
alarmTime:int
canMoveUp:boolean
cantGoAnyWhere:boolean
direction:int
gameFlow:int
ghost:boolean
ghostMode:boolean
interval:int
lefttime:int
prisonTime:int
speed:int
Stop:boolean
xPos:int
xVPos:int
yPos:int
yVPos:int
2 方法
Alarm(int):void //设置敌人是否处于反抗状态
Ghost():void //幽灵
draw(Graphics):void //绘制幽灵的颜色
move(int,int,Wall[]):void //敌人的移动
status():int //位置
stop():void //停止移动
3 详细类图

2.Packman类
1 成员变量
SOUND:AudioClip[]
UP_TYPED:bpplean
WALL:Image[]
alarm:boolean
alarmTime:int
gameFlow:int
gameStarted:boolean
gameover:boolean
health:int
levelComplete:boolean
offScreenImage:Image
2 方法
actionPerformed(ActionEvent):void //监听按键
init():void //applet初始化
keyPressed(KeyEvent):void //按下按键
keyReleased(KeyEvent):void //松开按键
keyTyped(KeyEvent):void //释放按键
paint(Graphics):void //绘制轨迹
start():void //开始
stop():void //结束
update(Graphics):void //绘制更新后的轨迹
3 详细类图

3.Player类
1 成员变量
canMoveUp:boolean
dead:boolean
Direction:int
isMoving:boolean
mouthDegree:int
mouthOpen:boolean
Player:Rectangle
Speed:int
xPos:int
xVPos:int
yPos:int
yVPos:int
2 方法
ChangeDirection(int):void // 改变前进方向
Dead():void //死亡
draw(Graphics):void //绘制吃豆者
move(Wall[]):void //吃豆者移动
stop():void //吃豆者停止移动
3 详细类图

4.Ticker类
1 成员变量
is Ticking:boolean
al:ActionListener
delay:int
t:Thread
2 方法
run():void //奔跑
start():void //开始
3 详细类图

5.Wall类
1 成员变量
Indexoflmage:int
Wall:Rectangle
xPos:int
yPos:int
2 详细类图

6.Fruit类
1 成员变量
Al_time1:int
appearTime:int
direction:int
fruit:Rectangle
interval:int
xPos:int
2 方法
draw(Graphics):void //绘制水果的颜色
move(Wall):void //移动水果
3 详细类图

7.Gold类
1 成员变量
gold:Rectangle
goldSpecies:int
xPos:int
2 方法
bigGoid():boolean // 判断是否是大豆子
draw(Graphics):void //根据x、y和豆子的类型构造一个豆子的对象
3 详细类图

四、系统测试
- 1 主界面测试


- 2 游戏界面菜单选项的功能测试
- 点击Applet菜单的测试结果表
|----|:----
吃豆子(Packman)的更多相关文章
- C++小项目-吃豆子游戏
GMap.h #pragma once //保证头文件只被编译一次 #include "stdafx.h" #define MAP_LEN 19 //逻辑地图大小 (逻辑地图由行. ...
- 有趣的动画swf 小鼠吃豆子
今天发现一个有趣的动画swf,小鼠吃豆子,呵呵 <object width="240" height="206" data="http://cd ...
- 九度OJ 1408 吃豆机器人 -- 动态规划
题目地址:http://ac.jobdu.com/problem.php?pid=1408 题目描述: 淘宝公司内部有许多新鲜的小玩具,例如淘宝智能机器人.小时候,大家都玩过那个吃豆子的游戏吧,这机器 ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- [代码]解析nodejs的require,吃豆人的故事
最近在项目中需要对nodejs的require关键字做解析,并且替换require里的路径.一开始我希望nodejs既然作为脚本语言,内核提供一个官方的parser库应该是一个稳定可靠又灵活的渠道,然 ...
- 2845 ACM 豆子 beans
题目:http://acm.hdu.edu.cn/showproblem.php?pid=2845 题意:吃豆子游戏 , 当你吃了一个格子的豆子 , 该格子左右两个和上下两行就不能吃了 , 输入每个格 ...
- [Jobdu] 题目1408:吃豆机器人
题目描述: 淘宝公司内部有许多新鲜的小玩具,例如淘宝智能机器人.小时候,大家都玩过那个吃豆子的游戏吧,这机器人就是按照这个游戏设计的,它会朝着豆子的方向行走.不过机器人还存在一个bug,他只会朝南和朝 ...
- ZLYD团队第三周项目总结
ZLYD团队第三周项目总结 项目进展 我们的吃豆子游戏的程序由八个文件组成:Wall.java.Gold.java.Player.java.Fruit.java.Enemy.java.Ticker.j ...
- JAVA上百实例源码以及开源项目
简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级.中级.高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情.执着,对IT的憧憬. ...
随机推荐
- ruby Errors & Exceptions
When you first started coding, errors were probably the last thing you wanted to see. After all, it’ ...
- HDU 1713 最小公倍数与最大公约数的问题 相遇周期
欢迎参加——BestCoder周年纪念赛(高质量题目+多重奖励) 相遇周期 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/ ...
- 腾讯新浪通过IP地址获取当前地理位置(省份)的接口
腾讯新浪通过IP地址获取当前地理位置(省份)的接口 腾讯的接口是 ,返回数组 http://fw.qq.com/ipaddress 返回值 var IPData = new Array(" ...
- wordpress工作原理
WP初始化的过程:当你输入<yourlink>/wordpress对wordpress进行初始化时,wordpress默认会找根目录下的index.php页面,看一下index.php页面 ...
- Shell编程基础
写之前我们先来搞清楚为什么要学shell,学习要有目的性shell简单.灵活.高效,特别适合处理一些系统管理方面的小问题shell可以实现自动化管理,让系统管理员的工作变得容易.简单.高效shell脚 ...
- JavaScript 使用 sort() 方法从数值上对数组进行排序
使用 sort() 方法从数值上对数组进行排序. <html> <body> <script type="text/javascript"> f ...
- Android 中的selector
今天做程序时,发现了selector 选择器不单单能用系统的自定义属性(比如, <item android:state_selected="true" android:co ...
- DP:Space Elevator(POJ 2392)
太空电梯 题目大意:一群牛想造电梯到太空,电梯都是由一个一个块组成的,每一种块不能超过这个类型的高度,且每一种块都有各自的高度,有固定数量,问最高能造多高. 这题就是1742的翻版,对ai排个序就可以 ...
- Greedy:Packets(POJ 1017)
装箱问题1.0 题目大意:就是一个工厂制造的产品都是正方形的,有1*1,2*2,3*3,4*4,5*5,6*6,高度都是h,现在要包装这些物品,只能用6*6*h的包装去装,问你怎么装才能使箱子打到最小 ...
- codeforces A. Domino 解题报告
题目链接:http://codeforces.com/problemset/problem/353/A 题目意思:通俗地说,就是当上下两半的数的总和不完全是偶数时,通过上下调换某些骨牌来使这两半的数和 ...