项目需求:游戏等级6级,随机字符串每级长度不同。每升一级减少比较次数,但是字符串长度相应增加!每级总分数不同,如果游戏中途输入错误则游戏退出!玩家每次在规定时间内输入字符串的同时,打印出游戏难度等级、当年难度下的游戏积分、输出用时。

根据需求抽象出三个类:Game、Player、Level.

Level类:

public class Level {

private int levelNo;// 各级别编号  private int strLength;// 各级别一次输出字符串的长度

private int strTimes;// 各级别输出字符串的次数  private int timeLimit;// 各级别闯关的时间限制

private int perScore;// 各级别正确输入一次的得分

//此处省略封装字段的Setter和Getter访问器

//Level的带参构造函数

public Level(int levelNo,int strLength,int strTimes,int timeLimit,int perScore){

this.levelNo=levelNo;   this.strLength=strLength;   this.strTimes=strTimes;   this.timeLimit=timeLimit;   this.perScore=perScore;

}

}

定义一个辅助类里面放一个静态数组程序编译时自动在内存级别赋值

public class LevelParam {
     public final static Level[] levels=new Level[6];//对应6个级别

//静态代码块
     static{
      levels[0]=new Level(1,2,10,30,1);//赋值顺序依次为:级别编号、各级别一次输出字符串的长度、输出字符串的次数、各级别闯关的时间限制、正确输入一次的得分
      levels[1]=new Level(2,3,9,26,2);
      levels[2]=new Level(3,4,8,22,5);
      levels[3]=new Level(4,5,7,17,8);
      levels[4]=new Level(5,6,6,15,10);
      levels[5]=new Level(6,7,5,12,15);
     }    
}

Game类:

private Player player; // 玩家省略Setter、Getter

定义一个方法用来:输出指定级别规定长度的字符串。

public String printStr() {
  int strLength = LevelParam.levels[player.getLevelNo() - 1].getStrLength();   //游戏等级编号-1=此等级在数组里的下标(也就定位到此等级本身了)
  StringBuffer buffer=new StringBuffer();    //StringBuffer每次修改字符串本身,效率比String要高。
  Random ran=new Random();
  for (int i = 0; i < strLength; i++) {  //按照指定级别的规定字符串长度本身循环
   int rand=ran.nextInt(strLength);
   switch (rand) {
   case 0:
    buffer.append(">");
      break;
   case 1:
    buffer.append("<");
    break;
   case 2:
    buffer.append("*");
    break;
   case 3:
    buffer.append("&");
    break; 
   case 4:
    buffer.append("%");
    break;
   case 5:
    buffer.append("#");
    break;
   default:
    break;
   }
  }
  //输出字符串
  System.out.println(buffer);
  //返回字符串用于和玩家输入相比较
  return buffer.toString();
 }

定义一个比较字符串输出结果的方法:

public void printResult(String out, String in) {    //out为输出字符串、int为用户输入字符串
        boolean flag;
        if(out.equals(in)){
         flag=true;
        }else{
         flag=false;
        }
        //1.如果输入正确
        if(flag){
         long currentTime=System.currentTimeMillis();   //System.currentTimeMillis()获得自1970-01-01 00:00:00.000到当前系统时刻的时间距离,以毫秒为单位
         //如果超时
         if((currentTime-player.getStartTime())/1000>LevelParam.levels[player.getLevelNo()-1].getTimeLimit()){//输入时间/1000为妙,大于规定时间
          System.out.println("你输入太慢了,已经超时,退出!");                  
          System.exit(1);
          /**
           * 这个方法是用来结束当前正在运行总的java虚拟机
           * 如果status是非零参数,那么表示是非正常退出。
           * System.exit(0)是将你的整个虚拟机里德内容都停掉了,而
           * dispose()只是关闭这个窗口,但是并没有停止整个application
           * exit().无论如何,内容都释放了!也就是说连JVM都关闭了,
           * 内存里根本不可能还有东西!System.exit(status)不管status为何值
           * 都会退出程序。和return相比有以下不同点:return是回到上一层,
           * 而System.exit(status)是回到最上层
           * System.exit(1)一般放在case块中,表示这个程序是非正常退出
           */         
         }else{
          //计算当前积分
          player.setCurrScore(player.getCurrScore()+LevelParam.levels[player.getLevelNo()-1].getPerScore());
          //计算已用时间
          player.setElapsedTime((int)((currentTime-player.getStartTime())/1000));
          //输出当前积分、当前级别、已用时间
          System.out.println("输入正确,您的级别"+player.getLevelNo()+",您的积分"+player.getCurrScore()+",已用时间"+player.getElapsedTime()+"秒。");
          //判断用户是否已经闯过最后一关
          if(player.getLevelNo()==6){
           //计算闯关分数
           int score=LevelParam.levels[player.getLevelNo()-1].getPerScore()*LevelParam.levels[player.getLevelNo()-1].getStrTimes();
           if(player.getCurrScore()==score){
            System.out.println("你已闯关成功,成为绝世高手,恭喜你!!!");
            System.exit(0);
           }
          }
         }        
        }else{//如果输入错误
         System.out.println("输入错误,退出!");
         System.exit(1);
        }       
 }

Player类:

private int levelNo;// 当前级别号
 private int currScore;// 当前级别积分
 private long startTime=0;// 当前级别开始时间
 private int elapsedTime;// 当前级别已用时间

//省略封装字段

