【原创】纯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 单一 ...
随机推荐
- oracle数据库、客户端安装以及ps/sql连接和导入表实例
从下面的网址下载http://www.oracle.com/technetwork/database/enterprise-edition/downloads/112010-win32soft-098 ...
- UVALive 5790 Ball Stacking 解题报告
比赛总结 题目 题意: 有n层堆成金字塔状的球,若你要选一个球,你必须把它上面那两个球取了,当然也可以一个不取.求选的球最大的权值和. 题解: 将这堆球转成举行,第一行是(0,0),第二个是(1,0) ...
- POJ1505&&UVa714 Copying Books(DP)
Copying Books Time Limit: 3000MS Memory Limit: 10000K Total Submissions: 7109 Accepted: 2221 Descrip ...
- hdu3790最短路径问题 (用优先队列实现的)
Problem Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的. Inp ...
- Android清理设备内存具体完整演示样例(一)
MainActivity例如以下: package come.on; import android.app.Activity; import android.content.Context; impo ...
- POJ 3589 Number-guessing Game(简单题)
[题目简述]:两个四位数,假设后一个数中的某个数与前一个相应的数的位置和值都相等.则统计数目由几个这种数.记为count1吧. 假设后一个数中的某个数与前一个数的数值相等,但位置不同. 此时这种数的个 ...
- hdu2845(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2845 题意:给你一个n*m的矩阵,每个位置有一定数量的豆子,如果你去map[x][y]位置上的豆子,则 ...
- 【OpenCV新手教程之十三】OpenCV图像金字塔:高斯金字塔、拉普拉斯金字塔与图片尺寸缩放
本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/26157633 作者:毛星云(浅墨) ...
- eval、json.parse()的介绍和使用注意点
原文:eval.json.parse()的介绍和使用注意点 eval和json.parse的使用 eval:来源于官网 定义和用法 eval() 函数可计算某个字符串,并执行其中的的 JavaScri ...
- nginx 301跳转到带www域名方法rewrite(转)
首先一.得在你的域名管理里面定义 test.com和www.test.com指向你的主机ip地址,我们可以使用nslookup命令测试:直接输入 nslookup test.com和nslookup ...