需求改进&原型设计

一.需求完善

(一)系统功能(补充)

图形界面(图片如下图所示:)

根据需求与组内讨论结果,现归纳图形界面方面需要的设计与相应功能:

数据-图形界面中间类:
  1. 数字方块类 NumBlock
  • 方块数字 num,若为0则表示为空方块,在具体的图形界面中不显示

  • 方块数字查看方法 getBlockNum()

  • 方块数字设置方法 setBlockNum()

  • 该方块在棋盘数组中的下标 location,初步定为存储行号、列号的结构体

  • 该方块相对于程序窗口的位置 position ,可能用QPointF实现

  • 方块类声明

class number_block {
public :
number_block() {}
// 以系统时间为种进行随机, difficulty :1 2 3对应只生成2, 24, 248
unsigned int generate_number(int difficulty) {
srand((unsigned)time(NULL));
return 1 << (rand() % difficulty + 1);
}
// 初始化
number_block(int difficulty, bool canBeMove = true, int x = 1, int y = 1) {
is_moving = canBeMove;
this -> x = x;
this -> y = y;
number = generate_number(difficulty);
}
// 修改相应的属性
void modify_x(unsigned int x) {
this -> x = x;
}
void modify_y(unsigned int y) {
this -> y = y;
}
void modify_number(unsigned int number) {
this -> number = number;
}
void modify_is_moving(bool is_moving) {
this -> is_moving = is_moving;
}
// 获取相应属性
unsigned int get_x() {
return x;
}
unsigned int get_y() {
return y;
}
unsigned int get_number() {
return number;
}
unsigned int get_is_moving() {
return is_moving;
}
private :
// 为了维护数据的安全性,私有类成员只允许通过公有借口进行间接访问
bool is_moving; // 移动
unsigned int number; // 数字
unsigned int x; // 二维横坐标
unsigned int y; // 二维纵坐标
};
  1. 5*7棋盘 Board:
  • 二维数组 board[ ][ ] ,以存储哪些方块为空方块、数字方块、下落方块,在具体的代码实现中可能以一级指针的形式声明于类中。

  • 获取二维数组信息的方法 getBoard()

  • 填入二维数组信息的方法 setBoard()

  • 游戏结束条件判断 bool end_judge(number_block* moving_block)

  • 方向键控制方法,参数为按键对应的ascii和指向正在下落块的指针 void control(const unsigned char control_flag, number_block* moving_block)

  • 随时间自动下落 void time_drop(number_block* moving_block)

  1. 游戏图形引擎 2048TetrisEnigine
  • 移动:

    • 左移 moveLeft()
    • 右移 moveRight()
    • 下移 moveDown()
  • “下一个方块”的数据获取 GetNextBlock()

  • 二维数组棋盘的图形映射方法 BoardDisplay()

  • 游戏计时 time

  • 积分记录 score

  • 积分上传方法 scoreUpload() ,将玩家ID与分数一起上传至服务器

  • 获取积分方法 unsigned int return_mark()

界面主窗口与排名界面

窗口分割控件:初定为QSplitter

文字显示: QLabel

按钮控件:QPushButton或QGraphicsItem

游戏界面:

需重写的函数:

  • 按键按一次 keyRelease()
  • 按键长按 keyPress()
  • 图形绘制 paint()

需要的控件:

  • 按钮控件:QPushButton或QGraphicsItem
  • 方块控件:初定为QPixmap或QTransfrom,加载数值方块对应的png,像素尺寸初定为20*20,并根据棋盘类Board的数据定时进行位置更新
  • 退出游戏时的对话框控件:QMessageBox

分数统计

障碍块

难度调整

在线排名

(二)四象限分析法

作用:帮助你清晰定位软件的功能特点和将来要进行研发的创新点,如图所示:

说明:

  • 杀手功能:针对某一应用需求我们的竞争对手和用户已经决定了的必要满足的需求,我们的创新功能也在这一部分。

  • 外围功能:辅助性的功能,比如良好的用户体验界面等。

  • 必要需求:能够准确解决用户主要功能的需求,比如游戏中的控制计分等功能。

  • 辅助需求:非必要需求,比如更改界面风格,增加背景音乐等功能。


解决方法:

  • 维持----以最低成本维持此功能

  • 抵消----快速地达到“足够好”、“和竞争对手差不多”

  • 优化----花大力气做到并保持行业最好

  • 差异化----产生同类产品比不了的功能或优势

  • 不做----砍掉一个功能,有时我们不需要做所有的功能

(三)进度计划(WBS,Work Breakdown Structure)

二.原型改进

三.系统设计

(一)架构设计

framwork_base.h

游戏结束条件判断

 bool end_judge(number_block* moving_block);

方向键控制方法

