结对项目之需求分析与原型设计

结对项目之需求分析与原型设计

031402317 李佳恺

031402511 黄家俊

这是我们两个人第一次合作,虽然结对是栋哥帮我们分配的,并且一开始我们就认识,但是也很开心有这个机会能一起合作完成任务。

  • 初步分工我负责随笔,家俊负责原型设计

  • 以下是原型设计完成后我们一起完善细节的照片

需求分析

在阅读《构建之法》以及分析了客户的现实困扰之后,下面我们将提出我们项目的NABCD模型。

N(Need)

  • 客户需要简化信息收集的过程
  • 客户需要能够实现学生与老师之间的双向选择
  • 每个学生必须被分配到有且只有一个导师
  • 尽量减少学生被分到非志愿的老师的情况

A(Approach)

我们决定开发一个安卓端的导师选择系统,首先代码的学习可以配合接下去我们各自小组的项目,并且能更有效率更有质量地完成这个系统。

  • 学生和导师都可以登录这个系统,实现学生选择导师或者导师选择学生
  • 学生和导师可以在系统上完善自己的个人信息
  • 学生和导师可以在系统上了解自己想要的导师或者学生的信息
  • 学生选择导师的时候需要填写五个志愿,老师在选择学生的时候,根据学生的志愿,志愿靠前的老师优先选择学生
  • 登录系统后学生和老师都可以看到最新的教务处的通知,有助于学生和导师了解学校最新的动态

B(Benefit)

  • 简化信息收集的过程,系统直接统计学生的导师选择情况并直接反馈给导师
  • 学生导师之间可以互相了解,个人信息的完善可以向对方体现个人的优点
  • 系统操作简单,功能实用

C(Competitors)

优势:功能具有针对性,为广大师生服务,提高学生与导师之间的交互

劣势:功能不够丰富,在提供学生与导师互选的服务之后,容易失去价值

