2017-2018-1 JaWorld 团队作业--冲刺2 (20162314)

总体架构

  • 我们本次团队项目设定为基于Android系统Java架构下的打飞机小游戏

  • 游戏中所有模型的原型设定是精灵,因此不管是敌机还是战斗机都是精灵类,精灵类是所有类的父类

  • 精灵类(Sprite)下有三个子类,一个是战斗机类,也就是玩家;一个是走直线的精灵类(AutoSprite),也就是对敌机的统称;还有一个是爆炸类,指的是敌机或战斗机被摧毁。

  • 我所负责的是精灵类(Sprite)下的走直线的精灵类(AutoSprite)下的子弹类(Bullet)

精灵类(Sprite)

精灵类是所有其他用于绘制(frame)的类的基类。

整个游戏界面是建立在一张巨大的位图(Bitmap)上的,它的长度和宽度是设定就好的,位图由像素构成,基于像素即可建立笛卡尔直角坐标系。因此战斗机开始,走过,被摧毁爆炸的位置就可以确定,我们通过战斗机走过的距离来为玩家记成绩。

宽度变量是getWidth,高度是getHeight,x和y分别表示战斗机初始位置的横纵坐标,offsetX和offsetY分别表示战斗机爆炸时的位置的横纵坐标,由此可以计算出战斗机走过的总距离。

其中,战斗机的横坐标x到位图x坐标中心点的距离显然是x减去宽度的一半,同理y也是减去高度的一半。

 public void centerTo(float centerX, float centerY) {
float w = getWidth();
float h = getHeight();
x = centerX - w / 2;
y = centerY - h / 2;
}

x是战斗机左边的长度,y是战斗机的高度,那么右边就是x加上宽度,到底部的长度就是y加上高度。

public RectF getRectF() {
float left = x;
float top = y;
float right = left + getWidth();
float bottom = top + getHeight();
RectF rectF = new RectF( left, top, right, bottom );
return rectF;
}

有了java架构下的算法后,接下来的就是把背后的算法表现出来,也就是绘制出来,我们称画(draw)到布(Canvas)上。

Draw需要三部分,游戏开始前的状态beforeDraw,游戏进行中的onDraw和游戏结束后的afterDraw。每部分都需要三要素布(Canvas),Paint(漆)和游戏视图(gameView)。

public final void draw(Canvas canvas, Paint paint, GameView gameView) {
frame++;
beforeDraw( canvas, paint, gameView );
onDraw( canvas, paint, gameView );
afterDraw( canvas, paint, gameView );
}

onDraw需要三个判定条件以确定是在游戏中,战斗机未被摧毁(!destroyed,位图bitmap不为空null,可见状态getvisible)

Draw将精灵Sprite绘制到布Canvas上。

摧毁类包含敌机被摧毁和战斗机被摧毁,摧毁后则位图bitmap为空。

public boolean isDestroyed() {
return destroyed;
} public int getFrame() {
return frame;
}

走直线的精灵类(AutoSprite)

敌机类,只能沿直线直上直下。

其速度为每帧移动的像素数,敌机的速度设定为2,即每帧移动的像素数==2.

战斗机的移动move量=速度speed*Time,Time=gameView。

