fiore@0
|
1 /*
|
fiore@0
|
2 CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool
|
fiore@0
|
3
|
fiore@0
|
4 Copyright (C) 2011 Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/)
|
fiore@0
|
5
|
fiore@0
|
6 This program is free software: you can redistribute it and/or modify
|
fiore@0
|
7 it under the terms of the GNU General Public License as published by
|
fiore@0
|
8 the Free Software Foundation, either version 3 of the License, or
|
fiore@0
|
9 (at your option) any later version.
|
fiore@0
|
10
|
fiore@0
|
11 This program is distributed in the hope that it will be useful,
|
fiore@0
|
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
|
fiore@0
|
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
fiore@0
|
14 GNU General Public License for more details.
|
fiore@0
|
15
|
fiore@0
|
16 You should have received a copy of the GNU General Public License
|
fiore@0
|
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
|
fiore@0
|
18 */
|
fiore@0
|
19 package uk.ac.qmul.eecs.ccmi.gui;
|
fiore@0
|
20
|
fiore@0
|
21 import java.awt.event.ItemEvent;
|
fiore@0
|
22 import java.awt.event.KeyEvent;
|
fiore@0
|
23 import java.util.Vector;
|
fiore@0
|
24
|
fiore@0
|
25 import javax.swing.ComboBoxModel;
|
fiore@0
|
26 import javax.swing.JComboBox;
|
fiore@0
|
27
|
fiore@0
|
28 /**
|
fiore@0
|
29 * A ComboBox component which overrides the default behaviour when selecting items by the keyboard
|
fiore@0
|
30 * up and down arrow keys. When the top is reached, if the user presses the up arrow key
|
fiore@0
|
31 * instead of blocking on the first item, the LoopComboBox loops forward to the last item. Likewise,
|
fiore@0
|
32 * when the bottom is reached and the user presses the down arrow key the LoopComboBox
|
fiore@0
|
33 * loops back to the first item.
|
fiore@0
|
34 *
|
fiore@0
|
35 */
|
fiore@0
|
36 @SuppressWarnings("serial")
|
fiore@0
|
37 public class LoopComboBox extends JComboBox {
|
fiore@0
|
38 public LoopComboBox(){
|
fiore@0
|
39 super();
|
fiore@0
|
40 }
|
fiore@0
|
41
|
fiore@0
|
42 public LoopComboBox(Object[] items){
|
fiore@0
|
43 super(items);
|
fiore@0
|
44 }
|
fiore@0
|
45
|
fiore@0
|
46 public LoopComboBox(ComboBoxModel aModel){
|
fiore@0
|
47 super(aModel);
|
fiore@0
|
48 }
|
fiore@0
|
49
|
fiore@0
|
50 public LoopComboBox(Vector<?> items){
|
fiore@0
|
51 super(items);
|
fiore@0
|
52 }
|
fiore@0
|
53
|
fiore@0
|
54 @Override
|
fiore@0
|
55 public void processKeyEvent(KeyEvent e) {
|
fiore@0
|
56 if(dataModel.getSize() == 0){
|
fiore@0
|
57 super.processKeyEvent(e);
|
fiore@0
|
58 }else{
|
fiore@0
|
59 if(e.getKeyCode() == KeyEvent.VK_DOWN
|
fiore@0
|
60 && e.getID()==KeyEvent.KEY_PRESSED
|
fiore@0
|
61 && getSelectedIndex() == getItemCount()-1){
|
fiore@0
|
62 setSelectedIndex(0);
|
fiore@0
|
63 if(getItemCount() == 1)
|
fiore@0
|
64 fireOneItemStateChanged();
|
fiore@0
|
65 }else if(e.getKeyCode() == KeyEvent.VK_UP
|
fiore@0
|
66 && e.getID()==KeyEvent.KEY_PRESSED
|
fiore@0
|
67 && getSelectedIndex() == 0){
|
fiore@0
|
68 setSelectedIndex(getItemCount()-1);
|
fiore@0
|
69 if(getItemCount() == 1)
|
fiore@0
|
70 fireOneItemStateChanged();
|
fiore@0
|
71 }else
|
fiore@0
|
72 super.processKeyEvent(e);
|
fiore@0
|
73 }
|
fiore@0
|
74 }
|
fiore@0
|
75
|
fiore@5
|
76 /*
|
fiore@0
|
77 * when the comboBox has only one item the ItemStateChanged listeners ain't fired by default.
|
fiore@0
|
78 * This behaviour has to be forced in order to have the item label to be spoken out by
|
fiore@0
|
79 * the narrator, in spite of the item number .
|
fiore@0
|
80 */
|
fiore@0
|
81 private void fireOneItemStateChanged(){
|
fiore@0
|
82 fireItemStateChanged(new ItemEvent(
|
fiore@0
|
83 this,
|
fiore@0
|
84 ItemEvent.ITEM_STATE_CHANGED,
|
fiore@0
|
85 getSelectedItem(),
|
fiore@0
|
86 ItemEvent.SELECTED
|
fiore@0
|
87 ));
|
fiore@0
|
88 }
|
fiore@0
|
89 }
|