| Prev Class | Next Class | Frames | No Frames |
| Summary: Nested | Field | Method | Constr | Detail: Nested | Field | Method | Constr |
java.lang.Objectca.odell.glazedlists.swing.AutoCompleteSupport<E>public final class AutoCompleteSupport<E>extends java.lang.ObjectAutoCompleteSupports support for filtering and autocompletion into
a standard JComboBox. It also acts as a factory class for
creating autocompleting table cell editors.
All autocompletion behaviour provided is meant to mimic the functionality
of the Firefox address field. To be explicit, the following is a list of
expected behaviours which are installed:
Typing into the ComboBox Editor
JComboBox, but may be wider to accomodate a
prototype display value
if a non-null prototype display value exists
JComboBox.getMaximumRowCount()
rows before scrolling the popup
ActionEvent is fired from the JComboBox in these situations:
null values located in the ComboBoxModel are considered
identical to empty Strings ("") for the purposes of locating autocompletion
terms.getSelectsTextOnFocusGain() returns true
getHidesPopupOnFocusLost() returns true
Object.toString()
to map elements to their String equivalents. Sometimes, however, toString()
is not a reliable or desirable mechanism to use. To deal with this problem,
AutoCompleteSupport provides an install method that takes a Format
object which is used to do all converting back and forth between Strings and
ComboBoxModel objects.
In order to achieve all of the autocompletion and filtering behaviour,
the following occurs when AutoCompleteSupport is called:
IllegalStateException thrown from any one of:
install(JComboBox, EventList)
install(JComboBox, EventList, TextFilterator)
install(JComboBox, EventList, TextFilterator, Format)
isInstalled()
uninstall()
setCorrectsCase(boolean)
setStrict(boolean)
setBeepOnStrictViolation(boolean)
setSelectsTextOnFocusGain(boolean)
setHidesPopupOnFocusLost(boolean)
setFilterMode(int)
setFirstItem(Object)
removeFirstItem()
Nested Class Summary | |
static class |
|
Method Summary | |
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
boolean |
|
JComboBox |
|
boolean |
|
int |
|
E |
|
boolean |
|
EventList |
|
boolean |
|
Object |
|
boolean |
|
boolean |
|
E |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
TextFilterator |
|
void |
|
public staticAutoCompleteCellEditor createTableCellEditor(Comparator uniqueComparator, TableFormat tableFormat, EventList tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditorwhich adapts an autocompletingJComboBoxfor use as a Table Cell Editor. The values within the table column are used as autocompletion terms within theComboBoxModel. This version ofcreateTableCellEditormakes no assumption about the values stored in the TableModel at the givencolumnIndex. Instead, it uses the givenuniqueComparatorto determine which values are duplicates (and thus can safely be removed) and which are unique (and thus must remain in theComboBoxModel). Note that this factory method is only appropriate for use when the values in theComboBoxModelshould be the unique set of values in a table column. If some other list of values will be used thencreateTableCellEditor(EventList)is the appropriate factory method to use. If the appearance or function of the autocompletingJComboBoxis to be customized, it can be retrieved usingAutoCompleteCellEditor.getComponent().
- Parameters:
uniqueComparator- theComparatorthat strips away duplicate elements from theComboBoxModeltableFormat- specifies how each row object within a table is broken apart into column valuestableData- theEventListbacking the TableModelcolumnIndex- the index of the column for which to return aAutoCompleteSupport.AutoCompleteCellEditor
- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditorwhich contains an autocompleting combobox whose contents remain consistent with the data in the table column at the givencolumnIndex
public staticAutoCompleteCellEditor createTableCellEditor(EventList source)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditorwhich adapts an autocompletingJComboBoxfor use as a Table Cell Editor. The values within thesourceare used as autocompletion terms within theComboBoxModel. If the appearance or function of the autocompletingJComboBoxis to be customized, it can be retrieved usingAutoCompleteCellEditor.getComponent().
- Parameters:
source- the source of data for the JComboBox within the table cell editor
- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditorwhich contains an autocompleting combobox whose model contents are determined by the givensource
public staticAutoCompleteCellEditor createTableCellEditor(TableFormat tableFormat, EventList tableData, int columnIndex)
This factory method creates and returns aAutoCompleteSupport.AutoCompleteCellEditorwhich adapts an autocompletingJComboBoxfor use as a Table Cell Editor. The values within the table column are used as autocompletion terms within theComboBoxModel. This version ofcreateTableCellEditorassumes that the values stored in the TableModel at the givencolumnIndexare allComparable, and that the natural ordering defined by thoseComparablevalues also determines which are duplicates (and thus can safely be removed) and which are unique (and thus must remain in theComboBoxModel). Note that this factory method is only appropriate for use when the values in theComboBoxModelshould be the unique set of values in a table column. If some other list of values will be used thencreateTableCellEditor(EventList)is the appropriate factory method to use. If the appearance or function of the autocompletingJComboBoxis to be customized, it can be retrieved usingAutoCompleteCellEditor.getComponent().
- Parameters:
tableFormat- specifies how each row object within a table is broken apart into column valuestableData- theEventListbacking the TableModelcolumnIndex- the index of the column for which to return aAutoCompleteSupport.AutoCompleteCellEditor
- Returns:
- a
AutoCompleteSupport.AutoCompleteCellEditorwhich contains an autocompleting combobox whose contents remain consistent with the data in the table column at the givencolumnIndex
public staticAutoCompleteSupport install(JComboBox comboBox, EventList items)
Installs support for autocompletion into thecomboBoxand returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()at some later time to remove the autocompletion features. This method assumes that theitemscan be converted into reasonable String representations viaObject.toString(). The following must be true in order to successfully install support for autocompletion on aJComboBox:
- The JComboBox must use a
JTextFieldas its editor component- The JTextField must use an
AbstractDocumentas its model
- Parameters:
comboBox- theJComboBoxto decorate with autocompletionitems- the objects to display in thecomboBox
- Returns:
- an instance of the support class providing autocomplete features
public staticAutoCompleteSupport install(JComboBox comboBox, EventList items, E> filterator)
Installs support for autocompletion into thecomboBoxand returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()at some later time to remove the autocompletion features. This method assumes that theitemscan be converted into reasonable String representations viaObject.toString(). Thefilteratorwill be used to extract searchable text strings from each of theitems. Anullfilterator implies the item's toString() method should be used when filtering it. The following must be true in order to successfully install support for autocompletion on aJComboBox:
- The JComboBox must use a
JTextFieldas its editor component- The JTextField must use an
AbstractDocumentas its model
- Parameters:
comboBox- theJComboBoxto decorate with autocompletionitems- the objects to display in thecomboBoxfilterator- extracts searchable text strings from each item;nullimplies the item's toString() method should be used when filtering it
- Returns:
- an instance of the support class providing autocomplete features
public staticAutoCompleteSupport install(JComboBox comboBox, EventList items, E> filterator, Format format)
Installs support for autocompletion into thecomboBoxand returns the support object that is actually providing those facilities. The support object is returned so that the caller may invokeuninstall()at some later time to remove the autocompletion features. This method uses the givenformatto convert the givenitemsinto Strings and back again. In other words, this method does NOT rely onObject.toString()to produce a reasonable String representation of each item. Likewise, it does not rely on the existence of a valueOf(String) method for creating items out of Strings as is the default behaviour of JComboBox. It can be assumed that the only methods called on the givenformatare:As a convenience, this method will install a custom
Format.format(Object)Format.parseObject(String, ParsePosition)ListCellRendereron thecomboBoxthat displays the String value returned by theformat. Though this is only done if the givenformatis notnulland if thecomboBoxdoes not already use a custom renderer. Thefilteratorwill be used to extract searchable text strings from each of theitems. Anullfilterator implies one of two default strategies will be used. If theformatis not null then the String value returned from theformatobject will be used when filtering a given item. Otherwise, the item's toString() method will be used when it is filtered. The following must be true in order to successfully install support for autocompletion on aJComboBox:
- The JComboBox must use a
JTextFieldas its editor component- The JTextField must use an
AbstractDocumentas its model
- Parameters:
comboBox- theJComboBoxto decorate with autocompletionitems- the objects to display in thecomboBoxfilterator- extracts searchable text strings from each item. If theformatis not null then the String value returned from theformatobject will be used when filtering a given item. Otherwise, the item's toString() method will be used when it is filtered.format- a Format object capable of convertingitemsinto Strings and back.nullindicates the standard JComboBox methods of converting are acceptable.
- Returns:
- an instance of the support class providing autocomplete features
public boolean getBeepOnStrictViolation()
Returns true if a beep sound is played when the user attempts to violate the strict invariant; false if no beep sound is played. This setting is only respected ifisStrict()returns true.
- See Also:
setStrict(boolean)
public JComboBox getComboBox()
public boolean getCorrectsCase()
Returns true if user specified strings are converted to the case of the autocompletion term they match; false otherwise.
public int getFilterMode()
Returns the manner in which the contents of theComboBoxModelare filtered. This method will return one ofTextMatcherEditor.CONTAINSorTextMatcherEditor.STARTS_WITH.TextMatcherEditor.CONTAINSindicates elements of theComboBoxModelare matched when they contain the text entered by the user.TextMatcherEditor.STARTS_WITHindicates elements of theComboBoxModelare matched when they start with the text entered by the user. In both modes, autocompletion only occurs when a given item starts with user-specified text. The filter mode only affects the filtering aspect of autocomplete support.
public E getFirstItem()
Returns the optional single value used as the first element in theComboBoxModelor null if no first item has been set.
- Returns:
- the special first value presented in the
ComboBoxModelor null if no first item has been set
public boolean getHidesPopupOnFocusLost()
Returns true if the popup menu is hidden whenever the combo box editor loses focus; false otherwise.
public EventListgetItemList()
Returns the filteredEventListof items which backs theComboBoxModelof the autocompletingJComboBox.
public boolean getSelectsTextOnFocusGain()
Returns true if the combo box editor text is selected when it gains focus; false otherwise.
public Object getTextMatchingStrategy()
Returns the manner in which the contents of theComboBoxModelare filtered and autocompletion terms are matched. The returnedstrategyis one ofTextMatcherEditor.IDENTICAL_STRATEGYorTextMatcherEditor.NORMALIZED_STRATEGYor the Unicode strategy of the ICU4J extension.
public boolean isInstalled()
Returns true if this autocomplete support instance is currently installed and altering the behaviour of the combo box; false if it has beenuninstall()ed.
public boolean isStrict()
Returns true if the user is able to specify values which do not appear in the popup list of suggestions; false otherwise.
public E removeFirstItem()
Removes and returns the optional single value used as the first element in theComboBoxModelor null if no first item has been set.
- Returns:
- the special first value presented in the
ComboBoxModelor null if no first item has been set
public void setBeepOnStrictViolation(boolean beepOnStrictViolation)
Sets the policy for indicating strict-mode violations to the user by way of a beep sound.
- Parameters:
beepOnStrictViolation- true if a beep sound should be played when the user attempts to violate the strict invariant; false if no beep sound should be played
public void setCorrectsCase(boolean correctCase)
IfcorrectCaseis true, user specified strings will be converted to the case of the element they match. Otherwise they will be left unaltered. Note: this flag only has meeting when strict mode is turned off. When strict mode is on, case is corrected regardless of this setting.
- See Also:
setStrict(boolean)
public void setFilterMode(int mode)
Sets the manner in which the contents of theComboBoxModelare filtered. The givenmodemust be one ofTextMatcherEditor.CONTAINSorTextMatcherEditor.STARTS_WITH.
- See Also:
getFilterMode()
public void setFirstItem(E item)
This method set a single optional value to be used as the first element in theComboBoxModel. This value typically represents "no selection" or "blank". This value is always present and is not filtered away during autocompletion.
- Parameters:
item- the first value to present in theComboBoxModel
public void setHidesPopupOnFocusLost(boolean hidesPopupOnFocusLost)
IfhidesPopupOnFocusLostis true, then the popup menu of the combo box is always hidden whenever the combo box editor loses focus. If it is false the default behaviour is preserved. In practice this means that if focus is lost because of a MouseEvent, the behaviour is reasonable, but if focus is lost because of a KeyEvent (e.g. tabbing to the next focusable component) then the popup menu remains visible.
public void setSelectsTextOnFocusGain(boolean selectsTextOnFocusGain)
IfselectsTextOnFocusGainis true, all text in the editor is selected when the combo box editor gains focus. If it is false the selection state of the editor is not effected by focus changes.
public void setStrict(boolean strict)
Ifstrictis false, the user can specify values not appearing within the ComboBoxModel. If it is true each keystroke must continue to match some value in the ComboBoxModel or it will be discarded. Note: When strict mode is enabled, all user input is corrected to the case of the autocompletion term, regardless of the correctsCase setting.
- See Also:
setCorrectsCase(boolean)
public void setTextMatchingStrategy(Object strategy)
Sets the manner in which the contents of theComboBoxModelare filtered and autocompletion terms are matched. The givenstrategymust be one ofTextMatcherEditor.IDENTICAL_STRATEGYorTextMatcherEditor.NORMALIZED_STRATEGYor the Unicode strategy of the ICU4J extension.
- See Also:
getTextMatchingStrategy()
public TextFilterator super E> getTextFilterator()
Returns theTextFilteratorthat extracts searchable strings from each item in theComboBoxModel.
public void uninstall()
This method removes autocompletion support from theJComboBoxit was installed on. This method is useful when theEventListof items that backs the combo box must outlive the combo box itself. Calling this method will return the combo box to its original state before autocompletion was installed, and it will be available for garbage collection independently of theEventListof items.