public class AutoISprite extends ISprite {
//每帧移动的像素数,以向下为正
private float speed = 2; public AutoISprite(Bitmap bitmap) {
super( bitmap );
} public void setSpeed(float speed) {
this.speed = speed;
} public float getSpeed() {
return speed;
}

AutoSprite还内置了一个afterDraw的摧毁方法的扩充,isDestroyed检查Sprite是否超出了Canvas的范围,如果超出,则销毁Sprite。

protected void afterDraw(Canvas canvas, Paint paint, GameView gameView) {
if (!isDestroyed()) {
//检查Sprite是否超出了Canvas的范围,如果超出,则销毁Sprite
RectF canvasRecF = new RectF( 0, 0, canvas.getWidth(), canvas.getHeight() );
RectF spriteRecF = getRectF();
if (!RectF.intersects( canvasRecF, spriteRecF )) {
destroy();

子弹类(Bullet)

子弹是从下向上沿直线移动的。

前面我们用从上往下的speed为正设定了精灵类的速度,因此从下向上的子弹的速度就是负的。

负数表示子弹向上飞

public class Bullet extends AutoISprite {

    public Bullet(Bitmap bitmap) {
super( bitmap );
setSpeed( -10 );//负数表示子弹向上飞
}

明日各个成员的任务安排

  • 陈是奇同学进行博客整理,王译潇同学和张师瑜同学帮其他同学查找相关资料以及提供建议,其余同学完成任务并将已完成的内容进行测试。

2017-2018-1 JaWorld 团队作业--冲刺2的更多相关文章

  1. 2017-2018-1 JaWorld 团队作业--冲刺1

    2017-2018-1 JaWorld 团队作业--冲刺1(20162301) 一.小组分工: 由于小组成员在本周比较忙碌,所以考虑后本组的冲刺就按照每天加入不同的类来完成.我们根据类的难度大小来决定 ...

  2. 2017-2018-1 JaWorld 团队作业--冲刺3

    2017-2018-1 JaWorld 团队作业--冲刺3 (20162306) 总体架构 我们本次团队项目设定为基于Android系统Java架构下的打飞机小游戏 游戏中所有模型的原型设定是精灵,因 ...

  3. 2017-2018-1 JaWorld 团队作业--冲刺4

    2017-2018-1 JaWorld 团队作业--冲刺4 (20162305) 总体架构 我们本次团队项目设定为基于Android系统Java架构下的打飞机小游戏 游戏中所有模型的原型设定是精灵,因 ...

  4. 2017-2018-1 JaWorld 团队作业--冲刺5

    2017-2018-1 JaWorld 团队作业--冲刺5(20162310) 团队项目之战斗机类分析博客 总结 我们本次团队项目设定为基于Android系统Java架构下的打飞机小游戏 游戏中所有模 ...

  5. 2017-2018-1 JaWorld 团队作业--冲刺6

    2017-2018-1 JaWorld 团队作业--冲刺6(20162308) 实现 由于我在冲刺部分负责的是类之间的耦合,所以我就介绍一下本次游戏的总体实现. 我们定义了Sprite类,即精灵类,游 ...

  6. 2017-2018-1 JaWorld 团队作业--冲刺7

    2017-2018-1 JaWorld 团队作业--冲刺7 冲刺博客 冲刺1 冲刺2 冲刺3 冲刺4 冲刺5 项目完成情况 存在的问题 存在的问题是敌机只设置了一种,没能实现多种敌机的游戏设置. 界面 ...

  7. 【2017集美大学1412软工实践_助教博客】团队作业4——第一次项目冲刺(Alpha版本)小组 成绩

    第四次团队作业成绩公布 题目 团队作业4: http://www.cnblogs.com/happyzm/p/6722264.html 团队成绩 成绩公示如下: 检查项 会议内容 代码签入 心得体会或 ...

  8. 【2017集美大学1412软工实践_助教博客】团队作业8——第二次项目冲刺(Beta阶段)

    题目 团队作业8: http://www.cnblogs.com/happyzm/p/6856179.html 团队作业8-1 beta冲刺计划 团队 新加入的成员,担当的角色,技术特点 下一阶段需要 ...

  9. 【2017集美大学1412软工实践_助教博客】团队作业7——Alpha冲刺之事后诸葛亮

    题目 团队作业7: http://www.cnblogs.com/happyzm/p/6827853.html 团队成绩 评分项目 变更管理 设计/实现 测试/发布 团队的角色,管理,合作 总结 全组 ...

随机推荐

  1. sql数据库中如何根据身份证号判断性别

    身份证号有15位和18位的..在sql中该如何判断? I_sex ,) ,) then '男' else '女' END

  2. ubuntu的两种网络连接模式

    ubuntu的网络连接分成两种类型,一种是modern 模式, 这种模式的配置通过ifconfig命令来进行配置,重启之后失效,这种模式就是在destop 下右上角的网络连接.如图所示 modern模 ...

  3. Java多线程详解(三)

    1)死锁 两个线程相互等待对方释放同步监视器时会出现死锁的现象,这时所有的线程都处于阻塞状态,程序无法继续向下执行. 如下就是会出现死锁的程序. 首先flag = 1,线程d1开始执行,锁住对象o1, ...

  4. split()有个坑

    刚才在做DBMS课程设计的时候遇到了一个以前遇到过的问题不过这次我没有一眼认出来,想了好一会才想起来. 就是在用split()方法来分割路径名字符串的时候,比如 String path = “E:\s ...

  5. 图论之最短路径(2)——Bellman-Ford算法

    继续最短路径!说说Bellman—Ford算法 思路:假设起点为s,图中有n个顶点和m个边,那么它到任一点(比如i)的最短路径 最多可以有n-1条(没有回路就是n-1条):因为最短路径中不可能包含回路 ...

  6. C/C++程序编译流程

    单个文件的编译过程 多个文件的编译过程

  7. .net Asp AdRotator(广告控件)

    1.新建项目名称AdRotator 2.右键项目名称添加一个xml文件命名为AdRotator.xml <?xml version="1.0" encoding=" ...

  8. 【Android】Android--Dialog

    前言 对话框对于应用也是必不可少的一个组件,在Android中也不例外,对话框对于一些提示重要信息,或者一些需要用户额外交互的一些内容很有帮助.本篇博客就讲解一下Android下对话框的使用,在本篇博 ...

  9. 解决pip install 安装慢问题

    使用豆瓣源 比如安装pyspark pip install -i https://pypi.douban.com/simple/ pyspark 速度就比用pip install快N倍 关注公众号:

  10. CodeForces 19B Checkout Assistant

    B. Checkout Assistant time limit per test 1 second memory limit per test 256 megabytes input standar ...