|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object thinwire.ui.DropDown<DateBox> thinwire.ui.DropDownDateBox
public class DropDownDateBox
A DropDownDateBox
is a DropDown
that contains
a DateBox
.
Example:
final Dialog dlg = new Dialog("DateBox Test"); dlg.setBounds(10, 10, 320, 240); DropDownDateBox dd = new DropDownDateBox(); dd.setBounds(10, 10, 200, 20); dlg.getChildren().add(dd); dlg.setVisible(true);
Keyboard Navigation:
KEY | RESPONSE | NOTE |
Down Arrow | Drops the DateBox down. | Only if the component has focus. |
Esc | Closes the DateBox | Only if the component has focus. |
Nested Class Summary |
---|
Nested classes/interfaces inherited from class thinwire.ui.DropDown |
---|
DropDown.AbstractView<T extends Component>, DropDown.View<T extends Component> |
Nested classes/interfaces inherited from interface thinwire.ui.AlignTextComponent |
---|
AlignTextComponent.AlignX |
Field Summary |
---|
Fields inherited from class thinwire.ui.DropDown |
---|
PROPERTY_COMPONENT, PROPERTY_EDIT_ALLOWED, PROPERTY_VIEW |
Fields inherited from interface thinwire.ui.MaskEditorComponent |
---|
PROPERTY_EDIT_MASK, PROPERTY_FORMAT_TEXT |
Fields inherited from interface thinwire.ui.EditorComponent |
---|
PROPERTY_CURSOR_INDEX, PROPERTY_MAX_LENGTH, PROPERTY_SELECTION_BEGIN_INDEX, PROPERTY_SELECTION_END_INDEX |
Fields inherited from interface thinwire.ui.AlignTextComponent |
---|
PROPERTY_ALIGN_X |
Fields inherited from interface thinwire.ui.TextComponent |
---|
PROPERTY_TEXT |
Fields inherited from interface thinwire.ui.Component |
---|
ACTION_CLICK, ACTION_DOUBLE_CLICK, PROPERTY_ENABLED, PROPERTY_FOCUS, PROPERTY_FOCUS_CAPABLE, PROPERTY_HEIGHT, PROPERTY_LIMIT, PROPERTY_USER_OBJECT, PROPERTY_VISIBLE, PROPERTY_WIDTH, PROPERTY_X, PROPERTY_Y |
Constructor Summary | |
---|---|
DropDownDateBox()
|
|
DropDownDateBox(java.lang.String text)
Creates a DropDownDateBox initialized a specific date |
Method Summary | |
---|---|
void |
addActionListener(java.lang.String[] actions,
ActionListener listener)
Adds a ActionListener to this component that will be notified when any of the specified actions occur. |
void |
addActionListener(java.lang.String action,
ActionListener listener)
Adds a ActionListener to this component that will be notified when the specified action occurs. |
void |
addDropListener(Component[] dragComponents,
DropListener listener)
|
void |
addDropListener(Component dragComponent,
DropListener listener)
|
void |
addKeyPressListener(java.lang.String[] keyPressCombos,
KeyPressListener listener)
Adds a KeyPressListener that will be notified when any of the specified key press combinations occur. |
void |
addKeyPressListener(java.lang.String keyPressCombo,
KeyPressListener listener)
Adds a KeyPressListener that will be notified when the specified key press combination occurs. |
void |
addPropertyChangeListener(java.lang.String[] propertyNames,
PropertyChangeListener listener)
Adds a PropertyChangeListener to this component that will be notified when any of the specified properties
change. |
void |
addPropertyChangeListener(java.lang.String propertyName,
PropertyChangeListener listener)
Adds a PropertyChangeListener to this componetn that will be notified when the specified property changes. |
void |
fireAction(ActionEvent ev)
Programmatically signals an action which triggers the appropriate listener which calls the desired method. |
void |
fireAction(java.lang.String action)
A convenience method that is equal to this.fireAction(new ActionEvent(this, action)); |
void |
fireAction(java.lang.String action,
java.lang.Object source)
A convenience method that is equal to this.fireAction(new ActionEvent(this, action)); |
void |
fireDrop(Component dragComponent)
|
void |
fireDrop(Component dragComponent,
java.lang.Object dragObject)
|
void |
fireDrop(DropEvent ev)
|
void |
fireKeyPress(KeyPressEvent ev)
Allows you to programmatically trigger a key press combination. |
void |
fireKeyPress(java.lang.String keyPressCombo)
A convenience method that is equal to this.fireKeyPress(new KeyPressEvent(keyPressCombo, this)); |
protected boolean |
firePropertyChange(java.lang.Object source,
java.lang.String propertyName,
boolean oldValue,
boolean newValue)
|
protected boolean |
firePropertyChange(java.lang.Object source,
java.lang.String propertyName,
int oldValue,
int newValue)
|
protected boolean |
firePropertyChange(java.lang.Object source,
java.lang.String propertyName,
java.lang.Object oldValue,
java.lang.Object newValue)
|
AlignTextComponent.AlignX |
getAlignX()
Get this label's text justification |
Container |
getContainer()
Returns the parent Container of this Component . |
int |
getCursorIndex()
Retuns the index of the current cursor position |
java.lang.String |
getEditMask()
Get this TextField's edit mask |
int |
getHeight()
Returns the height of this Component . |
Label |
getLabel()
Returns the Label assigned to this Component . |
java.lang.Object |
getLimit()
Gets the layout limit that controls the bounds of this component within the context of the parent Container 's layout. |
int |
getMaxLength()
Gets the TextField's max length. |
java.lang.Object |
getParent()
Returns the parent Object of this Component . |
int |
getSelectionBeginIndex()
Returns the index of the beginning of the selection |
int |
getSelectionEndIndex()
Returns the index of the end of the selection |
Style |
getStyle()
Returns a Style object representing this Component 's current style settings. |
java.lang.String |
getText()
This method will return the text in the field as a String. |
java.lang.Object |
getUserObject()
Returns the user defined Object for this Component . |
int |
getWidth()
Returns the width of this Component . |
int |
getX()
Returns the X coordinate of this Component . |
int |
getY()
Returns the Y coordinate of this Component . |
boolean |
isEnabled()
Returns whether this Component is enabled and therefore supports user interaction. |
boolean |
isFocus()
Returns whether this Component has the input focus. |
boolean |
isFocusCapable()
Returns whether this Component supports gaining focus. |
boolean |
isFormatText()
Determines whether the text returned by getText() is formatted. |
boolean |
isVisible()
Returns a boolean value indicating whether this Component may be displayed in a window. |
void |
removeActionListener(ActionListener listener)
Unregister an ActionListener from all action event notifications from this component. |
void |
removeDropListener(DropListener listener)
|
void |
removeKeyPressListener(KeyPressListener listener)
Removes the specified KeyPressListener from the component. |
void |
removePropertyChangeListener(PropertyChangeListener listener)
Removes the specified PropertyChangeListener from the component. |
void |
setAlignX(AlignTextComponent.AlignX alignX)
Sets the text justification of the label (left, right, or center). |
Component |
setBounds(int x,
int y,
int width,
int height)
Assigns the specified width, height, X and Y values to this Component atomically, in one operation. |
void |
setCursorIndex(int index)
Sets the index of the cursor position Events: |
void |
setEditMask(java.lang.String editMask)
This method accepts an edit mask as a String and applies it to the TextField . |
void |
setEnabled(boolean enabled)
Assigns whether this Component is enabled and therefore supports user interaction. |
void |
setFocus(boolean focus)
Assigns whether this Component has the input focus. |
void |
setFocusCapable(boolean focusCapable)
Assigns whether this Component supports gaining focus. |
void |
setFormatText(boolean formatText)
Sets whether the text returned by getText() is formatted. |
void |
setHeight(int height)
Assigns the specified height to this Component .Default: 0 Events: |
Component |
setLimit(java.lang.Object limit)
Sets a layout limit that controls the bounds of this component within the context of the parent Container 's layout. |
void |
setMaxLength(int maxLength)
Sets the editor max length. |
Component |
setPosition(int x,
int y)
Assigns the specified X and Y coordinates to this Component atomically, in one operation. |
void |
setSelectionBeginIndex(int selectionBeginIndex)
Sets the index of the beginning of a selection Events: |
void |
setSelectionEndIndex(int selectionEndIndex)
Sets the index of the end of the selection Events: |
void |
setSelectionRange(int selectionBeginIndex,
int selectionEndIndex)
Sets the range of the selection Events: |
Component |
setSize(int width,
int height)
Assigns the specified width and height to this Component atomically, in one operation. |
void |
setUserObject(java.lang.Object userObject)
Assigns a user defined Object to this Component . |
void |
setVisible(boolean visible)
Assigns a boolean value indicating whether this Component may be displayed in a window. |
void |
setWidth(int width)
Assigns the specified width to this Component .Default: 0 Events: |
void |
setX(int x)
Assigns the specified X coordinate to this Component .Default: 0 Events: |
void |
setY(int y)
Assigns the specified Y coordinate to this Component .Default: 0 Events: |
Methods inherited from class thinwire.ui.DropDown |
---|
getComponent, getView, isEditAllowed, setComponent, setEditAllowed, setText, setView |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Methods inherited from interface thinwire.ui.EditorComponent |
---|
getCursorIndex, getMaxLength, getSelectionBeginIndex, getSelectionEndIndex, setCursorIndex, setMaxLength, setSelectionBeginIndex, setSelectionEndIndex, setSelectionRange |
Methods inherited from interface thinwire.ui.AlignTextComponent |
---|
getAlignX, setAlignX |
Methods inherited from interface thinwire.ui.TextComponent |
---|
getText |
Constructor Detail |
---|
public DropDownDateBox()
public DropDownDateBox(java.lang.String text)
text
- The formatted date to initilize the DateBox to (MM/dd/yyyy)Method Detail |
---|
public void setEditMask(java.lang.String editMask)
TextField
. The edit mask also defines the Format that the
Date is displayed.
setEditMask
in interface MaskEditorComponent
public java.lang.String getEditMask()
MaskEditorComponent
getEditMask
in interface MaskEditorComponent
public boolean isFormatText()
MaskEditorComponent
isFormatText
in interface MaskEditorComponent
public void setFormatText(boolean formatText)
MaskEditorComponent
setFormatText
in interface MaskEditorComponent
formatText
- true if you want the text formattted, false otherwise. Default is true.public void setSelectionRange(int selectionBeginIndex, int selectionEndIndex)
EditorComponent
If the prior values and new values differ, setting this property causes 2 PropertyChangeEvent
s ( propertyName = PROPERTY_SELECTION_BEGIN_INDEX and propertyName = PROPERTY_SELECTION_END_INDEX ) to be generated.
setSelectionRange
in interface EditorComponent
selectionBeginIndex
- the index of the start of the selectionselectionEndIndex
- the index of the end of the selectionEditorComponent.setSelectionBeginIndex(int)
,
EditorComponent.setSelectionEndIndex(int)
,
EditorComponent.PROPERTY_SELECTION_BEGIN_INDEX
,
EditorComponent.PROPERTY_SELECTION_END_INDEX
,
PropertyChangeEvent
public int getSelectionBeginIndex()
EditorComponent
getSelectionBeginIndex
in interface EditorComponent
#setSelectionBeginIndex()
public void setSelectionBeginIndex(int selectionBeginIndex)
EditorComponent
If the prior values and new values differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_SELECTION_BEGIN_INDEX ) to be generated.
setSelectionBeginIndex
in interface EditorComponent
selectionBeginIndex
- the index of the start of the selectionEditorComponent.getSelectionBeginIndex()
,
EditorComponent.setSelectionRange(int, int)
,
EditorComponent.PROPERTY_SELECTION_BEGIN_INDEX
,
PropertyChangeEvent
public int getSelectionEndIndex()
EditorComponent
getSelectionEndIndex
in interface EditorComponent
EditorComponent.setSelectionEndIndex(int)
public void setSelectionEndIndex(int selectionEndIndex)
EditorComponent
If the prior values and new values differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_SELECTION_END_INDEX ) to be generated.
setSelectionEndIndex
in interface EditorComponent
selectionEndIndex
- the index of the end of the selectionEditorComponent.getSelectionEndIndex()
,
EditorComponent.setSelectionRange(int, int)
,
EditorComponent.PROPERTY_SELECTION_END_INDEX
,
PropertyChangeEvent
public int getCursorIndex()
EditorComponent
getCursorIndex
in interface EditorComponent
EditorComponent.setCursorIndex(int)
public void setCursorIndex(int index)
EditorComponent
If the prior values and new values differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_CURSOR_INDEX ) to be generated.
setCursorIndex
in interface EditorComponent
index
- the index of the cursorEditorComponent.getCursorIndex()
,
EditorComponent.PROPERTY_CURSOR_INDEX
,
PropertyChangeEvent
public void setMaxLength(int maxLength)
EditorComponent
setMaxLength
in interface EditorComponent
maxLength
- The maxLength to set.public int getMaxLength()
EditorComponent
getMaxLength
in interface EditorComponent
public AlignTextComponent.AlignX getAlignX()
AlignTextComponent
getAlignX
in interface AlignTextComponent
public void setAlignX(AlignTextComponent.AlignX alignX)
AlignTextComponent
setAlignX
in interface AlignTextComponent
alignX
- (Default = AlignX.LEFT)public java.lang.String getText()
TextComponent
getText
in interface TextComponent
public void addPropertyChangeListener(java.lang.String propertyName, PropertyChangeListener listener)
Component
PropertyChangeListener
to this componetn that will be notified when the specified property changes.
Adding a property listener to a component allows your code to react to a state change within the component. final TextField tf = new TextField(); tf.setEnabled(false); CheckBox cb = new CheckBox("Check me to enable the TextField."); cb.addPropertyChangeListener(CheckBox.PROPERTY_CHECKED, new PropertyChangeListener() { public void propertyChange(PropertyChangeEvent pce) { if (pce.getNewValue() == Boolean.TRUE) { tf.setEnabled(true); } else { tf.setEnabled(false); } } });
addPropertyChangeListener
in interface Component
propertyName
- the name of the property that the listener will receive change events for.listener
- the listener that will receive PropertyChangeEvent
objects upon the property changing.PropertyChangeListener
,
PropertyChangeEvent
public void addPropertyChangeListener(java.lang.String[] propertyNames, PropertyChangeListener listener)
Component
PropertyChangeListener
to this component that will be notified when any of the specified properties
change. This method is equivalent to calling Component.addPropertyChangeListener(String, PropertyChangeListener)
once
for each property you want to listen to.
addPropertyChangeListener
in interface Component
propertyNames
- a string array of property names that the listener will receive change events for.listener
- the listerner that will receive PropertyChangeEvent
objects anytime one of the specified
propertyNames of this component change.Component.addPropertyChangeListener(String, PropertyChangeListener)
,
PropertyChangeListener
,
PropertyChangeEvent
public void removePropertyChangeListener(PropertyChangeListener listener)
Component
PropertyChangeListener
from the component. If the listener was added for multiple
properties, it will be removed for all of them. NOTE: An exception is NOT thrown if you attempt to remove a listener that
does not exist on this component.
removePropertyChangeListener
in interface Component
listener
- the listener to remove from the component.PropertyChangeListener
protected final boolean firePropertyChange(java.lang.Object source, java.lang.String propertyName, int oldValue, int newValue)
protected final boolean firePropertyChange(java.lang.Object source, java.lang.String propertyName, boolean oldValue, boolean newValue)
protected final boolean firePropertyChange(java.lang.Object source, java.lang.String propertyName, java.lang.Object oldValue, java.lang.Object newValue)
public void addActionListener(java.lang.String action, ActionListener listener)
Component
ActionListener
to this component that will be notified when the specified action occurs.
addActionListener
in interface Component
action
- the action to specficially be notified of.listener
- the event listener that will receive notification.public void addActionListener(java.lang.String[] actions, ActionListener listener)
Component
ActionListener
to this component that will be notified when any of the specified actions occur.
addActionListener
in interface Component
actions
- the actions to specficially be notified of.listener
- the event listener that will receive notification.public void removeActionListener(ActionListener listener)
Component
ActionListener
from all action event notifications from this component.
removeActionListener
in interface Component
listener
- the listener that should no longer receive action event notifications.public void fireAction(ActionEvent ev)
Component
fireAction
in interface Component
ev
- the event to signalpublic void fireAction(java.lang.String action)
Component
fireAction
in interface Component
action
- the action to perform on the component.public void fireAction(java.lang.String action, java.lang.Object source)
Component
fireAction
in interface Component
action
- the action to perform on the component.public void addDropListener(Component dragComponent, DropListener listener)
addDropListener
in interface Component
public void addDropListener(Component[] dragComponents, DropListener listener)
addDropListener
in interface Component
public void removeDropListener(DropListener listener)
removeDropListener
in interface Component
public void fireDrop(DropEvent ev)
fireDrop
in interface Component
public void fireDrop(Component dragComponent)
fireDrop
in interface Component
public void fireDrop(Component dragComponent, java.lang.Object dragObject)
fireDrop
in interface Component
public void addKeyPressListener(java.lang.String keyPressCombo, KeyPressListener listener)
Component
KeyPressListener
that will be notified when the specified key press combination occurs.
For a description and list of valid keyPressCombo
strings, see the documentation for
KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
.
Establishing keyboard shortcuts for certain features can be a highly effective way to improve the efficiency of your
application. If your application has a Menu
, then typically the best way to establish such shortcuts is to
simply set the keyPressCombo
property for each Menu.Item
. Second to that, using this method to
establish shortcuts on the Frame
or a Dialog
will have a similar wide reaching effect.
Occasionally, based on the requirements of your application, you may also use this method to establish shortcuts that are
only valid when a given component has focus.
When a user presses a key and/or combination, the event bubbles up the component hierarchy from the component that currently
has focus and is absorbed by the first Component
that has a listener asking to be notified of that event.
Therefore, if both a Component
and a Container
up the hierarchy are listening for the same
event, only the Component
will receive notification. There is currently no way to cause the event to continue
bubbling.
Additionally, the keyboard navigation of each Component
cannot be overridden and you cannot receive
notification of such events. As an example, establishing a KeyPressListener
for "Space" key on the
CheckBox
, will have no effect because the "Space" key toggles the checked state of that component.
NOTE ON WEBBROWSERS: If no Component
is listening for a given key press, then the default behavior that the
browser has associated with that key press will occur. Additionally, certain key press events in certain browsers cannot be
entirely circumvented. In such a case, both the action defined by a listener and the browser's default behavior will occur.
An example of this is the F1 key in Internet Explorer. If you establish a listener for the F1 key, the IE help file will open
in addition to whatever action you may have defined.
Application.current().getFrame().addKeyPressListener("Ctrl-Alt-M", new KeyPressListener() { public void keyPress(KeyPressEvent kpe) { MessageBox.confirm("You pressed the following key combination: " + kpe.getKeyPressCombo()); } });
addKeyPressListener
in interface Component
keyPressCombo
- a key press combo in any dash separated format supported by
KeyPressEvent.normalizeKeyPressCombo(String)
.listener
- the listener that will receive KeyPressEvent
objects upon the key press occurring.KeyPressListener
,
KeyPressEvent
,
KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
,
KeyPressEvent.normalizeKeyPressCombo(String)
public void addKeyPressListener(java.lang.String[] keyPressCombos, KeyPressListener listener)
Component
KeyPressListener
that will be notified when any of the specified key press combinations occur.
For a description and list of valid keyPressCombo
strings, see the documentation for
KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
.
See Component.addKeyPressListener(String, KeyPressListener)
for a full semantic description.
addKeyPressListener
in interface Component
keyPressCombos
- a string array of key press combos, each in any dash separated format supported by
KeyPressEvent.normalizeKeyPressCombo(String)
.listener
- the listener that will receive KeyPressEvent
objects when any of the key presses occur.Component.addKeyPressListener(String, KeyPressListener)
,
KeyPressListener
,
KeyPressEvent
,
KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
,
KeyPressEvent.normalizeKeyPressCombo(String)
public void removeKeyPressListener(KeyPressListener listener)
Component
KeyPressListener
from the component. If the listener was added for multiple
key press combinations, it will be removed for all of them. NOTE: An exception is NOT thrown if you attempt to remove a listener that
does not exist on this component.
removeKeyPressListener
in interface Component
listener
- the listener to remove from the component.KeyPressListener
public void fireKeyPress(KeyPressEvent ev)
Component
KeyPressEvent
being generated. As a result, all KeyPressListener
's that are registered on
the specified keyPressCombo
will be notified.
For a description and list of valid keyPressCombo
strings, see the documentation for
KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
.
A KeyPressEvent
that is generated programmatically via this mechansim may, under some circumstances, have a
slightly different behavior than one generated by user activity. The reason for this is that the event is only propagated
within the framework itself and does not actually occur in the client. In general, this should never be an issue because the
desired response to a keypress will be expressly defined by a given KeyPressListener
and therefore there would be
no dependence on any such side-effect. However, an example of one such
difference, is in terms of a browser's default behavior for a specific key press combination. If you use this mechanism
to trigger an F1 keypress, the browser's default behavior (typically bringing up a help window), will not occur.
fireKeyPress
in interface Component
ev
- a KeyPressEvent that represents the key press combo you want to signal has occured.public void fireKeyPress(java.lang.String keyPressCombo)
Component
fireKeyPress
in interface Component
keyPressCombo
- a key press combo in any dash separated format supported by
KeyPressEvent.normalizeKeyPressCombo(String)
.KeyPressEvent.encodeKeyPressCombo(boolean, boolean, boolean, String)
,
KeyPressEvent.normalizeKeyPressCombo(String)
public java.lang.Object getParent()
Component
Object
of this Component
. If you specifically need the parent
Container
of this Component
use Component.getContainer()
instead.
Under the majority of situations, the returned value is either a Container
or null
since a
Component
will either be a child of a Container
or not attached to any object. However, in some
cases the parent of the Component
may be another Component
, or a completely different kind of
Object
. For example, in the case of the DropDownGridBox
, there is an actual
GridBox
that is a child of the drop down. Therefore, the parent of that GridBox
would be the
DropDownGridBox
. Another situation exists when you use a multi-tiered GridBox
, meaning a
GridBox
that has one or more "pop-up" child GridBox
's. Under that scenario, the parent of the
child's GridBox
is actually an instance of GridBox.Row
and the parent of the row is the
GridBox
.
getParent
in interface Component
Object
of this Component
, or null
if no parent exists.Component.getContainer()
public Container getContainer()
Component
Container
of this Component
. Unlike getParent()
, this
method guarantees that if a non-null value is returned, it will be a Contaienr
.
getContainer
in interface Component
Container
of this Component
, or null
if no parent exists.Component.getParent()
public Label getLabel()
Component
Label
assigned to this Component
. This property is part of a two-way relationship
that is established by the Label.setLabelFor(Component)
property. There is no setLabel
method, instead use Label.setLabelFor(Component)
.
getLabel
in interface Component
Label
assigned to this Component
.public java.lang.Object getUserObject()
Component
Object
for this Component
.
getUserObject
in interface Component
Object
for this Component
, or null if no value has been specified.Component.setUserObject(Object)
public void setUserObject(java.lang.Object userObject)
Component
Object
to this Component
. This property has no direct effect
on the state of the Component
. Instead, it provides a general purpose storage
mechanism to the developer that allows any kind of data to be associated to this Component
.
For complex applications, alternate methods of associating state to a Component
will likely
serve your design more thoroughly. However, there are a number of cases where this flexibility could be useful
and therefore the framework supports the concept.
Refer to the documenation on Application.addGlobalPropertyChangeListener(String, PropertyChangeListener)
for an
example of a potential use of this property.
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_USER_OBJECT ) to be generated.
setUserObject
in interface Component
userObject
- an Object
of any type that is to be associated with this Component
.Component.getUserObject()
,
Application.addGlobalPropertyChangeListener(String, PropertyChangeListener)
,
Component.PROPERTY_USER_OBJECT
,
PropertyChangeEvent
public boolean isEnabled()
Component
Component
is enabled and therefore supports user interaction.
isEnabled
in interface Component
Component
supports user interaction, false otherwise.Component.setEnabled(boolean)
public void setEnabled(boolean enabled)
Component
Component
is enabled and therefore supports user interaction.
The form of user iteraction this property controls, depends on the specific kind of Component
itself. However, in general, all keyboard interaction and mouse interaction is disabled by
setting this property to false.
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_ENABLED ) to be generated.
setEnabled
in interface Component
enabled
- true to allow user interaction, false to disallow it.Component.isEnabled()
,
Component.PROPERTY_ENABLED
,
PropertyChangeEvent
public boolean isFocusCapable()
Component
Component
supports gaining focus. Divider
, Image
and Label
.
isFocusCapable
in interface Component
Component
supports gaining focus, false otherwise.Component.setFocusCapable(boolean)
,
Component.setFocus(boolean)
public void setFocusCapable(boolean focusCapable)
Component
Component
supports gaining focus. Divider
, Image
and Label
.
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_FOCUS_CAPABLE ) to be generated.
setFocusCapable
in interface Component
focusCapable
- true to allow this component to receive focus, false to disallow it.Component.isFocusCapable()
,
Component.PROPERTY_FOCUS_CAPABLE
,
Component.setFocus(boolean)
,
PropertyChangeEvent
public final boolean isFocus()
Component
Component
has the input focus. If this is a Container
, then this method
will return true if a child Component
has the focus. In such a case, you can use the
Container.getChildWithFocus()
method to get a reference to that child. Similarly, if you want to find the
child Component
that has the focus anywhere in the current Frame
or Dialog
, you
can use the Container.getComponentWithFocus()
method.
Default: false. However, at rendering time, if no component in the window has focus, the first focus capable component is given focus.
See the Component.setFocus(boolean)
method for a full description of focus details.
isFocus
in interface Component
Component
has the input focus, false otherwise.Component.setFocus(boolean)
,
Container.getComponentWithFocus()
,
Container.getChildWithFocus()
public void setFocus(boolean focus)
Component
Component
has the input focus. When this Component
has the input focus, it will receive all keyboard events generated by the user. Therefore,
if this Component
supports text editing and it has focus, the user can type a value
into it's field. Additionally, any keyboard navigation supported by this Component
or keyboard shortcuts added by a developer become available upon gaining focus. Conversely, when this Component
no longer has
focus, it will receive no keyboard events.
Default: false. However, at rendering time, if no component in the window has focus, the first focus capable component is given focus.
Details:
The simplest of all cases, is when this Component
has not yet been added to a Container
.
In that scenario, the focus property is simply set to true and no other effect occurs. Later, when this
Component
is added to a Container
it will be given the focus according to the guidelines
that follow.
As a general rule,
only a single Component
can have the focus per Frame
or Dialog
container hierarchy. In terms of the user interface, only a single Component
will actually
have the focus regardless of whether a Dialog
and the Frame
have components with focus.
In such a case, the actual focus is determined based on which window is currently active.
Since only one Component
per window can have focus, giving this Component
focus
will cause the prior Component
of the window to lose focus. In the most common case, both this
Component
and the Component
losing focus will be siblings in the same Container
.
In that case, the focus property of the Component
losing focus is simply set to false whereas the
focus property of this Component
is set to true.
More complex scenarios arise when the Component
losing focus and this Component
are
not siblings in the same Container
. In those cases, the order in which focus is lost and gained
occurs as follows:
Container
between both the Component
losing focus
and this Component
is found. This shared parent and any Container
above it in the hierarchy will be left alone.false
for each Container
in the hierarchy that contains the Component
losing focus, as well as the
component itself. This is done in top down order, so that the top most Container
loses focus first, followed
by every container between it and the Component
losing focus next, and with the component itself losing focus last. for each Container
in the hierarchy that contains this Component
, as well as the
component itself. This is done in top down order, so that the top most Container
gains focus first, followed
by every container between it and the Component
gaining focus next, and with this component gaining focus last.
The final case to be aware of is if you directly set this Component
's focus to false. In that case,
the same loss of focus rules outlined above apply. There is simply no gaining of focus that occurs by any component.
Therefore you cause the window to have no Component
with focus, with the except of the parent Container
of this Component
.
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_FOCUS ) to be generated. Additionally,
similar event generation may occur for other components according to the details outlined above.
- Specified by:
setFocus
in interface Component
- Parameters:
focus
- true to give this Component
and it's parent containers focus, false otherwise.- See Also:
Component.isFocus()
,
Container.getComponentWithFocus()
,
Container.getChildWithFocus()
getStyle
public Style getStyle()
- Description copied from interface:
Component
- Returns a
Style
object representing this Component
's current style settings. NOTE: This method
will never return null.
- Specified by:
getStyle
in interface Component
- Returns:
- a
Style
object representing this Component
's current style settings. - See Also:
Style
getX
public int getX()
- Description copied from interface:
Component
- Returns the X coordinate of this
Component
.
- Specified by:
getX
in interface Component
- Returns:
- the X coordinate (in pixels) of this
Component
- See Also:
Component.setX(int)
setX
public void setX(int x)
- Description copied from interface:
Component
- Assigns the specified X coordinate to this
Component
.
Default: 0
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_X ) to be generated.
- Specified by:
setX
in interface Component
- Parameters:
x
- the x coordinate (in pixels) to assign to this Component
- See Also:
Component.getX()
,
Component.setPosition(int, int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_X
,
PropertyChangeEvent
getY
public int getY()
- Description copied from interface:
Component
- Returns the Y coordinate of this
Component
.
- Specified by:
getY
in interface Component
- Returns:
- the Y coordinate (in pixels) of this
Component
- See Also:
Component.setY(int)
setY
public void setY(int y)
- Description copied from interface:
Component
- Assigns the specified Y coordinate to this
Component
.
Default: 0
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_Y ) to be generated.
- Specified by:
setY
in interface Component
- Parameters:
y
- the y coordinate (in pixels) to assign to this Component
- See Also:
Component.getY()
,
Component.setPosition(int, int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_Y
,
PropertyChangeEvent
setPosition
public Component setPosition(int x,
int y)
- Description copied from interface:
Component
- Assigns the specified X and Y coordinates to this
Component
atomically, in one operation.
Aside from the convienence provided by this method, it also guarantees that both of the provided
X and Y coordinates are legal values before the values are committed. The primary benefit of this
is that no PropertyChangeEvent
's will be generated until both values have been set.
Events:
This method may generate PropertyChangeEvent
's. See the documenation of setX
and setY
for more details.
- Specified by:
setPosition
in interface Component
- Parameters:
x
- the x coordinate (in pixels) to assign to this Component
y
- the y coordinate (in pixels) to assign to this Component
- Returns:
- this
Component
so that you can perform operations like container.getChildren().add(new Button().setPosition(x, y)) - See Also:
Component.setX(int)
,
Component.setY(int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_X
,
Component.PROPERTY_Y
,
PropertyChangeEvent
getWidth
public int getWidth()
- Description copied from interface:
Component
- Returns the width of this
Component
.
- Specified by:
getWidth
in interface Component
- Returns:
- the width (in pixels) of this
Component
- See Also:
Component.setWidth(int)
setWidth
public void setWidth(int width)
- Description copied from interface:
Component
- Assigns the specified width to this
Component
.
Default: 0
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_WIDTH ) to be generated.
- Specified by:
setWidth
in interface Component
- Parameters:
width
- the width (in pixels) to assign to this Component
- See Also:
Component.getWidth()
,
Component.setSize(int, int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_WIDTH
,
PropertyChangeEvent
getHeight
public int getHeight()
- Description copied from interface:
Component
- Returns the height of this
Component
.
- Specified by:
getHeight
in interface Component
- Returns:
- the height (in pixels) of this
Component
- See Also:
Component.setHeight(int)
setHeight
public void setHeight(int height)
- Description copied from interface:
Component
- Assigns the specified height to this
Component
.
Default: 0
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_HEIGHT ) to be generated.
- Specified by:
setHeight
in interface Component
- Parameters:
height
- the height (in pixels) to assign to this Component
- See Also:
Component.getHeight()
,
Component.setSize(int, int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_HEIGHT
,
PropertyChangeEvent
setSize
public Component setSize(int width,
int height)
- Description copied from interface:
Component
- Assigns the specified width and height to this
Component
atomically, in one operation.
Aside from the convienence provided by this method, it also guarantees that both of the provided
width and height are legal values before the values are committed. The primary benefit of this
is that no PropertyChangeEvent
's will be generated until both values have been set.
Events:
This method may generate PropertyChangeEvent
's. See the documenation of setWidth
and setHeight
for more details.
- Specified by:
setSize
in interface Component
- Parameters:
width
- the width (in pixels) to assign to this Component
height
- the height (in pixels) to assign to this Component
- Returns:
- this
Component
so that you can perform operations like container.getChildren().add(new Button().setSize(width, height)) - See Also:
Component.setWidth(int)
,
Component.setHeight(int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_WIDTH
,
Component.PROPERTY_HEIGHT
,
PropertyChangeEvent
setBounds
public Component setBounds(int x,
int y,
int width,
int height)
- Description copied from interface:
Component
- Assigns the specified width, height, X and Y values to this
Component
atomically, in one operation.
Aside from the convienence provided by this method, it also guarantees that all of the provided
values are legal before they are committed. The primary benefit of this
is that no PropertyChangeEvent
's will be generated until all values have been set.
Events:
This method may generate PropertyChangeEvent
's. See the documenation of setX
, setY
, setWidth
and setHeight
for more details.
- Specified by:
setBounds
in interface Component
- Parameters:
x
- the x coordinate (in pixels) to assign to this Component
y
- the y coordinate (in pixels) to assign to this Component
width
- the width (in pixels) to assign to this Component
height
- the height (in pixels) to assign to this Component
- Returns:
- this
Component
so that you can perform operations like container.getChildren().add(new Button().setBounds(x, y, width, height)) - See Also:
Component.setX(int)
,
Component.setY(int)
,
Component.setWidth(int)
,
Component.setHeight(int)
,
Component.setBounds(int, int, int, int)
,
Component.PROPERTY_X
,
Component.PROPERTY_Y
,
Component.PROPERTY_WIDTH
,
Component.PROPERTY_HEIGHT
,
PropertyChangeEvent
getLimit
public java.lang.Object getLimit()
- Description copied from interface:
Component
- Gets the layout limit that controls the bounds of this component within the context of the parent
Container
's layout.
- Specified by:
getLimit
in interface Component
- Returns:
- the layout limit that is in use by the
Container
's layout, or null if no limit is specified. - See Also:
Component.setLimit(Object)
,
Container.getLayout()
,
Container.setLayout(thinwire.ui.layout.Layout)
,
Layout
setLimit
public Component setLimit(java.lang.Object limit)
- Description copied from interface:
Component
- Sets a layout limit that controls the bounds of this component within the context of the parent
Container
's layout.
The type of limit object that is acceptable depends on the Layout
that is specified for the parent Container
.
Default: null
- Specified by:
setLimit
in interface Component
- Parameters:
limit
- a layout limit to use for the Container
's layout, or null to clear the limit.
- Returns:
- this
Component
so that you can perform operations like container.getChildren().add(new Button().setLimit(...)) - See Also:
Component.PROPERTY_LIMIT
,
Component.getLimit()
,
Container.getLayout()
,
Container.setLayout(thinwire.ui.layout.Layout)
,
Layout
,
PropertyChangeEvent
isVisible
public boolean isVisible()
- Description copied from interface:
Component
- Returns a boolean value indicating whether this
Component
may be displayed in a window. See
the documentation of Component.setVisible(boolean)
for further details about this property.
Default: true, except for the Dialog
and Frame
containers.
- Specified by:
isVisible
in interface Component
- Returns:
- true if this
Component
may be displayed, fasle otherwise - See Also:
Component.setVisible(boolean)
setVisible
public void setVisible(boolean visible)
- Description copied from interface:
Component
- Assigns a boolean value indicating whether this
Component
may be displayed in a window.
Default: true, except for the Dialog
and Frame
containers.
Details:
This Component
will not actually be displayed unless it is visible and added to a Container
hierarchy in which all of the containers are also visible and the top-level Container
is a visible
Frame
or Dialog
. Once a Component
has been displayed, toggling this property
results in a light-weight operation that simply hides/shows this Component
. This may sound trivial, but the
difference is important when you need to maximize the performance of your application. For instance, it is a faster to toggle
the visibility of components then it is to add/remove the components from a displayed Container
. This is
because the first time a Component
is displayed, the entire state must be rendered. In contrast, when you
toggle visibility, the Component
remains in memory in a fully rendered form, it is just not visible to the
user.
Events:
If the prior value and new value differ, setting this property causes a PropertyChangeEvent
( propertyName = PROPERTY_VISIBLE ) to be generated.
- Specified by:
setVisible
in interface Component
- Parameters:
visible
- true to indicate this Component
may be displayed, false otherwise- See Also:
Component.isVisible()
,
Component.PROPERTY_VISIBLE
,
Container.getChildren()
,
PropertyChangeEvent
Overview
Package
Class
Tree
Deprecated
Index
Help
PREV CLASS
NEXT CLASS
FRAMES
NO FRAMES
All Classes
SUMMARY: NESTED | FIELD | CONSTR | METHOD
DETAIL: FIELD | CONSTR | METHOD