void control(const unsigned char control_flag, number_block* moving_block);

定义了框架内每个方块的元素类型

struct framework_block_item
{
number_block* block;
bool is_none;
bool is_uncombined;
};

number_block.h

以系统时间为种进行随机生成数字块的数值

number_block() {}
// 以系统时间为种进行随机, difficulty :1 2 3对应只生成2, 24, 248
unsigned int generate_number(int difficulty) {
srand((unsigned)time(NULL));
return 1 << (rand() % difficulty + 1);
}

初始化数字块

 number_block(int difficulty, bool canBeMove = true, int x = 1, int y = 1) {
is_moving = canBeMove;
this -> x = x;
this -> y = y;
number = generate_number(difficulty);
}

修改数字块相应的属性

 void modify_x(unsigned int x) {
this -> x = x;
}
void modify_y(unsigned int y) {
this -> y = y;
}
void modify_number(unsigned int number) {
this -> number = number;
}
void modify_is_moving(bool is_moving) {
this -> is_moving = is_moving;
}

获取数字块相应属性

unsigned int get_x() {
return x;
}
unsigned int get_y() {
return y;
}
unsigned int get_number() {
return number;
}
unsigned int get_is_moving() {
return is_moving;
}

suitiation_judgement.h

超出上界和填满空格判断

bool framework::end_judge(number_block* moving_block)

