【原创】纯OO:从设计到编码写一个FlappyBird (四)
第三部分请点这里
这里来实现Obstacle类。其实flappybird的本质就是小鸟原地掉,然后几根柱子在走。这也是在Game类里,用obs.move()来实现游戏逻辑的原因。
我们首先必须确定几个数据。
0、柱子之间的间隙
1、柱子的最小值和最大值
2、柱子之间的间距
3、柱子的宽度
在屏幕高度确定的情况下,只要我们确定了上半部分的柱子的高度,那么根据间隙,就能画出两个柱子。(tip:做个减法而已)
因此,一个障碍需要两个数据来标示:
0、x值
1、高度
而move的实现,就是x的递减。
还需要实现一个重要的功能,就是 柱子的添加和删除。我们必须要决定,何时删除一个既有的柱子,并且何时添加一个新的柱子。
但是在那以前,我们必须要决定使用什么数据结构来储存柱子。
容易发现,柱子的动态添加和删除有先进先出的性质,那么自然就是实现了Queue接口的LinkedList了。
那么我们何时添加一个柱子?
答:当最后一个柱子,和最右距离差一个柱子间间隙的时候。
何时删除一个柱子:
答:当第一个柱子的x值加宽度小于0时。
注意:Judge类需要和Obstacle公用LinkedList,要不然没法算分。。这个耦合度还得在下一次重构中好好想想怎么解决。。
Obstacle类的全部代码:
import javax.swing.*;
import java.util.LinkedList;
import java.awt.*;
import java.awt.event.*; public interface Obstacle {
public void move();
public LinkedList<Pillar> getObstacles();
} class SimpleObstacle implements Obstacle {
private static final int SPEED = 2;
public LinkedList<Pillar> pillar = new LinkedList<Pillar> ();
int border; SimpleObstacle(int border)
{
this.border = border;
init();
} private static int getRandomHeight()
{
int res = (int)(Math.random() * (Pillar.getHeiLmt() - 100) + 100);
return res;
} private void init()
{
pillar.add(new Pillar(this.border,getRandomHeight()));
} public LinkedList<Pillar> getObstacles()
{
return pillar;
} public void move()
{
boolean del = false;
for (Pillar p : pillar)
{
p.setX(p.getX() - SPEED);
if (p.getX() + Pillar.getWidLmt() <= 0)
del = true;
}
if (del)
pillar.remove();
Pillar tmp = pillar.getLast();
if (tmp.getX() + Pillar.getWidLmt() + Pillar.getWidGap() <= border)
pillar.add(new Pillar(this.border,getRandomHeight()));
}
} class Pillar {
int height;
int x;
private static final int WIDGAP = 200;
private static final int HEIGAP = 150;
private static final int WIDLMT = 100;
private static final int HEILMT = 300;
Pillar(int x,int height)
{
this.x = x;
this.height = height;
} public void setX(int x)
{
this.x = x;
} public int getX()
{
return x;
} public int getHeight()
{
return height;
} public static int getWidGap()
{
return WIDGAP;
} public static int getHeiGap()
{
return HEIGAP;
} public static int getWidLmt()
{
return WIDLMT;
} public static int getHeiLmt()
{
return HEILMT;
}
}
【原创】纯OO:从设计到编码写一个FlappyBird (四)的更多相关文章
- 【原创】纯OO:从设计到编码写一个FlappyBird (一)
说起来,自学计算机也有2年多的时间了,自己还没有从设计到编码,完完整整的设计一个基于面向对象的软件的经历..囧 于是,就有了这个系列.首先选用的语言是Java,没别的原因,HeadFirst设计模式是 ...
- 【原创】纯OO:从设计到编码写一个FlappyBird (六)
第五部分请看这里 终于到了最后一个部分了! 这里使用SimpleJudge类来实现Judge接口. 首先是SimpleJudge需要的实例变量: 0.final LinkedList<Pilla ...
- 【原创】纯OO:从设计到编码写一个FlappyBird (五)
第四部分请点这里 本文将实现DrawBoard. 如前文所述,Obstacle类和Bing类仅仅提供给DrawBoard必要的信息,如何绘制则完全委托给了DrawBoard,也就是说游戏关键类的细节和 ...
- 【原创】纯OO:从设计到编码写一个FlappyBird (三)
第二部分请点这里 下面首先来实现Bing接口! 实现Bing接口的类取名SimpleBing. 容易发现,SimpleBing类总的来说要向下,但点击一下又得向上,向上到了一定界限又得向下,但我们又只 ...
- 【原创】纯OO:从设计到编码写一个FlappyBird (二)
第一部分请点这里. 续结前文,本文将实现Game类. 首先是实例变量.由上次的类图可以看出,Game类首先得具有如下实例变量: 0.Judge judge;1.SimpleDraw draw; // ...
- Qt 利用XML文档,写一个程序集合 四
接上一篇https://www.cnblogs.com/DreamDog/p/9214067.html 启动外部程序 这里简单了,直接上代码吧 connect(button,&MPushBut ...
- 后端开发实践系列之二——领域驱动设计(DDD)编码实践
Martin Fowler在<企业应用架构模式>一书中写道: I found this(business logic) a curious term because there are f ...
- 领域驱动设计(DDD)编码实践
写在前面 Martin Fowler在<企业应用架构模式>一书中写道: I found this(business logic) a curious term because there ...
- 【设计模式系列】之OO面向对象设计七大原则
1 概述 本章叙述面向向对象设计的七大原则,七大原则分为:单一职责原则.开闭原则.里氏替换原则.依赖倒置原则.接口隔离原则.合成/聚合复用原则.迪米特法则. 2 七大OO面向对象设计 2.1 单一 ...
随机推荐
- Python逐块读取大文件行数的代码 - 为程序员服务
Python逐块读取大文件行数的代码 - 为程序员服务 python数文件行数最简单的方法是使用enumerate方法,但是如果文件很大的话,这个方法就有点慢了,我们可以逐块的读取文件的内容,然后按块 ...
- JAVA必备——13个核心规范
标准的价值: 你听过这句话吗?"一流企业做标准.二流企业做品牌.三流企业做产品!"我时我就在想,做标准的企业就是一流的?卖产品就是三流公司?而坐产品或者加工的公司,即使说销售量非常 ...
- SRM 638 Div2
2333... 因为TC过少的参与者.加上不断fst 我掉了div2该. 幸运的是完成的背div1该.. 250 水的问题 500 水的问题.. 直接bfs扩展即可了 注意判重. 我还用康托展开了真 ...
- 盒子游戏(The Seventh Hunan Collegiate Programming Contest)
盒子游戏 有两个相同的盒子,其中一个装了n个球,另一个装了一个球.Alice和Bob发明了一个游戏,规则如下:Alice和Bob轮流操作,Alice先操作.每次操作时,游戏者先看看哪个盒子里的球的数目 ...
- B. 沙漠之旅(分组背包)
B. 沙漠之旅 Time Limit: 1000ms Case Time Limit: 1000ms Memory Limit: 65536KB 64-bit integer IO format: % ...
- python socket编程实现的简单tcp迭代server
与c/c++ socket编程对照见http://blog.csdn.net/aspnet_lyc/article/details/38946915 server: import socket POR ...
- poj3984(经典dfs)
题目链接:http://poj.org/problem?id=3984 分析:直接深搜从起点到终点,如何取最短路线,其实只要优先向下或向右走即可. #include <cstdio> #i ...
- H3C TE老版本OSPF正确配置
R1配置: ---------------------------------------------------- # sysname RT1# super password level 3 cip ...
- SE 2014年4月17日
描述BGP路由属性 MED.首选值 的特点 MED相当于IGP协议中的度量值,在其他条件相同时,当本自治系统有多条到达外部自治系统的链路时,MED值小的路由优选.MED属性只能在两个自治系统间传递. ...
- thinkphp框架相关研究(一)
小编最近开始正式研究thinkphp框架,在此写下研究的整个历程,从最最基本的搭建网站开始,一步步记录.希望对大家有所帮助. 1.菜鸟从下载框架到建站 参考网址:http://blog.csdn.ne ...