结对编程-四则运算-GUI
201421123022 王若凡 201421123026 欧阳勇
https://git.coding.net/ttoyy/sizeyunsuan-GUI.git
a.需求分析:
这个程序做成GUI(可以是Windows PC 上的,也可以是Mac、Linux,web,手机上的),成为一个有基本功能、一定价值的程序。在下面的功能需求中实现两个:
- 记录用户的对错总数,程序退出再启动的时候,能把以前的对错数量保存并在此基础上增量计算。
- 有计时功能,能显示用户开始答题后的消耗时间。
- 界面支持中文简体/中文繁体/英语,用户可以选择一种;
b.功能设计
1.生成自定义数目算术题。
2.支持整数和分数的加减乘除。
3.输入答案判断对错,错误后写出正确答案。
4.集中收集错题。
5.简繁中英文切换。
6.计时功能。
思维导图
c.设计实现与代码展示(Viewcode)
计时功能:
- B0.addActionListener(new ActionListener(){
- public void actionPerformed(ActionEvent e) {
- tishu=Integer.parseInt(T1.getText());//获取总题数
- timer = new Timer();
- finishtime=System.currentTimeMillis();
- starttime=finishtime;
- timer.schedule(new TimerTask()
- {
- public void run() {
- finishtime=System.currentTimeMillis();
- duration=finishtime-starttime;
- String str=df.format(new Date(duration));
- L12.setText(str);
- if(summary==tishu){
- try {
- Thread.sleep(2000000);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- }, 1000, 1000);
- }
- });
出题功能:
- B1.addActionListener(new ActionListener(){
- public void actionPerformed(ActionEvent e) {
- noanswer=tishu-dadui-dacuo;//算出未答题数
- L9.setText("");
- L8.setText(null);
- T3.setText(null);
- if(summary==tishu)
- {
- JOptionPane.showMessageDialog(null, "答题已完成,答题总题数:"+tishu+",答对题数:"+dadui+",答错题数:"+dacuo+",未答数:"+noanswer);
- frame.setVisible(false);
- }
- //生成一个随机算术.该处代码由上次作业改成。
- if(t==1){summary++;} } });
结果判断与输出
- T3.addActionListener(new ActionListener(){
- public void actionPerformed(ActionEvent d) {
- if(sum1.equals(T3.getText()))
- {
- L9.setText("Right!");
- dadui++;
- L10.setText(String.valueOf(dadui));
- }
- else
- {
- L9.setText("Error!answer is:"+sum1);
- dacuo++;
- FileWriter fw = null;
- try {
- //如果文件存在,则追加内容;如果文件不存在,则创建文件
- File f=new File("D:/cuoti.txt");
- fw = new FileWriter(f, true);
- }
- catch (IOException e) {
- e.printStackTrace();
- }
- PrintWriter pw = new PrintWriter(fw);
- pw.println(L8.getText()+"="+T3.getText()+" "+"正确答案:"+sum1 +'\n');
- pw.flush();
- try {
- fw.flush();
- pw.close();
- fw.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- L11.setText(String.valueOf(dacuo));
- }
- }
- });
错题统计收集
- FileWriter fw = null;
- try {
- //如果文件存在,则追加内容;如果文件不存在,则创建文件
- File f=new File("D:/cuoti.txt");
- fw = new FileWriter(f, true);
- }
- catch (IOException e) {
- e.printStackTrace();
- }
- PrintWriter pw = new PrintWriter(fw);
- pw.println(L8.getText()+"="+T3.getText()+" "+"正确答案:"+sum1 +'\n');
- pw.flush();
- try {
- fw.flush();
- pw.close();
- fw.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- B6.addActionListener(new ActionListener(){//错题本打开
- public void actionPerformed(ActionEvent d) {
- try
- {
- Runtime.getRuntime().exec("notepad.exe D:/cuoti.txt");
- }
- catch(Exception e)
- {
- System.out.println(e.getMessage());
- }
- }
- });
语言切换
- B3.addActionListener(new ActionListener(){//简体中文
- public void actionPerformed(ActionEvent e) {
- L1.setText("题数:");
- L2.setText("题目:");
- L3.setText("输入答案:");
- L4.setText("结果:");
- L5.setText("答对题数:");
- L6.setText("答错题数:");
- L7.setText("答题时间:");
- B0.setText("开始");
- B1.setText("下一题");
- B6.setText("错题集");
- //B2.setText("计时");
- }
- });
- B4.addActionListener(new ActionListener(){//繁体中文
- public void actionPerformed(ActionEvent e) {
- L1.setText("題數");
- L2.setText("題目:");
- L3.setText("輸入答案:");
- L4.setText("結果:");
- L5.setText("答對題數:");
- L6.setText("答錯題數:");
- L7.setText("答題時間:");
- B0.setText("開始");
- B1.setText("下一題");
- B6.setText("錯題集");
- }
- });
- B5.addActionListener(new ActionListener(){//英文
- public void actionPerformed(ActionEvent e) {
- L1.setText("Question number");
- L2.setText("Test:");
- L3.setText("Enter the answer:");
- L4.setText("Result:");
- L5.setText("Right number:");
- L6.setText("Wrong number:");
- L7.setText("Answer times:");
- B0.setText("Run");
- B1.setText("Next");
- B6.setText("WrongTest");
- }
- });
d.测试运行
点击错题集:
PSP表格
PSP2.1 |
Personal Software Process Stages |
Estimated time(h) |
actual time(h) |
Planning |
计划 |
16 |
17 |
· Estimate |
估计这个任务需要多少时间 |
16 |
17 |
Development |
开发 |
8 |
9 |
· Analysis |
需求分析 (包括学习新技术) |
1 |
0.5 |
· Design Spec |
生成设计文档 |
0.5 |
0.5 |
· Design Review |
设计复审 |
1 |
1 |
· Coding Standard |
代码规范 |
0.5 |
0.2 |
· Design |
具体设计 |
2 |
1.5 |
· Coding |
具体编码 |
8 |
8 |
· Code Review |
代码复审 |
0.5 |
0.5 |
· Test |
测试(自我测试,修改代码,提交修改) |
1 |
1.5 |
Reporting |
报告 |
1.5 |
1.5 |
· |
测试报告 |
||
· |
计算工作量 |
0.5 |
1 |
· |
并提出过程改进计划 |
1 |
1 |
总结:
此次结对编程任务与王若凡合作,开始我们先对需求进行了分析,对于功能实现先定了大致方向。基础四则运算算法取用王若凡的程序,在此基础上实现各种功能。在错题集功能上耗费时间较多,想对错题集里的错题进行编号的功能还是无法完成实现。
结对编程无疑提高了我们编程的高效性,互相监督,取长补短,如我的思路较快,而他实际操作网上查找资料能力较强。两个人的思路想法在同一时间产生碰撞,让程序更好更快地完成。一个人编写另一个人旁边护航有效地发现一些错误特别是低级错误,
如此才不会产生当局者迷而陷入死循环。
汉堡包点评:
先来一片面包: 我们有着一个共同任务,对任务有着相同思路,并且我们可以互相信赖,主要是他看上了我的壁纸~;
铺上肉与佐料:队友在编程中充分地展示了他强大的动手能力与资料知识搜索能力,而且他是一个很耐心的人,是能带着我认真打代码的引航者。
不足之处在于对问题解决思路不够清晰,思路的表达条理性不够。若有一个清晰的思路加上他强大的编程动手能力,那肯定会成为无敌的编程大神。
然后再来一片面包:方向盘与gps导航,才能走的更远才能探索未知道路;互相配合,终能完成任务,更上一层楼。
结对编程-四则运算-GUI的更多相关文章
- 结对编程四则运算gui
码市地址:https://git.coding.net/linzhao/sizeyunsuangui.git 林 钊 -- 201421123105 吴世荣 -- 201421123119 王坤彬 - ...
- 结对编程-四则运算GUI的实现
一.项目成员以及coding地址: 洪灏捷(本人)201321122020 coding地址:https://git.coding.net/hoje/The-GUI-operation.git 白至 ...
- 20175226 2018-2019-2《java程序设计》结对编程-四则运算(第一周-阶段总结)
结对编程-四则运算(第一周-阶段总结) 需求分析 实现一个四则运算程序,要求: 自动随机生成小学四则运算题目(加,减,乘,除) 支持整数.真分数且支持多项式 能够利用栈的思想,将中缀转换为后缀表达式 ...
- 20175305张天钰Java结对编程四则运算(二)
Java结对编程四则运算(二) 一.题目描述及要求 Git提交粒度不要太粗,建议一个文件/一个类/一个函数/一个功能/一个bug修复都进行提交,不能一天提交一次,更不能一周一次,参考Commit Me ...
- 20175305张天钰Java结对编程四则运算
Java结对编程四则运算 一.题目描述:如何对表达式进行求值运算呢 1.中缀表达式与后缀表达式(娄老师讲解) 中缀表达式就是运算符号在运算数中间的表达式,比如1+2,顾名思义,后缀表达式就是运算符在运 ...
- 结对编程--四则运算(Java)萧英杰 夏浚杰
结对编程--四则运算(Java)萧英杰 夏浚杰 Github项目地址 功能要求 题目:实现一个自动生成小学四则运算题目的命令行程序 使用 -n 参数控制生成题目的个数(实现) 使用 -r 参数控制题目 ...
- 结对编程--四则运算(Java)梅进鹏 欧思良
结对编程--四则运算(Java)梅进鹏 欧思良 Github项目地址:https://github.com/MeiJinpen/Arithmetic 功能要求 题目:实现一个自动生成小学四则运算题目的 ...
- 王译潇20162314 实验报告三plus结对编程四则运算第一阶段
北京电子科技学院BESTI实验报告 课程:程序设计与数据结构 班级: 1623 姓名: 王译潇 学号:20162314 指导教师:娄佳鹏老师.王志强老师 实验日期:2017年5月12号 实验密级: 非 ...
- Java结对编程四则运算一周小结
Java结对编程四则运算一周小结 需求分析 对于四则运算来说最主要的就是要计算出产生的式子(字符串的形式). 设计思路 总体可将这个项目分解为几个部分:产生式子,计算式子,判断对错并记录: 具体的思路 ...
随机推荐
- java网络编程实现两端聊天
网络编程的三要素: ip地址:唯一标识网络上的每一台计算机 端口号:计算机中应用的标号(代表一个应用程序),0-1024系统使用或者保留端口,有效端口0-65535(short) 通信协议:通信的规则 ...
- --使用oracle数据先要创建表空间
one\--创建表空间 CREATE TABLESPACE 表空间的名字DATAFILE 'E:\oracle\app\userdata\java5space.dbf' --表空间物理文件路径SIZE ...
- python---------函数练习题
2.写函数,,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作 # 方法一 # import os # def fun(): #y为要修改的内容,z为修改的结果 # y=in ...
- 【leetcode】147. Insertion Sort List
Sort a linked list using insertion sort. 链表的插入排序. 需要创建一个虚拟节点.注意点就是不要节点之间断了. class Solution { public: ...
- 改进的Bresenham算法
这里不仔细讲原理,只是把我写的算法发出来,跟大家分享下,如果有错误的话,还请大家告诉我,如果写的不好,也请指出来,一起讨论进步. 算法步骤: (1) 输入直线的两端点P0 (x0, y0)和P1 (x ...
- 设计模式,Let's Go! (上)
* { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...
- oracle 查询优化改写
-----------书籍: oracle 查询优化改写-----------第1个“C###oracle”为登录数据库的用户名,第2个“oracleChange”为登录数据库的密码“oracleCh ...
- php递归查找指定目录下及子文件名称是否包含中文空格及括号
//php递归查找该目录下及子文件名称是否包含中文空格括号 function searchDir($path,&$data){ if(is_dir($path)){ $dp=dir($path ...
- markdownpad生成目录
生成目录 document.addEventListener("DOMContentLoaded", function() { // 生成目录列表 var outline = do ...
- 数据库及SQL----常用知识点总结
数据库也是计算机类笔试面试中不可避免会遇到的考点,尤其是银行和部分传统软件类公司.这里根据整理的资料,对数据库的相关知识也做个总结吧.希望学过数据库但长时间不用的同学根据这些知识能够回忆和重拾,没学过 ...