201421123022 王若凡        201421123026  欧阳勇

https://git.coding.net/ttoyy/sizeyunsuan-GUI.git

a.需求分析:

这个程序做成GUI(可以是Windows PC 上的,也可以是Mac、Linux,web,手机上的),成为一个有基本功能、一定价值的程序。在下面的功能需求中实现两个:

  1. 记录用户的对错总数,程序退出再启动的时候,能把以前的对错数量保存并在此基础上增量计算。
  2. 有计时功能,能显示用户开始答题后的消耗时间。
  3. 界面支持中文简体/中文繁体/英语,用户可以选择一种;

b.功能设计

1.生成自定义数目算术题。

2.支持整数和分数的加减乘除。

3.输入答案判断对错,错误后写出正确答案。

4.集中收集错题。

5.简繁中英文切换。

6.计时功能。


思维导图


c.设计实现与代码展示(Viewcode

计时功能:

  1. B0.addActionListener(new ActionListener(){
  2.  
  3. public void actionPerformed(ActionEvent e) {
  4.  
  5. tishu=Integer.parseInt(T1.getText());//获取总题数
  6.  
  7. timer = new Timer();
  8.  
  9. finishtime=System.currentTimeMillis();
  10.  
  11. starttime=finishtime;
  12.  
  13. timer.schedule(new TimerTask()
  14.  
  15. {
  16.  
  17. public void run() {
  18.  
  19. finishtime=System.currentTimeMillis();
  20.  
  21. duration=finishtime-starttime;
  22.  
  23. String str=df.format(new Date(duration));
  24.  
  25. L12.setText(str);
  26.  
  27. if(summary==tishu){
  28.  
  29. try {
  30.  
  31. Thread.sleep(2000000);
  32.  
  33. } catch (InterruptedException e) {
  34.  
  35. e.printStackTrace();
  36.  
  37. }
  38.  
  39. }
  40.  
  41. }
  42.  
  43. }, 1000, 1000);
  44.  
  45. }
  46.  
  47. });

出题功能:

  1. B1.addActionListener(new ActionListener(){
  2.  
  3. public void actionPerformed(ActionEvent e) {
  4.  
  5. noanswer=tishu-dadui-dacuo;//算出未答题数
  6.  
  7. L9.setText("");
  8.  
  9. L8.setText(null);
  10.  
  11. T3.setText(null);
  12.  
  13. if(summary==tishu)
  14.  
  15. {
  16.  
  17. JOptionPane.showMessageDialog(null, "答题已完成,答题总题数:"+tishu+",答对题数:"+dadui+",答错题数:"+dacuo+",未答数:"+noanswer);
  18.  
  19. frame.setVisible(false);
  20.  
  21. }
  22.  
  23. //生成一个随机算术.该处代码由上次作业改成。
  24.  
  25. if(t==1){summary++;} } });

结果判断与输出

  1. T3.addActionListener(new ActionListener(){
  2.  
  3. public void actionPerformed(ActionEvent d) {
  4.  
  5. if(sum1.equals(T3.getText()))
  6.  
  7. {
  8.  
  9. L9.setText("Right!");
  10.  
  11. dadui++;
  12.  
  13. L10.setText(String.valueOf(dadui));
  14.  
  15. }
  16.  
  17. else
  18.  
  19. {
  20.  
  21. L9.setText("Error!answer is:"+sum1);
  22.  
  23. dacuo++;
  24.  
  25. FileWriter fw = null;
  26.  
  27. try {
  28.  
  29. //如果文件存在,则追加内容;如果文件不存在,则创建文件
  30.  
  31. File f=new File("D:/cuoti.txt");
  32.  
  33. fw = new FileWriter(f, true);
  34.  
  35. }
  36.  
  37. catch (IOException e) {
  38.  
  39. e.printStackTrace();
  40.  
  41. }
  42.  
  43. PrintWriter pw = new PrintWriter(fw);
  44.  
  45. pw.println(L8.getText()+"="+T3.getText()+" "+"正确答案:"+sum1 +'\n');
  46.  
  47. pw.flush();
  48.  
  49. try {
  50.  
  51. fw.flush();
  52.  
  53. pw.close();
  54.  
  55. fw.close();
  56.  
  57. } catch (IOException e) {
  58.  
  59. e.printStackTrace();
  60.  
  61. }
  62.  
  63. L11.setText(String.valueOf(dacuo));
  64.  
  65. }
  66.  
  67. }
  68.  
  69. });

错题统计收集

  1. FileWriter fw = null;
  2.  
  3. try {
  4.  
  5. //如果文件存在,则追加内容;如果文件不存在,则创建文件
  6.  
  7. File f=new File("D:/cuoti.txt");
  8.  
  9. fw = new FileWriter(f, true);
  10.  
  11. }
  12.  
  13. catch (IOException e) {
  14.  
  15. e.printStackTrace();
  16.  
  17. }
  18.  
  19. PrintWriter pw = new PrintWriter(fw);
  20.  
  21. pw.println(L8.getText()+"="+T3.getText()+" "+"正确答案:"+sum1 +'\n');
  22.  
  23. pw.flush();
  24.  
  25. try {
  26.  
  27. fw.flush();
  28.  
  29. pw.close();
  30.  
  31. fw.close();
  32.  
  33. } catch (IOException e) {
  34.  
  35. e.printStackTrace();
  36.  
  37. }
  38. B6.addActionListener(new ActionListener(){//错题本打开
  39.  
  40. public void actionPerformed(ActionEvent d) {
  41.  
  42. try
  43.  
  44. {
  45.  
  46. Runtime.getRuntime().exec("notepad.exe D:/cuoti.txt");
  47.  
  48. }
  49.  
  50. catch(Exception e)
  51.  
  52. {
  53.  
  54. System.out.println(e.getMessage());
  55.  
  56. }
  57.  
  58. }
  59.  
  60. });

语言切换

  1. B3.addActionListener(new ActionListener(){//简体中文
  2.  
  3. public void actionPerformed(ActionEvent e) {
  4.  
  5. L1.setText("题数:");
  6.  
  7. L2.setText("题目:");
  8.  
  9. L3.setText("输入答案:");
  10.  
  11. L4.setText("结果:");
  12.  
  13. L5.setText("答对题数:");
  14.  
  15. L6.setText("答错题数:");
  16.  
  17. L7.setText("答题时间:");
  18.  
  19. B0.setText("开始");
  20.  
  21. B1.setText("下一题");
  22.  
  23. B6.setText("错题集");
  24.  
  25. //B2.setText("计时");
  26.  
  27. }
  28.  
  29. });
  30.  
  31. B4.addActionListener(new ActionListener(){//繁体中文
  32.  
  33. public void actionPerformed(ActionEvent e) {
  34.  
  35. L1.setText("題數");
  36.  
  37. L2.setText("題目:");
  38.  
  39. L3.setText("輸入答案:");
  40.  
  41. L4.setText("結果:");
  42.  
  43. L5.setText("答對題數:");
  44.  
  45. L6.setText("答錯題數:");
  46.  
  47. L7.setText("答題時間:");
  48.  
  49. B0.setText("開始");
  50.  
  51. B1.setText("下一題");
  52.  
  53. B6.setText("錯題集");
  54.  
  55. }
  56.  
  57. });
  58.  
  59. B5.addActionListener(new ActionListener(){//英文
  60.  
  61. public void actionPerformed(ActionEvent e) {
  62.  
  63. L1.setText("Question number");
  64.  
  65. L2.setText("Test:");
  66.  
  67. L3.setText("Enter the answer:");
  68.  
  69. L4.setText("Result:");
  70.  
  71. L5.setText("Right number:");
  72.  
  73. L6.setText("Wrong number:");
  74.  
  75. L7.setText("Answer times:");
  76.  
  77. B0.setText("Run");
  78.  
  79. B1.setText("Next");
  80.  
  81. B6.setText("WrongTest");
  82.  
  83. }
  84.  
  85. });

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的更多相关文章

  1. 结对编程四则运算gui

    码市地址:https://git.coding.net/linzhao/sizeyunsuangui.git 林 钊 -- 201421123105 吴世荣 -- 201421123119 王坤彬 - ...

  2. 结对编程-四则运算GUI的实现

    一.项目成员以及coding地址: 洪灏捷(本人)201321122020  coding地址:https://git.coding.net/hoje/The-GUI-operation.git 白至 ...

  3. 20175226 2018-2019-2《java程序设计》结对编程-四则运算(第一周-阶段总结)

    结对编程-四则运算(第一周-阶段总结) 需求分析 实现一个四则运算程序,要求: 自动随机生成小学四则运算题目(加,减,乘,除) 支持整数.真分数且支持多项式 能够利用栈的思想,将中缀转换为后缀表达式 ...

  4. 20175305张天钰Java结对编程四则运算(二)

    Java结对编程四则运算(二) 一.题目描述及要求 Git提交粒度不要太粗,建议一个文件/一个类/一个函数/一个功能/一个bug修复都进行提交,不能一天提交一次,更不能一周一次,参考Commit Me ...

  5. 20175305张天钰Java结对编程四则运算

    Java结对编程四则运算 一.题目描述:如何对表达式进行求值运算呢 1.中缀表达式与后缀表达式(娄老师讲解) 中缀表达式就是运算符号在运算数中间的表达式,比如1+2,顾名思义,后缀表达式就是运算符在运 ...

  6. 结对编程--四则运算(Java)萧英杰 夏浚杰

    结对编程--四则运算(Java)萧英杰 夏浚杰 Github项目地址 功能要求 题目:实现一个自动生成小学四则运算题目的命令行程序 使用 -n 参数控制生成题目的个数(实现) 使用 -r 参数控制题目 ...

  7. 结对编程--四则运算(Java)梅进鹏 欧思良

    结对编程--四则运算(Java)梅进鹏 欧思良 Github项目地址:https://github.com/MeiJinpen/Arithmetic 功能要求 题目:实现一个自动生成小学四则运算题目的 ...

  8. 王译潇20162314 实验报告三plus结对编程四则运算第一阶段

    北京电子科技学院BESTI实验报告 课程:程序设计与数据结构 班级: 1623 姓名: 王译潇 学号:20162314 指导教师:娄佳鹏老师.王志强老师 实验日期:2017年5月12号 实验密级: 非 ...

  9. Java结对编程四则运算一周小结

    Java结对编程四则运算一周小结 需求分析 对于四则运算来说最主要的就是要计算出产生的式子(字符串的形式). 设计思路 总体可将这个项目分解为几个部分:产生式子,计算式子,判断对错并记录: 具体的思路 ...

随机推荐

  1. java网络编程实现两端聊天

    网络编程的三要素: ip地址:唯一标识网络上的每一台计算机 端口号:计算机中应用的标号(代表一个应用程序),0-1024系统使用或者保留端口,有效端口0-65535(short) 通信协议:通信的规则 ...

  2. --使用oracle数据先要创建表空间

    one\--创建表空间 CREATE TABLESPACE 表空间的名字DATAFILE 'E:\oracle\app\userdata\java5space.dbf' --表空间物理文件路径SIZE ...

  3. python---------函数练习题

    2.写函数,,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作 # 方法一 # import os # def fun(): #y为要修改的内容,z为修改的结果 # y=in ...

  4. 【leetcode】147. Insertion Sort List

    Sort a linked list using insertion sort. 链表的插入排序. 需要创建一个虚拟节点.注意点就是不要节点之间断了. class Solution { public: ...

  5. 改进的Bresenham算法

    这里不仔细讲原理,只是把我写的算法发出来,跟大家分享下,如果有错误的话,还请大家告诉我,如果写的不好,也请指出来,一起讨论进步. 算法步骤: (1) 输入直线的两端点P0 (x0, y0)和P1 (x ...

  6. 设计模式,Let's Go! (上)

    * { color: #3e3e3e } body { font-family: "Helvetica Neue", Helvetica, "Hiragino Sans ...

  7. oracle 查询优化改写

    -----------书籍: oracle 查询优化改写-----------第1个“C###oracle”为登录数据库的用户名,第2个“oracleChange”为登录数据库的密码“oracleCh ...

  8. php递归查找指定目录下及子文件名称是否包含中文空格及括号

    //php递归查找该目录下及子文件名称是否包含中文空格括号 function searchDir($path,&$data){ if(is_dir($path)){ $dp=dir($path ...

  9. markdownpad生成目录

    生成目录 document.addEventListener("DOMContentLoaded", function() { // 生成目录列表 var outline = do ...

  10. 数据库及SQL----常用知识点总结

    数据库也是计算机类笔试面试中不可避免会遇到的考点,尤其是银行和部分传统软件类公司.这里根据整理的资料,对数据库的相关知识也做个总结吧.希望学过数据库但长时间不用的同学根据这些知识能够回忆和重拾,没学过 ...