{

unsigned int current_x = moving_block->get_x();

unsigned int current_y = moving_block->get_y();

//超出上界判断
if ((this->game_blocks[current_x][current_y - 1].is_none == false) && current_y == column - 1)
{
return true;
} //填满空格判断
for (current_y = 0; current_y < row; ++current_y)
{
for (current_x = 0; current_x < column; ++current_x)
{
if (game_blocks[current_y][current_x].is_none)
{
return false;
}
}
}
if (current_y == row && current_x == column)
{
return true;
}

控制数字块左移

case 75://方向左

{

if (current_x == 0)//

{//边界判断

return;

}

    if (!this->game_blocks[current_y][current_x - 1].is_none || this->game_blocks[current_y][current_x - 1].is_uncombined)
{//左侧块为空块或为障碍块
return;
} game_blocks[current_y][current_x].is_none = true;
game_blocks[current_y][current_x - 1].is_none = false;
game_blocks[current_y][current_x - 1].block = moving_block;
moving_block->modify_x(current_x - 1);
}
break;

控制数字块右移

case 77://方向右
{
if (current_x == this->column - 1)
return;
else if (!this->game_blocks[current_y][current_x + 1].is_none || this->game_blocks[current_y][current_x + 1].is_uncombined)
{//右侧块不为空或为障碍块
return;
}
this->game_blocks[current_y][current_x].is_none = true;
this->game_blocks[current_y][current_x + 1].is_none = false;
this->game_blocks[current_y][current_x + 1].block = moving_block;
moving_block->modify_x(current_x + 1);
}
break;

控制数字块下移

case 80://方向下
{
int tmp = 0;
if (current_y == 0)
{
return;
}
if (!this->game_blocks[current_y - 1][current_x].is_none || this->game_blocks[current_y - 1][current_x].is_uncombined)
{
return;
}
while (!this->game_blocks[tmp][current_x].is_none)
{
tmp++;
}
this->game_blocks[tmp][current_x].is_none = false;
this->game_blocks[tmp][current_x].is_uncombined = false;
this->game_blocks[tmp][current_x].block = moving_block;
this->game_blocks[current_y][current_x].is_none = true;
moving_block->modify_y(tmp);
}
break;

(二)数据库设计

四.Alpha任务分配计划

召开迭代计划会议,为下周进入Sprint作准备。具体内容如下:

  1. 依据项目组能提供的总时间、功能模块的优先级以及模块之间的依赖关系,在Product Backlog中选取待实现的功能项。

  1. 对已选择的功能项再做进一步分解,分解为1-10小时左右的任务,构成Sprint Backlog。在PM的协助下,编码的同学对任务进行认领。

  1. 以甘特图的方式拟定迭代冲刺计划。

五.测试计划

说明:测试将在游戏基本实现后再进行

C++轮子队-第三周(需求改进&原型设计)的更多相关文章

  1. 拉登是我罩的队_第三周_需求改进&原型设计

    需求改进&原型设计 1. 需求&原型改进 1.1硬件部分(1) 硬件部分分为主机和遥控器,分别由两个单片机进行控制.(2) 单片机1:负责显示游戏的界面.使用数码管显示当前得分,使用不 ...

  2. 宇宙最帅叉叉——第三周博客 for 需求改进&原型设计

    需求改进&原型设计 Ⅰ. 需求&原型改进 根据组内成员的讨论以及老师和同学的建议,本周进行了以下的改进: 添加注册功能   根据用户图形界面接收的用户账号及密码,客户端将接受内容记录在 ...

  3. 莪的拽、像省田各号①样没尽頭队——需求改进&原型设计

    需求改进&原型设计 1. 需求&原型改进 经过老师的指导以及组内成员的讨论后,我们认为之前的需求分析已经比较准确完备. 根据电子宠物的形象结构特点,以及模拟屏幕的空间限制,我们设计出了 ...

  4. 团队作业(HCL队)第三周—需求改进和系统分析

    2.需求&原型改进: 1.问题:游戏中坦克的移动和攻击怎么控制的? 改进: 在游戏中,我控制我方坦克,按下方向键坦克便向按下的方向移动,按下Z键,我方坦克发射炮弹.敌方坦克面向随机的方向移动, ...

  5. 团队作业第3周——需求改进&系统设计

    目录 团队作业第3周--需求改进&系统设计 1.需求&原型改进 2.系统设计 3.Alpha任务分配计划 4.测试计划 1 测试术语 4.2 有关项目人员组成 2 任务概述 3.测试策 ...

  6. 团队作业3-需求改进&原型设计

    选题:实验室报修系统 实验室设备经常会发生这样或那样的故障,靠值班人员登记设备故障现象,维护人员查看故障记录,进行维修,然后登记维修过程与内容,以备日后复查,用这种方式进行设备运营管理,它仅仅起到一个 ...

  7. 缓慢变化维 (Slowly Changing Dimension) 常见的三种类型及原型设计(转)

    开篇介绍 在从 OLTP 业务数据库向 DW 数据仓库抽取数据的过程中,特别是第一次导入之后的每一次增量抽取往往会遇到这样的问题:业务数据库中的一些数据发生了更改,到底要不要将这些变化也反映到数据仓库 ...

  8. C++轮子队-第六周--事后分析

    C++轮子队 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 实现2048+俄罗斯方块结合的小游戏,定义的比较清楚,典型用户也很清晰,提供给那些对该类游 ...

  9. 集美大学网络1413第七次作业成绩(团队三) --需求改进&系统设计

    题目 团队作业3--需求改进&系统设计 团队作业3成绩  团队/分值 TD BZ GJ CJ SI WBS GS JG DB SS SJ CS DC 总分  1 0.25 0.75 1 0.5 ...

随机推荐

  1. Android图片加载框架Picasso最全使用教程4

    通过前几篇的学习,我们已经对Picasso的加载图片的用法有了很深的了解,接下来我们开始分析Picasso为我们提供的其他高级功能及内存分析,Let’sGo ! Picasso进行图片的旋转(Rota ...

  2. path的join和resolve的使用区别

    文章目录   1.连接路径:path.join([path1][, path2][, ...]) 2.路径解析:path.resolve([from ...], to) 3.对比 1.连接路径:pat ...

  3. hibernate 一对多、多对多的配置

    一对多 <class name="Question" table="questions" dynamic-insert="true" ...

  4. cmd 命令 记忆

    1,“开始”—>“运行”,输入cmd,回车.<或 win+R> 2,出现“命令提示符”的窗口,一般情况下是 C:\Documents and Settings\Administrat ...

  5. Windows Server 2008 R2 FTP无法从外部访问的解决方法

    在Windows Server 2008 R2中配置好FTP服务器后,可以在本机访问,但是无法从另一台电脑访问.原因就是在于防火墙没有配置好. 1.首先检查服务器管理器中的入站规则,确保已启用FTP服 ...

  6. 构造函数与super

    1. 当不定义构造方法,系统会为类隐式的创建一个空的无参构造方法 2. 当类定义了有参的构造方法,系统就不会为类创建无参构造方法 3. 子类中,若不显式调用super(), super()会被隐式调用 ...

  7. String创建方式的区别

    String str0 = "abc"; String str1 = new String("abc"); 第一句执行后,会在String pool中创建一个& ...

  8. camera corder profile

    /system/etc/ 其中的qulity high 必须与 最大的支持的分辨率相同. 不然cts 不过. 这里的配置必须在报告给app的数据匹配.

  9. ==和equals在比较字符串时候的区别

    作为一个菜鸟  之前一直迷茫 都说比较字符串要用equals()方法  但是有时候用==貌似也可以  话不多说  先来一个例子 public static void main(String[] arg ...

  10. 怎样发布一个工程到自己的GitHub

    本人小白一枚: 第一次通过命令行的形式将自己的工程发布到自己的GitHub上去,还是请教了大神之后才完成的.通过总结经验,小白也掌握了一些关于往代码托管平台上发布工程的方式,其实只要用心学,里面的东西 ...