C++轮子队-第三周(需求改进&原型设计)
需求改进&原型设计
一.需求完善
(一)系统功能(补充)
图形界面(图片如下图所示:)

根据需求与组内讨论结果,现归纳图形界面方面需要的设计与相应功能:
数据-图形界面中间类:
- 数字方块类 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; // 二维纵坐标
};
- 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)
- 游戏图形引擎 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作准备。具体内容如下:
- 依据项目组能提供的总时间、功能模块的优先级以及模块之间的依赖关系,在Product Backlog中选取待实现的功能项。
 

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

- 以甘特图的方式拟定迭代冲刺计划。
 
五.测试计划
说明:测试将在游戏基本实现后再进行
C++轮子队-第三周(需求改进&原型设计)的更多相关文章
- 拉登是我罩的队_第三周_需求改进&原型设计
		
需求改进&原型设计 1. 需求&原型改进 1.1硬件部分(1) 硬件部分分为主机和遥控器,分别由两个单片机进行控制.(2) 单片机1:负责显示游戏的界面.使用数码管显示当前得分,使用不 ...
 - 宇宙最帅叉叉——第三周博客 for 需求改进&原型设计
		
需求改进&原型设计 Ⅰ. 需求&原型改进 根据组内成员的讨论以及老师和同学的建议,本周进行了以下的改进: 添加注册功能 根据用户图形界面接收的用户账号及密码,客户端将接受内容记录在 ...
 - 莪的拽、像省田各号①样没尽頭队——需求改进&原型设计
		
需求改进&原型设计 1. 需求&原型改进 经过老师的指导以及组内成员的讨论后,我们认为之前的需求分析已经比较准确完备. 根据电子宠物的形象结构特点,以及模拟屏幕的空间限制,我们设计出了 ...
 - 团队作业(HCL队)第三周—需求改进和系统分析
		
2.需求&原型改进: 1.问题:游戏中坦克的移动和攻击怎么控制的? 改进: 在游戏中,我控制我方坦克,按下方向键坦克便向按下的方向移动,按下Z键,我方坦克发射炮弹.敌方坦克面向随机的方向移动, ...
 - 团队作业第3周——需求改进&系统设计
		
目录 团队作业第3周--需求改进&系统设计 1.需求&原型改进 2.系统设计 3.Alpha任务分配计划 4.测试计划 1 测试术语 4.2 有关项目人员组成 2 任务概述 3.测试策 ...
 - 团队作业3-需求改进&原型设计
		
选题:实验室报修系统 实验室设备经常会发生这样或那样的故障,靠值班人员登记设备故障现象,维护人员查看故障记录,进行维修,然后登记维修过程与内容,以备日后复查,用这种方式进行设备运营管理,它仅仅起到一个 ...
 - 缓慢变化维 (Slowly Changing Dimension) 常见的三种类型及原型设计(转)
		
开篇介绍 在从 OLTP 业务数据库向 DW 数据仓库抽取数据的过程中,特别是第一次导入之后的每一次增量抽取往往会遇到这样的问题:业务数据库中的一些数据发生了更改,到底要不要将这些变化也反映到数据仓库 ...
 - C++轮子队-第六周--事后分析
		
C++轮子队 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 实现2048+俄罗斯方块结合的小游戏,定义的比较清楚,典型用户也很清晰,提供给那些对该类游 ...
 - 集美大学网络1413第七次作业成绩(团队三) --需求改进&系统设计
		
题目 团队作业3--需求改进&系统设计 团队作业3成绩 团队/分值 TD BZ GJ CJ SI WBS GS JG DB SS SJ CS DC 总分 1 0.25 0.75 1 0.5 ...
 
随机推荐
- Python3 标准库
			
Python3标准库 更详尽:http://blog.csdn.net/jurbo/article/details/52334345 文本 string:通用字符串操作 re:正则表达式操作 diff ...
 - DP专题·二
			
1.hdu 1260 Tickets 题意:有k个人,售票员可以选择一个人卖,或者同时卖给相邻的两个人.问最少的售票时间. 思路:dp[i] = min(dp[i - 1] + singlep[i], ...
 - 解释一下python中的//,%和**运算符
			
//运算符执行地板除法(向下取整除),它会返回整除结果的整数部分 print(7//2) 这里整除后会返回3.5 同样的,执行取幂运算,ab会返回a的b次方 print(2**10) 最后,%执行取模 ...
 - python中json怎么转换成字典
			
json的标准格式:要求必须 只能使用双引号作为键 或者 值的边界符号,不能使用单引号,而且“键”必须使用边界符(双引号)
 - 集合遍历(Set,List,Map)
			
一.Set遍历 定义一个set Set<String> books = new HashSet<String>(); books.add("Java"); ...
 - Jsoup学习总结
			
Jsoup学习总结 摘要 Jsoup是一款比较好的Java版HTML解析器.可直接解析某个URL地址.HTML文本内容.它提供了一套非常省力的API,可通过DOM,CSS以及类似于jQuery的操作方 ...
 - C# int32与int64的区别 附加:字符字节关系
			
int32 =int int64 =long 1byte=8bit unicode 占2btye int32 占 1 btye long 占 4 btye
 - 【hihocoder】01背包
			
描述 且说上一周的故事里,小Hi和小Ho费劲心思终于拿到了茫茫多的奖券!而现在,终于到了小Ho领取奖励的时刻了! 小Ho现在手上有M张奖券,而奖品区有N件奖品,分别标号为1到N,其中第i件奖品需要ne ...
 - win vista系统的ReadyBoost性能测试
			
如果想提高电脑的性能,大家通常会选择升级处理器.内存或是相关硬件,而新一代Windows Vista操作系统中增加的ReadyBoost功能,号称只需一个USB接口的闪存盘(俗称U盘),就能达到加快系 ...
 - Linux网络配置脚本
			
#!/bin/bash ip=$1 if [ -f "/etc/sysconfig/network-scripts/ifcfg-bond1" ] then break else # ...