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)的更多相关文章

  1. C++小项目-吃豆子游戏

    GMap.h #pragma once //保证头文件只被编译一次 #include "stdafx.h" #define MAP_LEN 19 //逻辑地图大小 (逻辑地图由行. ...

  2. 有趣的动画swf 小鼠吃豆子

    今天发现一个有趣的动画swf,小鼠吃豆子,呵呵 <object width="240" height="206" data="http://cd ...

  3. 九度OJ 1408 吃豆机器人 -- 动态规划

    题目地址:http://ac.jobdu.com/problem.php?pid=1408 题目描述: 淘宝公司内部有许多新鲜的小玩具,例如淘宝智能机器人.小时候,大家都玩过那个吃豆子的游戏吧,这机器 ...

  4. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  5. [代码]解析nodejs的require,吃豆人的故事

    最近在项目中需要对nodejs的require关键字做解析,并且替换require里的路径.一开始我希望nodejs既然作为脚本语言,内核提供一个官方的parser库应该是一个稳定可靠又灵活的渠道,然 ...

  6. 2845 ACM 豆子 beans

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2845 题意:吃豆子游戏 , 当你吃了一个格子的豆子 , 该格子左右两个和上下两行就不能吃了 , 输入每个格 ...

  7. [Jobdu] 题目1408:吃豆机器人

    题目描述: 淘宝公司内部有许多新鲜的小玩具,例如淘宝智能机器人.小时候,大家都玩过那个吃豆子的游戏吧,这机器人就是按照这个游戏设计的,它会朝着豆子的方向行走.不过机器人还存在一个bug,他只会朝南和朝 ...

  8. ZLYD团队第三周项目总结

    ZLYD团队第三周项目总结 项目进展 我们的吃豆子游戏的程序由八个文件组成:Wall.java.Gold.java.Player.java.Fruit.java.Enemy.java.Ticker.j ...

  9. JAVA上百实例源码以及开源项目

    简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级.中级.高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情.执着,对IT的憧憬. ...

随机推荐

  1. ruby Errors & Exceptions

    When you first started coding, errors were probably the last thing you wanted to see. After all, it’ ...

  2. HDU 1713 最小公倍数与最大公约数的问题 相遇周期

    欢迎参加——BestCoder周年纪念赛(高质量题目+多重奖励) 相遇周期 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/ ...

  3. 腾讯新浪通过IP地址获取当前地理位置(省份)的接口

    腾讯新浪通过IP地址获取当前地理位置(省份)的接口  腾讯的接口是 ,返回数组 http://fw.qq.com/ipaddress 返回值 var IPData = new Array(" ...

  4. wordpress工作原理

    WP初始化的过程:当你输入<yourlink>/wordpress对wordpress进行初始化时,wordpress默认会找根目录下的index.php页面,看一下index.php页面 ...

  5. Shell编程基础

    写之前我们先来搞清楚为什么要学shell,学习要有目的性shell简单.灵活.高效,特别适合处理一些系统管理方面的小问题shell可以实现自动化管理,让系统管理员的工作变得容易.简单.高效shell脚 ...

  6. JavaScript 使用 sort() 方法从数值上对数组进行排序

    使用 sort() 方法从数值上对数组进行排序. <html> <body> <script type="text/javascript"> f ...

  7. Android 中的selector

    今天做程序时,发现了selector 选择器不单单能用系统的自定义属性(比如,  <item android:state_selected="true" android:co ...

  8. DP:Space Elevator(POJ 2392)

    太空电梯 题目大意:一群牛想造电梯到太空,电梯都是由一个一个块组成的,每一种块不能超过这个类型的高度,且每一种块都有各自的高度,有固定数量,问最高能造多高. 这题就是1742的翻版,对ai排个序就可以 ...

  9. Greedy:Packets(POJ 1017)

    装箱问题1.0 题目大意:就是一个工厂制造的产品都是正方形的,有1*1,2*2,3*3,4*4,5*5,6*6,高度都是h,现在要包装这些物品,只能用6*6*h的包装去装,问你怎么装才能使箱子打到最小 ...

  10. codeforces A. Domino 解题报告

    题目链接:http://codeforces.com/problemset/problem/353/A 题目意思:通俗地说,就是当上下两半的数的总和不完全是偶数时,通过上下调换某些骨牌来使这两半的数和 ...