• 结对编程1——四则运算优化


    一、需求分析

    1、题目要求:

    我们在个人作业1中,用各种语言实现了一个命令行的四则运算小程序。进一步,本次要求把这个程序做成GUI(可以是Windows PC 上的,也可以是Mac、Linux,web,手机上的),成为一个有基本功能、一定价值的程序。在下面的功能需求中实现两个:

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

    2、题目分析:

    (1)支持真分数和整数的运算;
    (2)能够判断对错,且输出正确答案;能够计算正确率并输出;
    (3)将程序弄成GUI;
    (4)可切换语言,界面支持中文简体/中文繁体/英语,用户可以选择一种;
    (5)计时器功能,点击开始计时时,能显示用户开始答题后的消耗时间;

    3、分工

    此次程序设计由我(201421123033)和林莹(201421123035)一起完成,因为时间不够,代码其实挺乱的并没有进行修改和整理,只上传了一次
    我的码市地址:https://git.coding.net/Belong033/java-second-two.git
    同伴博客地址:http://www.cnblogs.com/ly-35/

    二、 程序设计

    我们选择设计了两个功能:
    1、计时器功能,点击开始计时时,能显示用户开始答题后的消耗时间;
    2、可切换语言,界面支持中文简体/中文繁体/英语,用户可以选择一种;

    流程图:

    三、代码展示
    计时器

    //计时器
             private boolean isRun = false;
    	 private MyRunable myTimeRunable = new MyRunable();
    	 private class MyRunable implements Runnable{
    	        private int hour = 0;
    	        private int min = 0;
    	        private int sec = 0;
    	        private NumberFormat format = NumberFormat.getInstance();
    	        private String nextSecond(){
    	            ++sec;
    	            if(sec == 60) {
    	                ++min;
    	                sec = 0;
    	            }
    	             
    	            if(min == 60) {
    	                ++hour;
    	                min = 0;
    	            }
    	            return currentTime();
    	        }
    	         
    	        private String currentTime(){
    	            return format.format(hour)+":"+format.format(min)+":"+format.format(sec);
    	        }
    	         
    	        @Override
    	        public void run() {
    	            format.setMinimumIntegerDigits(2);
    	            format.setGroupingUsed(false);
    	            while(true) {
    					if(rootPaneCheckingEnabled) {
    	                    if(isRun) {
    	                        nextSecond();
    	                        jLabel4.setText(currentTime());
    	                    }
    	                }
    	                try {
    	                    Thread.sleep(1000);
    	                }catch (InterruptedException e) {
    	                }
    	            }
    	        }
    	         
    	    }
    

    语言转换(以英文为例)

    		//创建内容面板
    	JPanel contentPane;
    	//创建菜单栏组件的对象
    	JMenuBar jMenuBar1=new JMenuBar();//菜单条
    	JMenu jMenu0=new JMenu("system");//菜单
    	JMenuItem jMenuItem0=new JMenuItem("exit");//子菜单
    	JMenu jMenu1=new JMenu("The text conversion");
    	JMenuItem jMenuItem1=new JMenuItem("Simplified Chinese");
    	JMenuItem jMenuItem2=new JMenuItem("Traditional Chinese");
    	JMenuItem jMenuItem3=new JMenuItem("English");
    	JMenu jMenu2=new JMenu("Help");
    	JMenuItem jMenuItem4=new JMenuItem("Directions");
    	JLabel jLabel1=new JLabel("Please enter the number:");
    	JTextField jTextField1=new JTextField();
    	JButton jButton1=new JButton("Start the topic");
    	//创建构造方法
    
    //点击文字转换下的英文
    		if(e.getSource()==jMenuItem3)
    		{
    			//创建英文的面板对象
    			MainFrameE MFE=new MainFrameE();
    			this.remove(this.getRootPane());
    			this.dispose();
    		    MFE.setVisible(true);
    
    		}
    

    四、程序运行

    进入四则运算系统

    输入题目数量

    开始做题并计时

    点击确定输出正确答案和正确率计时停止

    点击文字转换的繁体中文和英文

    五、小结

    做起来其实还是挺困难的哈哈,两个人都是对java不是很熟悉的人,然后只能一边摸索百度一边讨论编程,弄GUI页面的时候就弄了很久,尤其弄计时器的时候,明明程序没有错但是点击界面上的开始计时,秒表就一直不走!然而程序并没有报错啊。。。找了老半天修改了下函数才弄好_(:зゝ∠)_。。。

    结对编程我觉得还是有做到1+1>2的效果的,在我老解决不了程序报错然后暴躁时能够鼓励安慰我,并一起百度讨论解决方法,两个人的效率会比一个人高一点,毕竟人多了就总有一个人能够想到解决办法,比一个人默默的想方设法的快多了。。当然还是有一些分歧的,比如还是计时器,我本来想弄成那种一跳到做题页面时无需点击就能自动开始计时的,但是林莹想要那种能够控制合适开始计时的比较好,毕竟如果用户突然有事耽搁了一会,自动计时的话那个数据就可能不太真实,对用户并没有太大的帮助,后来商讨了一下决定用她的计时方式。。

    嘛。。本来一开始总觉得可能会弄不完,设计过程之中真的好艰难,慢慢的一点一点摸索开始做,最终弄完的时候成就感还是蛮大的哈哈哈,虽然设计的并不怎么好,只是勉强完成了功能设计_(:зゝ∠)_。。能够改进的地方还是蛮多的,比如存储的功能就没有实现,本来想写的,但是能力不够,时间也不够,就只弄到目前这样。。总之。。继续努力吧。。

    我和我的同伴

    六、PSP

  • 相关阅读:
    为什么非全站升级HTTPS不可?
    使用JSON实现分页
    Git常用命令
    chrome浏览器tab页内存占用变大,网站变慢为哪般?
    我们前端跟后端是怎么合作的
    关于响应式布局
    AngularJS(1)
    关于php语言的使用!
    你必须收藏的Github技巧
    CSS3 动画
  • 原文地址:https://www.cnblogs.com/belong033/p/6550896.html
Copyright © 2020-2023  润新知