zoukankan      html  css  js  c++  java
  • Java开发笔记(一百三十一)Swing的列表框

    前面介绍了选择框的用法,当时为了方便用户勾勾点点,无论是复选框还是单选按钮,统统把所有选项都摆在界面上。倘若只有两三个选项还好办,要是选项数量变多比如超过五个,这么多的选择框一齐在界面罗列,不光程序员排版费劲,用户瞅着也容易眼花。鉴于这些选择框往往选完一次就了事,难得有重新选择第二次的机会,因而在界面上全部铺开这些选择框实属浪费。更好的做法是在选择的时候才展开所有选项,选完之后就缩回只显示选中的那一项,一伸一缩之间才能充分利用有限的屏幕界面。
    以单选按钮的组合为例,许多个单选按钮只能选择其中一个,这种情况就很适合展开与收缩的处理逻辑。Swing给该场景提供了专门的下拉框控件JComboBox,为了往下拉框塞进各个选项,还需要将它与下拉框模型DefaultComboBoxModel搭配使用才行。下拉框具体的调用过程分为下列三个步骤:
    1、创建一个下拉框模型,并调用模型对象的addElement方法依次添加每个选项;
    2、创建一个下拉框控件,注意要在JComboBox的构造方法中填入第一步的模型对象;
    3、调用下拉框对象的addItemListener方法给它添加一个点击监听器,每当用户在下拉面板中选择某一项,都会触发监听器的itemStateChanged方法。此时即可通过下拉框对象的getSelectedIndex方法获得选中项的序号,还可通过getSelectedItem方法获得选中项的对象。
    下面是利用JComboBox实现下拉选择功能的代码例子:

    		JPanel panelTop = new JPanel(); // 创建顶部面板
    		// 创建一个下拉框模型
    		DefaultComboBoxModel<String> comboModel = new DefaultComboBoxModel<String>();
    		comboModel.addElement("鱼香肉丝饭"); // 往下拉模型中添加元素
    		comboModel.addElement("香菇滑鸡饭"); // 往下拉模型中添加元素
    		comboModel.addElement("黑椒牛排饭"); // 往下拉模型中添加元素
    		comboModel.addElement("梅菜扣肉饭"); // 往下拉模型中添加元素
    		comboModel.addElement("糖醋里脊饭"); // 往下拉模型中添加元素
    		comboModel.addElement("红烧排骨饭"); // 往下拉模型中添加元素
    		comboModel.addElement("台式卤肉饭"); // 往下拉模型中添加元素
    		JComboBox<String> comboBox = new JComboBox<String>(comboModel); // 创建一个下拉框
    		panelTop.add(comboBox); // 在顶部面板上添加下拉框
    		frame.add(panelTop, BorderLayout.NORTH); // 把顶部面板添加到窗口的北边(上方)
    		comboBox.setEditable(false); // 设置下拉框能否编辑。默认不允许编辑
    		comboBox.addItemListener(new ItemListener() { // 给下拉框添加一个点击监听器
    			public void itemStateChanged(ItemEvent e) { // 下拉框被选择
    				// 获取下拉框内选中项的序号及其描述
    				// getSelectedIndex方法可获得选中项的序号,getSelectedItem方法可获得选中项的对象
    				String desc = String.format("您点了第%d项,套餐名称是%s", 
    						comboBox.getSelectedIndex(), comboBox.getSelectedItem().toString());
    				label.setText(desc); // 在标签上显示当前选中的文本项
    			}
    		});
    

    运行上面的下拉框代码,弹出如下图所示的窗口界面,可见一开始下拉框只占据长条般的空间,并且默认展示第一个选项。


    接着单击下拉框的长条区域,界面会向下弹出包含所有选项的下拉面板,选中面板上的某一项后,下拉面板消失不见,同时长条框内的文字变成了刚才选中项的文本。选择前后的窗口界面分别如以下两张图所示。


    虽然下拉框比起单选按钮组合要节省屏幕空间,但它的实现机制也导致了如下几点局限:
    1、下拉框只实现了单选功能,不支持多选功能,无法同时选择好几个选项;
    2、重新选择之时,要先点一下长条区域,才能在弹出的下拉面板中挑选新的选项,简简单单的选择操作也花费了两个步骤,甚不经济;
    以上两点局限的起因,皆来源于下拉面板的弹出与缩回机制,每次都要单击长条框才会弹出下拉面板,单击选中某一项后又会自动关闭下拉面板,正是这种单次点击单次响应的行为决定了下拉框只能用于单选操作,而不能用于多选操作。要想实现多选功能,还得将所有选项铺开展示,就像文件列表那样,用户才能按下Ctrl键逐个选中,或者按下Shift键选择一段连续的数个选项。这种平铺直叙所有选项的控件也叫列表框,对应于Swing中的JList类型,列表框的用法类似下拉框,它的调用过程依然分为以下三个步骤:
    1、创建一个列表框模型DefaultListModel,并调用模型对象的addElement方法依次添加每个选项;
    2、创建一个列表框控件,注意要在JList的构造方法中填入第一步的模型对象;
    3、调用列表框对象的addListSelectionListener方法给它添加一个点击监听器,每当用户单击列表框中的某一项,都会触发监听器的valueChanged方法。此时即可通过列表框对象的getSelectedIndex方法获得选中项的序号,通过getSelectedValue方法获得选中项的值,还能通过getSelectedValuesList方法获得所有选中项的值列表。
    下面是利用JList实现多次选择功能的代码例子:

    		JPanel panelLeft = new JPanel(); // 创建左边面板
    		// 创建一个列表框模型
    		DefaultListModel<String> listModel = new DefaultListModel<String>();
    		listModel.addElement("鱼香肉丝饭"); // 往列表模型中添加元素
    		listModel.addElement("香菇滑鸡饭"); // 往列表模型中添加元素
    		listModel.addElement("黑椒牛排饭"); // 往列表模型中添加元素
    		listModel.addElement("梅菜扣肉饭"); // 往列表模型中添加元素
    		listModel.addElement("糖醋里脊饭"); // 往列表模型中添加元素
    		listModel.addElement("红烧排骨饭"); // 往列表模型中添加元素
    		listModel.addElement("台式卤肉饭"); // 往列表模型中添加元素
    		JList<String> listBox = new JList<String>(listModel); // 创建一个列表框
    		panelLeft.add(listBox); // 在顶部面板上添加列表框
    		frame.add(panelLeft, BorderLayout.WEST); // 把顶部面板添加到窗口的西边(左侧)
    		listBox.addListSelectionListener(new ListSelectionListener() { // 给列表框添加一个点击监听器
    			public void valueChanged(ListSelectionEvent arg0) { // 列表框被选择
    				// 获取列表框内选中项的序号及其描述
    				// getSelectedIndex方法可获得选中项的序号,getSelectedValue方法可获得选中项的值
    				String desc = String.format("您点了第%d项,套餐名称是%s", 
    						listBox.getSelectedIndex(), listBox.getSelectedValue());
    				labelBottom.setText(desc); // 在标签上显示当前选中的文本项
    				String total = "<html>您已选择的套餐列表如下:<br>";
    				// 获取列表框内的所有选择项,并拼接html格式的描述串
    				for (String str : listBox.getSelectedValuesList()) {
    					total = String.format("%s<center>%s</center>", total, str);
    				}
    				total += "</html>";
    				labelCenter.setText(total); // 在标签上显示所有选中的文本项
    			}
    		});
    

    运行以上的列表框代码,弹出如下图所示的窗口界面,可见列表框一开始就展示了所有选项。


    然后按住Ctrl键,从下往上依次单击选中第七项、第五项、第三项、第一项,每次单击之后的界面效果分别如以下四张图片所示。


    从这些效果图可以看到,在按住Ctrl键的时候,列表框可以实现多选功能;未按住Ctrl键的时候,列表框变成实现单选功能。



    更多Java技术文章参见《Java开发笔记(序)章节目录

  • 相关阅读:
    人物-作家-马克·吐温:马克·吐温
    人物-发明家-特斯拉:尼古拉·特斯拉
    视觉暂留-Info:这些神奇的“视觉暂留”动画,每一幅都让人拍案叫绝!
    视觉暂留:余晖效应/视觉暂留
    mingetty
    mesg
    md5sum
    man.conf
    man
    makemap
  • 原文地址:https://www.cnblogs.com/pinlantu/p/11279354.html
Copyright © 2011-2022 走看看