D(Delivery

通过与教务处之间的合作,可以在学生和老师直接推广开来

原型设计

在经过NABCD模型的建立以及一些细节的讨论之后,我们开始着手于原型的设计

  1. 原型工具:MockingBot

  2. 原型模型:

  • 登录:学生通过学号,导师通过教职工号登录导师选择系统

  • 在学生选择导师的界面当中,导师信息里面列出学生可以选择的所有导师,并且可以点击导师的姓名栏了解导师详细地信息

    在导师详细信息当中,有统计了当前选择该位导师的学生人数

  • 在导师选择学生的界面当中,学生信息里面列出所有选择该位导师的学生,也可以点击学生的姓名栏了解学生详细的信息,包括成绩排名

  • 学生在个人选择当中填写自己的五个志愿,在第一栏我的分配结果中了解自己的导师分配结果

  • 导师在选择详情当中了解自己的学生选择结果

  • 学生可以在个人中心完善自己的个人资料,导师也是如此

  • 设置中心,可以设置是否开启推送

PSP

PSP
计划估计需要3周时间
开发需求分析:简化双发互选的过程,减少系负责人的工作量,提高效率
生成设计文档:PDF
设计复审:两个人共同讨论,一步一步完善
代码规范:格式整齐,变量名词化
具体设计:界面设计、数据库设计、代码逻辑设计等等
具体编码:Java
代码复审:小组内部一起审核
测试:黑白盒测试
记录用时利用课余时间,大概2-3周左右的时间
测试报告根据黑白盒的测试结果写测试报告
计算工作量多利用课余时间应该可以完成
事后总结
过程改进计划

小结

第一次接触到原型设计,一开始是懵逼的,完全不知道怎么入手,这时候队友提供了很大的帮助,完成了大部分原型设计的工作,并且教会了我怎么去做原型设计,自然我接受了博客的工作,但是里面需求分析也是我们共同分析的结果,所以结对让我认识到团队合作的重要性。然而这是大学第一次接触项目,博客的内容以及原型设计都存在很多需要改进的地方,而我们尽力而为。第二次软工实践的作业就让我觉得受益匪浅。

结对项目之需求分析和原型设计PDF文件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/250627.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaEE项目部署方式

1、手动部署 2、自动化部署 “自动化”的具体体现:向版本库提交新的代码后,应运服务器上自动部署 转载于:https://www.cnblogs.com/zyc-blogs/p/9674606.html

vue --- 2.0数据的响应式的一种实现

初识: 实际上是通过Object.defineProperty()方法来实现的talk is cheap, show your code let obj {}; Object.defineProperty(obj, name, {get(){return document.querySelector(#name).innerHTML;},set(newVal){document.querySelector(#name).innerHTML val;} })// 注1: …

结对编程作业——毕设导师智能匹配

结对编程作业——毕设导师智能匹配 031402317 李佳恺031402511 黄家俊 问题描述及要求 输入30个老师(包含带学生数的要求的上限,单个数值,在[0,8]内),100个学生(包含绩点信息),每…

OptaPlanner - 把example运行起来(运行并浅析Cloud balancing)

经过上面篇长篇大论的理论之后,在开始讲解Optaplanner相关基本概念及用法之前,我们先把他们提供的示例运行起来,好先让大家看看它是如何工作的。OptaPlanner的优点不仅仅是提供详细丰富的文档 ,还为各种应用场景提供丰富的示例&am…

软件产品案例分析

软件产品案例分析 第一部分: 评测: 上手体验: 说实话,在老师布置这个作业之前我确实不知道有K米这个APP,我想这是很少去KTV的原因吧。。。不过在接到这个作业后,我就去百度了普及了一下这个app的相关知识。…

vue --- 2.0 编译的实现

初识 假设html中有如下dom: <div id"app"><!-- 插值绑定 --><p>{{name}}</p><!-- 指令解析 --><p l-text"name"></p><p>{{age}}</p><p>{{doubleAge}}</p><!-- 双向绑定实现 -->…

vue --- configureWebpack模拟后台数据

初识 使用vue/cli搭建的项目可以在vue.config.js中,模拟一个后台(express写法)vue.config.js configureWebpack: {devServer: {// 模拟后台服务器 express写法before(app) {app.get(/api/login, function(req, res) {const { username, passwd } req.query;console.log(user…

Linux:客户端的实现

写了一个简单的服务器软件&#xff0c;但是没有写客户端。现在我将客户端实现了&#xff0c;其实昨天已经说了客户端的实现步骤了。 步骤&#xff1a; socket() 初始化 connet()链接 从标准输入读数据fgets() 传数据到服务器write() 读从服务器返回的数据read() 写数据到屏幕上…

HTTP 1.1与HTTP 1.0的比较

HTTP 1.1与HTTP 1.0的比较 一个WEB站点每天可能要接收到上百万的用户请求&#xff0c;为了提高系统的效率&#xff0c;HTTP 1.0规定浏览器与服务器只保持短暂的连接&#xff0c;浏览器的每次请求都需要与服务器建立一个TCP连接&#xff0c;服务器完成请求处理后立即断开TCP连接…

python全栈开发-json和pickle模块(数据的序列化)

一、什么是序列化&#xff1f; 我们把对象(变量)从内存中变成可存储或传输的过程称之为序列化&#xff0c;在Python中叫pickling&#xff0c;在其他语言中也被称之为serialization&#xff0c;marshalling&#xff0c;flattening等等&#xff0c;都是一个意思。 为什么要序列化…

Gale-Shapley---婚姻匹配算法算法

原文链接&#xff1a;http://blog.csdn.net/cscmaker/article/details/8291131 &#xff08;一&#xff09;问题的引出&#xff1a; 有N男N女&#xff0c;每个人都按照他对异性的喜欢程度排名。现在需要写出一个算法安排这N个男的、N个女的结婚&#xff0c;要求两个人的婚姻应该…

工具:meson+ninja(安装问题解决)

问题1&#xff1a;Python版本问题 报错信息&#xff1a; NOTICE: You are using Python 3.6 which is EOL. Starting with v0.62.0, Meson will require Python 3.7 or newer ubuntu 18默认的python3是3.6. 解决方案1&#xff1a;从源码安装python 3.7 wget https://www.pyth…

配置 --- vscode自定义代码段Snippets

目标 在vscode中输入vbs-vue 然后产生一个自己想要的模板 写好模板 在线上写好模板传送门: https://snippet-generator.app/ 1是标题,对应 2是前缀.对应在vue中使用的快捷键 vbs-vue3就是需要显示的代码段了 在vscode中配置 1.ctrlshiftp2.选择 Preferences: Configure U…

透明图与元素居中

1,定位让元素居中 1. 透明度 opacity 默认值是1 不透明 0是全透明转载于:https://www.cnblogs.com/Shinigami/p/9709382.html

配置 --- vscode中react格式化解决方案

选择右下角的语言 在弹出框搜react选择 JavaScript React(或者根据需求选择 TypeScript React) 快捷键, windows下 Alt SHIFT F

【商城购物车】购物车逻辑

转载于:https://www.cnblogs.com/xuzhengzong/p/8746677.html

PHP递归实现无限极分类

PHP递归实现无限极分类 摘要 今天在编码的时候要用到二级的栏目分类&#xff0c;所以顺便就把无限极分类给整理了一下&#xff0c;采用的是递归方法 //实现无限级分类public function getTree(){$categorys Category::all();return $this->makeTree($categorys, cate_id,…

react --- 生命周期 给子组件传递数据

子组件 /src/components/LifeCycle.js import React, { Component } from reactexport class LifeCycle extends Component {constructor(props) {super(props);// 常用于初始化状态(状态初始化、属性初始化)console.log("1.组件构建函数执行");}componentWillMoun…

Vue---mock.js 使用

mockjs 概述 在我们的生产实际中&#xff0c;后端的接口往往是较晚才会出来&#xff0c;并且还要写接口文档&#xff0c;于是我们的前端的许多开发都要等到接口给我们才能进行&#xff0c;这样对于我们前端来说显得十分的被动&#xff0c;于是有没有可以制造假数据来模拟后端接…