定义一个玩游戏的方法
 public void play(){
  Game game=new Game(this);    //直接把当前player类当参数传进游戏的构造函数里
  Scanner input=new Scanner(System.in);
  //外层循环,循环一次,级别升一级
  for (int i= 0; i < LevelParam.levels.length; i++) {
   //升级
   this.levelNo+=1;
   //升级后计时清零,积分清零
   this.startTime=System.currentTimeMillis();
   this.currScore=0;
   //内层循环,循环一次完成一次字符串的输出、输入、比较
   for (int j = 0; j < LevelParam.levels[levelNo-1].getStrTimes(); j++) {
    //游戏输出字符串
    String out=game.printStr();
    //接收用户输入
    String in=input.next();
    //游戏判断玩家输入是否正确,并输出相应结果信息
    game.printResult(out, in);
   }
  }
 }

测试类New 出一个玩家.Player就OK了,整个项目完成!

JavaOOP QuickHit项目分析的更多相关文章

  1. 【QuickHit项目实例】

    关于java面向对象QuickHit项目实例 Game类:用来得到随机出现的字符串(随机打印的字符串,然后玩家进行输入字符串) public class Game { private String s ...

  2. iOS项目分析及优化

    iOS项目分析及优化  来源:吴白的简书   从代码看一个程序员的笔力 从代码的整洁度上就可以看出一个程序员的实力,规范其实就是让你养成一种良好习惯的标杆,在此面前我们应该顺从.本篇我们以OC为例,统 ...

  3. QuickHit游戏

    一 项目需求 根据输入速率和正确率将玩家分为不同级别,级别越高,一次显示的字符数越多,玩家正确输入一次的得分也越高.如果玩家在规定时间内完成规定次数的输入,正确率达到规定要求,则玩家升级(为了简单起见 ...

  4. 项目分析_xxoo-master

    项目介绍:使用java1.5的原生xml操作类实现 对象<-->xml字符串的相互转化 项目分析:主要分为是三个部分 1.容器类:AbstractContainer         存储x ...

  5. 第五章项目:QuickHit

    需求概述: 根据输入速率和正确率将玩家分为不同级别,级别越高,一次显示的字符数越多,玩家正确输入一次的得分也越高.如果玩家在规定时间内完成规定次数的输入,正确率达到规定要求,则玩家升级(为了简单起见, ...

  6. 05章项目: QuickHit快速击键

    一.项目分析 根据输入速率和正确率将玩家分为不同等级,级别越高,一次显示的字符数越多,玩家正确输入一次的得分也越高.如果玩家在规定时间内完成规定次数的输入,正确率达到规定要求,则玩家升级.玩家最高级别 ...

  7. JavaOOP 试题

    1) 以下属于OOP的特征有().   a)继承   b)封装   c)多态   d)隐藏   2) JavaOOP中的多态包括()   a) 方法重写 b) 方法重载   c) 方法隐藏 d) 以上 ...

  8. Quickhit快速击键

    一.项目分析 根据输入速率和正确率将玩家分为不同等级,级别越高,一次显示的字符数越多,玩家正确输入一次的得分也越高.如果玩家在规定时间内完成规定次数的输入,正确率达到规定要求,则玩家升级.玩家最高级别 ...

  9. 【项目分析】利用C#改写JAVA中的Base64.DecodeBase64以及Inflater解码

    原文:[项目分析]利用C#改写JAVA中的Base64.DecodeBase64以及Inflater解码 最近正在进行项目服务的移植工作,即将JAVA服务的程序移植到DotNet平台中. 在JAVA程 ...

随机推荐

  1. js判断ie版本号

     jQuery 2.0 去除了对浏览器版本号的判断(它推荐特性检测),这里是一个老外写的原生判断方法,这段代码着实巧妙!既简介.有向后兼容!一般做法都是:正则搜索 USER_AGENT :但因为历史原 ...

  2. Java高级之类结构的认识

    本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! Java体系包括,各种版本的虚拟机,可执行文件,各种第三方类库,Java API类库,Java语言 ...

  3. AMQP协议

    当前各种应用大量使用异步消息模型,并随之产生众多消息中间件产品及协议,标准的不一致使应用与中间件之间的耦合限制产品的选择,并增加维护成本. AMQP是一个提供统一消息服务的应用层标准协议,基于此协议的 ...

  4. 【Java 进阶篇】【第二课】异常处理

    概念 异常处理的存在是为了:   允许程序员跳过无法处理的问题,继续开发后续的工作,或根据异常做出更加聪明的处理方式. Java中存在一类对象叫“异常对象”. 当异常情况发生时,就会暗战预先的设定,抛 ...

  5. H264(NAL简介与I帧判断)

    1.NAL全称Network Abstract Layer, 即网络抽象层.         在H.264/AVC视频编码标准中,整个系统框架被分为了两个层面:视频编码层面(VCL)和网络抽象层面(N ...

  6. Nmap 網路診斷工具基本使用技巧與教學

    Nmap 是一個開放原始碼的網路掃描與探測工具,可以讓網路管理者掃描整個子網域或主機的連接埠等,功能非常強大. Nmap(Network Mapper)是一個開放原始碼的網路檢測工具,它的功能非常強大 ...

  7. ajax处理回调函数,用ajax向后台发送数据

    这是我的后台返回给前台的数据: 处理后台返回的数据有一下两种方式: function sethouse_housing_pattern(housing_pattern){ var str=[]; va ...

  8. cp 命令(转)

    cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一.一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数.但是如果是 ...

  9. Linux就这个范儿 第19章 团结就是力量 LSB是Linux标准化基地(Linux Standards Base)的简称

    Linux就这个范儿 第19章 团结就是力量  LSB是Linux标准化基地(Linux Standards Base)的简称 这个图片好可爱,它是LSB组织的图标.你肯定会问:“图标这么设计一定有说 ...

  10. 30天,APP创业从0到1【7.26苏州站】

    活动概况 时间:2015年7月26日13:30-16:30 地点:创客巢(苏州吴中区玉山路646号金枫广告产业园B栋4楼) 主办:APICloud.融云.鱼多多 网址:www.apicloud.com ...