public class TableCombo
extends org.eclipse.swt.widgets.Composite
TableCombo was written to allow the user to be able to display multiple columns of data in the "Drop Down" portion of the combo.
Special Note: Although this class is a subclass of Composite
, it
does not make sense to add children to it, or set a layout on it.
Constructor and Description |
---|
TableCombo(org.eclipse.swt.widgets.Composite parent,
int style)
Constructs a new instance of this class given its parent and a style value
describing its behavior and appearance.
|
Modifier and Type | Method and Description |
---|---|
void |
addModifyListener(org.eclipse.swt.events.ModifyListener listener)
Adds the listener to the collection of listeners who will be notified when
the receiver's text is modified, by sending it one of the messages defined in
the
ModifyListener interface. |
void |
addSelectionListener(org.eclipse.swt.events.SelectionListener listener)
Adds the listener to the collection of listeners who will be notified when
the user changes the receiver's selection, by sending it one of the messages
defined in the
SelectionListener interface. |
void |
addTextControlKeyListener(org.eclipse.swt.events.KeyListener listener)
Adds the listener to the collection of listeners who will be notified when
the user presses keys in the text field.
|
void |
addVerifyListener(org.eclipse.swt.events.VerifyListener listener)
Adds the listener to the collection of listeners who will be notified when
the receiver's text is verified, by sending it one of the messages defined in
the
VerifyListener interface. |
void |
clearSelection()
Sets the selection in the receiver's text field to an empty selection
starting just before the first character.
|
org.eclipse.swt.graphics.Point |
computeSize(int wHint,
int hHint,
boolean changed) |
void |
copy()
Copies the selected text.
|
(package private) void |
createPopup(int selectionIndex)
creates the popup shell.
|
void |
cut()
Cuts the selected text.
|
void |
defineColumns(int numberOfColumnsToCreate)
Defines what columns the drop down table will have.
|
void |
defineColumns(int[] columnBounds)
Defines what columns the drop down table will have.
|
void |
defineColumns(java.lang.String[] columnHeaders)
Defines what columns the drop down table will have.
|
void |
defineColumns(java.lang.String[] columnHeaders,
int[] columnBounds)
Defines what columns the drop down table will have.
|
(package private) void |
dropDown(boolean drop)
handle DropDown request
|
org.eclipse.swt.widgets.Button |
getArrowControl()
Returns the Arrow control reference.
|
boolean |
getEditable()
Gets the editable state.
|
java.lang.String |
getItem(int index)
Returns the item at the given, zero-relative index in the receiver's list.
|
int |
getItemCount()
Returns the number of items contained in the receiver's list.
|
int |
getItemHeight()
Returns the height of the area which would be used to display one of
the items in the receiver's list.
|
java.lang.String[] |
getItems()
Returns an array of
String s which are the items in the
receiver's list. |
org.eclipse.swt.graphics.Point |
getSelection()
Returns a
Point whose x coordinate is the start of the selection
in the receiver's text field, and whose y coordinate is the end of the
selection. |
int |
getSelectionIndex()
Returns the zero-relative index of the item which is currently selected in
the receiver's list, or -1 if no item is selected.
|
int |
getStyle() |
org.eclipse.swt.widgets.Table |
getTable()
returns the Table reference.
|
java.lang.String |
getText()
Returns a string containing a copy of the contents of the receiver's text
field.
|
org.eclipse.swt.widgets.Text |
getTextControl()
Returns the Text control reference.
|
int |
getTextHeight()
Returns the height of the receivers's text field.
|
int |
getVisibleItemCount()
Gets the number of items that are visible in the drop down portion of the
receiver's list.
|
int |
indexOf(java.lang.String string)
Searches the receiver's list starting at the first item (index 0) until an
item is found that is equal to the argument, and returns the index of that
item.
|
int |
indexOf(java.lang.String string,
int start)
Searches the receiver's list starting at the given, zero-relative index until
an item is found that is equal to the argument, and returns the index of that
item.
|
(package private) void |
initAccessible()
Add Accessbile listeners to label and table.
|
boolean |
isFocusControl() |
void |
paste()
Pastes text from clipboard.
|
void |
redraw() |
void |
redraw(int x,
int y,
int width,
int height,
boolean all) |
void |
removeModifyListener(org.eclipse.swt.events.ModifyListener listener)
Removes the listener from the collection of listeners who will be notified
when the receiver's text is modified.
|
void |
removeSelectionListener(org.eclipse.swt.events.SelectionListener listener)
Removes the listener from the collection of listeners who will be notified
when the user changes the receiver's selection.
|
void |
removeTextControlKeyListener(org.eclipse.swt.events.KeyListener listener)
Removes the listener from the collection of listeners who will be notified
when the user presses keys in the text control.
|
void |
removeVerifyListener(org.eclipse.swt.events.VerifyListener listener)
Removes the listener from the collection of listeners who will be notified
when the control is verified.
|
void |
select(int index)
Selects the item at the given zero-relative index in the receiver's list.
|
(package private) void |
selectedImageEvent(org.eclipse.swt.widgets.Event event) |
void |
setBackground(org.eclipse.swt.graphics.Color color) |
void |
setBorderColor(org.eclipse.swt.graphics.Color color)
Sets the receiver's border color to the color specified by the argument, or
to the default system color for the control if the argument is null.
|
void |
setClosePopupAfterSelection(boolean closePopupAfterSelection)
Modifies the behavior of the popup after an entry was selected.
|
void |
setDisplayColumnIndex(int displayColumnIndex)
Sets the zero-relative column index that will be used to display the
currently selected item in the label control.
|
void |
setEditable(boolean editable)
Sets the editable state.
|
void |
setEnabled(boolean enabled) |
void |
setEvenLinesBackgroundColor(org.eclipse.swt.graphics.Color color)
Sets the receiver's background color for even lines to the color specified by
the argument, or to the default system color for the control if the argument
is null.
|
void |
setEvenLinesForegroundColor(org.eclipse.swt.graphics.Color color)
Sets the receiver's color for even lines to the color specified by the
argument, or to the default system color for the control if the argument is
null.
|
boolean |
setFocus() |
void |
setFont(org.eclipse.swt.graphics.Font font) |
void |
setForeground(org.eclipse.swt.graphics.Color color) |
void |
setLayout(org.eclipse.swt.widgets.Layout layout)
Sets the layout which is associated with the receiver to be the argument
which may be null.
|
void |
setOddLinesBackgroundColor(org.eclipse.swt.graphics.Color color)
Sets the receiver's background color for odd lines to the color specified by
the argument, or to the default system color for the control if the argument
is null.
|
void |
setOddLinesForegroundColor(org.eclipse.swt.graphics.Color color)
Sets the receiver's color for odd lines to the color specified by the
argument, or to the default system color for the control if the argument is
null.
|
void |
setSelection(org.eclipse.swt.graphics.Point selection)
Sets the selection in the receiver's text field to the range specified by the
argument whose x coordinate is the start of the selection and whose y
coordinate is the end of the selection.
|
void |
setShowColorWithinSelection(boolean showColorWithinSelection) |
void |
setShowFontWithinSelection(boolean showFontWithinSelection) |
void |
setShowImageWithinSelection(boolean showImageWithinSelection) |
void |
setShowTableHeader(boolean showTableHeader)
sets whether or not to show table header.
|
void |
setShowTableLines(boolean showTableLines)
sets whether or not to show table lines
|
void |
setTableVisible(boolean visible)
Marks the receiver's list as visible if the argument is
true ,
and marks it invisible otherwise. |
void |
setTableWidthPercentage(int ddWidthPct)
Sets the table width percentage in relation to the width of the label
control.
|
void |
setText(java.lang.String string)
Sets the contents of the receiver's text field to the given string.
|
void |
setTextLimit(int limit)
Sets the maximum number of characters that the receiver's text field is
capable of holding to be the argument.
|
void |
setToolTipText(java.lang.String tipText) |
void |
setUpdateSelectionOnEnter(boolean selectOnEnter)
Allows to change the on enter behavior when the drop-down is shown.
|
void |
setUpdateTextWithinSelection(boolean updateTextWithinSelection)
Whether a selection change should automatically update the combo's text to
the selection's text.
|
void |
setVisible(boolean visible) |
void |
setVisibleItemCount(int count)
Sets the number of items that are visible in the drop down portion of the
receiver's list.
|
(package private) void |
textEvent(org.eclipse.swt.widgets.Event event) |
changed, checkSubclass, drawBackground, getBackgroundMode, getChildren, getLayout, getLayoutDeferred, getTabList, isLayoutDeferred, layout, layout, layout, layout, layout, setBackgroundMode, setLayoutDeferred, setTabList
computeTrim, getClientArea, getHorizontalBar, getScrollbarsMode, getVerticalBar
addControlListener, addDragDetectListener, addFocusListener, addGestureListener, addHelpListener, addKeyListener, addMenuDetectListener, addMouseListener, addMouseMoveListener, addMouseTrackListener, addMouseWheelListener, addPaintListener, addTouchListener, addTraverseListener, computeSize, dragDetect, dragDetect, forceFocus, getAccessible, getBackground, getBackgroundImage, getBorderWidth, getBounds, getCursor, getDragDetect, getEnabled, getFont, getForeground, getLayoutData, getLocation, getMenu, getMonitor, getOrientation, getParent, getRegion, getShell, getSize, getTextDirection, getToolTipText, getTouchEnabled, getVisible, internal_dispose_GC, internal_new_GC, isEnabled, isReparentable, isVisible, moveAbove, moveBelow, pack, pack, print, removeControlListener, removeDragDetectListener, removeFocusListener, removeGestureListener, removeHelpListener, removeKeyListener, removeMenuDetectListener, removeMouseListener, removeMouseMoveListener, removeMouseTrackListener, removeMouseWheelListener, removePaintListener, removeTouchListener, removeTraverseListener, requestLayout, setBackgroundImage, setBounds, setBounds, setCapture, setCursor, setDragDetect, setLayoutData, setLocation, setLocation, setMenu, setOrientation, setParent, setRedraw, setRegion, setSize, setSize, setTextDirection, setTouchEnabled, toControl, toControl, toDisplay, toDisplay, traverse, traverse, traverse, update
addDisposeListener, addListener, checkWidget, dispose, getData, getData, getDisplay, getListeners, isAutoDirection, isDisposed, isListening, notifyListeners, removeDisposeListener, removeListener, removeListener, reskin, setData, setData, toString
public TableCombo(org.eclipse.swt.widgets.Composite parent, int style)
The style value is either one of the style constants defined in class
SWT
which is applicable to instances of this class, or must be
built by bitwise OR'ing together (that is, using the
int
"|" operator) two or more of those SWT
style
constants. The class description lists the style constants that are
applicable to the class. Style bits are also inherited from superclasses.
parent
- a widget which will be the parent of the new instance (cannot be
null)style
- the style of widget to constructjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- SWT.BORDER
,
SWT.READ_ONLY
,
SWT.FLAT
,
Widget.getStyle()
public void addModifyListener(org.eclipse.swt.events.ModifyListener listener)
ModifyListener
interface.listener
- the listener which should be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- ModifyListener
,
removeModifyListener(org.eclipse.swt.events.ModifyListener)
public void addSelectionListener(org.eclipse.swt.events.SelectionListener listener)
SelectionListener
interface.
widgetSelected
is called when the combo's list selection
changes. widgetDefaultSelected
is typically called when ENTER is
pressed the combo's text area.
listener
- the listener which should be notified when the user changes the
receiver's selectionjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- SelectionListener
,
removeSelectionListener(org.eclipse.swt.events.SelectionListener)
,
SelectionEvent
public void addTextControlKeyListener(org.eclipse.swt.events.KeyListener listener)
listener
- the listener which should be notified when the user presses keys
in the text control.java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void removeTextControlKeyListener(org.eclipse.swt.events.KeyListener listener)
listener
- the listener which should no longer be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void addVerifyListener(org.eclipse.swt.events.VerifyListener listener)
VerifyListener
interface.listener
- the listener which should be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- VerifyListener
,
removeVerifyListener(org.eclipse.swt.events.VerifyListener)
public void clearSelection()
Note: To clear the selected items in the receiver's list, use
deselectAll()
.
org.eclipse.swt.SWTException
- #deselectAll
public org.eclipse.swt.graphics.Point computeSize(int wHint, int hHint, boolean changed)
computeSize
in class org.eclipse.swt.widgets.Control
public void copy()
The current selection is copied to the clipboard.
org.eclipse.swt.SWTException
- void createPopup(int selectionIndex)
selectionIndex
- public void cut()
The current selection is first copied to the clipboard and then deleted from the widget.
org.eclipse.swt.SWTException
- void dropDown(boolean drop)
drop
- public boolean getEditable()
org.eclipse.swt.SWTException
- public java.lang.String getItem(int index)
index
- the index of the item to returnjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public int getItemCount()
org.eclipse.swt.SWTException
- public int getItemHeight()
org.eclipse.swt.SWTException
- public java.lang.String[] getItems()
String
s which are the items in the
receiver's list.
Note: This is not the actual structure used by the receiver to maintain its list of items, so modifying the array will not affect the receiver.
org.eclipse.swt.SWTException
- public org.eclipse.swt.graphics.Point getSelection()
Point
whose x coordinate is the start of the selection
in the receiver's text field, and whose y coordinate is the end of the
selection. The returned values are zero-relative. An "empty" selection as
indicated by the the x and y coordinates having the same value.org.eclipse.swt.SWTException
- public int getSelectionIndex()
org.eclipse.swt.SWTException
- public int getStyle()
getStyle
in class org.eclipse.swt.widgets.Widget
public java.lang.String getText()
org.eclipse.swt.SWTException
- public int getTextHeight()
org.eclipse.swt.SWTException
- public int getVisibleItemCount()
org.eclipse.swt.SWTException
- public int indexOf(java.lang.String string)
string
- the search itemjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public int indexOf(java.lang.String string, int start)
string
- the search itemstart
- the zero-relative index at which to begin the searchjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setShowTableLines(boolean showTableLines)
showTableLines
- public void setShowTableHeader(boolean showTableHeader)
showTableHeader
- void initAccessible()
public boolean isFocusControl()
isFocusControl
in class org.eclipse.swt.widgets.Control
public void setUpdateSelectionOnEnter(boolean selectOnEnter)
true
.selectOnEnter
- true
if pressing enter should set the combo selection
to the last selected element in the table, false
if
combo selection should not changepublic void paste()
The selected text is deleted from the widget and new text inserted from the clipboard.
org.eclipse.swt.SWTException
- public void redraw()
redraw
in class org.eclipse.swt.widgets.Control
public void redraw(int x, int y, int width, int height, boolean all)
redraw
in class org.eclipse.swt.widgets.Control
public void removeModifyListener(org.eclipse.swt.events.ModifyListener listener)
listener
- the listener which should no longer be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- ModifyListener
,
addModifyListener(org.eclipse.swt.events.ModifyListener)
public void removeSelectionListener(org.eclipse.swt.events.SelectionListener listener)
listener
- the listener which should no longer be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- SelectionListener
,
addSelectionListener(org.eclipse.swt.events.SelectionListener)
public void removeVerifyListener(org.eclipse.swt.events.VerifyListener listener)
listener
- the listener which should no longer be notifiedjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- VerifyListener
,
addVerifyListener(org.eclipse.swt.events.VerifyListener)
public void select(int index)
index
- the index of the item to selectorg.eclipse.swt.SWTException
- public void setBackground(org.eclipse.swt.graphics.Color color)
setBackground
in class org.eclipse.swt.widgets.Control
public void setEditable(boolean editable)
editable
- the new editable stateorg.eclipse.swt.SWTException
- public void setEnabled(boolean enabled)
setEnabled
in class org.eclipse.swt.widgets.Control
public boolean setFocus()
setFocus
in class org.eclipse.swt.widgets.Composite
public void setFont(org.eclipse.swt.graphics.Font font)
setFont
in class org.eclipse.swt.widgets.Control
public void setForeground(org.eclipse.swt.graphics.Color color)
setForeground
in class org.eclipse.swt.widgets.Control
public void setLayout(org.eclipse.swt.widgets.Layout layout)
Note : No Layout can be set on this Control because it already manages the size and position of its children.
setLayout
in class org.eclipse.swt.widgets.Composite
layout
- the receiver's new layout or nullorg.eclipse.swt.SWTException
- public void setTableVisible(boolean visible)
true
,
and marks it invisible otherwise.
If one of the receiver's ancestors is not visible or some other condition makes the receiver not visible, marking it visible may not actually cause it to be displayed.
visible
- the new visibility stateorg.eclipse.swt.SWTException
- public void setSelection(org.eclipse.swt.graphics.Point selection)
selection
- a point representing the new selection start and endjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setText(java.lang.String string)
Note: The text field in a Combo
is typically only capable of
displaying a single line of text. Thus, setting the text to a string
containing line breaks or other special characters will probably cause it to
display incorrectly.
string
- the new textjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setTextLimit(int limit)
limit
- new text limitjava.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setToolTipText(java.lang.String tipText)
setToolTipText
in class org.eclipse.swt.widgets.Control
public void setVisible(boolean visible)
setVisible
in class org.eclipse.swt.widgets.Control
public void setVisibleItemCount(int count)
count
- the new number of items to be visibleorg.eclipse.swt.SWTException
- public void defineColumns(java.lang.String[] columnHeaders)
columnHeaders
- columnWidths
- public void defineColumns(int[] columnBounds)
columnHeaders
- columnBounds
- public void defineColumns(int numberOfColumnsToCreate)
columnHeaders
- columnWidths
- public void defineColumns(java.lang.String[] columnHeaders, int[] columnBounds)
columnHeaders
- columnBounds
- public void setTableWidthPercentage(int ddWidthPct)
ddWidthPct
- public void setDisplayColumnIndex(int displayColumnIndex)
displayColumnIndex
- public void setClosePopupAfterSelection(boolean closePopupAfterSelection)
true
the popup will be closed, if false
it will remain open.closePopupAfterSelection
- public void setShowImageWithinSelection(boolean showImageWithinSelection)
showImageWithinSelection
- public void setShowColorWithinSelection(boolean showColorWithinSelection)
showColorWithinSelection
- public void setShowFontWithinSelection(boolean showFontWithinSelection)
showFontWithinSelection
- public void setUpdateTextWithinSelection(boolean updateTextWithinSelection)
true
.updateTextWithinSelection
- true
if selection changes will update the combo's
text accordingly; false
if no text changes are
desired. Clients have to update the text manuallypublic org.eclipse.swt.widgets.Table getTable()
void textEvent(org.eclipse.swt.widgets.Event event)
void selectedImageEvent(org.eclipse.swt.widgets.Event event)
public org.eclipse.swt.widgets.Text getTextControl()
public org.eclipse.swt.widgets.Button getArrowControl()
public void setBorderColor(org.eclipse.swt.graphics.Color color)
color
- the new color (or null)java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setOddLinesBackgroundColor(org.eclipse.swt.graphics.Color color)
color
- the new color (or null)java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setOddLinesForegroundColor(org.eclipse.swt.graphics.Color color)
color
- the new color (or null)java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setEvenLinesForegroundColor(org.eclipse.swt.graphics.Color color)
color
- the new color (or null)java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
- public void setEvenLinesBackgroundColor(org.eclipse.swt.graphics.Color color)
color
- the new color (or null)java.lang.IllegalArgumentException
- org.eclipse.swt.SWTException
-