java.lang.Object | |||
↳ | javax.swing.plaf.ComponentUI | ||
↳ | javax.swing.plaf.TextUI | ||
↳ | javax.swing.plaf.basic.BasicTextUI |
![]() |
![]() |
Basis of a text components look-and-feel. This provides the
basic editor view and controller services that may be useful
when creating a look-and-feel for an extension of
JTextComponent
.
Most state is held in the associated JTextComponent
as bound properties, and the UI installs default values for the
various properties. This default will install something for
all of the properties. Typically, a LAF implementation will
do more however. At a minimum, a LAF would generally install
key bindings.
This class also provides some concurrency support if the
Document
associated with the JTextComponent is a subclass of
AbstractDocument
. Access to the View (or View hierarchy) is
serialized between any thread mutating the model and the Swing
event thread (which is expected to render, do model/view coordinate
translation, etc). Any access to the root view should first
acquire a read-lock on the AbstractDocument and release that lock
in a finally block.
An important method to define is the getPropertyPrefix()
method
which is used as the basis of the keys used to fetch defaults
from the UIManager. The string should reflect the type of
TextUI (eg. TextField, TextArea, etc) without the particular
LAF part of the name (eg Metal, Motif, etc).
To build a view of the model, one of the following strategies can be employed.
create(Element)
method.
Warning:
Serialized objects of this class will not be compatible with
future Swing releases. The current serialization support is
appropriate for short term storage or RMI between applications running
the same version of Swing. As of 1.4, support for long term storage
of all JavaBeansTM
has been added to the java.beans
package.
Please see XMLEncoder
.
Nested Classes | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
BasicTextUI.BasicCaret | |||||||||||
BasicTextUI.BasicHighlighter |
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Creates a new UI.
|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Creates a view for an element.
| |||||||||||
Creates a view for an element.
| |||||||||||
Causes the portion of the view responsible for the
given part of the model to be repainted.
| |||||||||||
Causes the portion of the view responsible for the
given part of the model to be repainted.
| |||||||||||
Fetches the EditorKit for the UI.
| |||||||||||
Gets the maximum size for the editor component.
| |||||||||||
Gets the minimum size for the editor component.
| |||||||||||
Provides a way to determine the next visually represented model
location that one might place a caret.
| |||||||||||
Gets the preferred size for the editor component.
| |||||||||||
Fetches a View with the allocation of the associated
text component (i.e.
| |||||||||||
Returns the string to be used as the tooltip at the passed in location.
| |||||||||||
Installs the UI for a component.
| |||||||||||
Converts the given location in the model to a place in
the view coordinate system.
| |||||||||||
Converts the given location in the model to a place in
the view coordinate system.
| |||||||||||
Paints the interface.
| |||||||||||
Deinstalls the UI for a component.
| |||||||||||
Superclass paints background in an uncontrollable way
(i.e.
| |||||||||||
Converts the given place in the view coordinate system
to the nearest representative location in the model.
| |||||||||||
Converts the given place in the view coordinate system
to the nearest representative location in the model.
|
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Creates the object to use for a caret.
| |||||||||||
Creates the object to use for adding highlights.
| |||||||||||
Creates the keymap to use for the text component, and installs
any necessary bindings into it.
| |||||||||||
Fetches the text component associated with this
UI implementation.
| |||||||||||
Fetches the name of the keymap that will be installed/used
by default for this UI.
| |||||||||||
Gets the name used as a key to look up properties through the
UIManager.
| |||||||||||
Gets the allocation to give the root View.
| |||||||||||
Initializes component properties, e.g.
| |||||||||||
Installs listeners for the UI.
| |||||||||||
Flags model changes.
| |||||||||||
Paints a background for the view.
| |||||||||||
Paints the interface safely with a guarantee that
the model won't change from the view of this thread.
| |||||||||||
This method gets called when a bound property is changed
on the associated JTextComponent.
| |||||||||||
Sets the current root of the view hierarchy and calls invalidate().
| |||||||||||
Sets the component properties that haven't been explicitly overridden to
null.
| |||||||||||
Uninstalls listeners for the UI.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() | |||||||||||
![]() | |||||||||||
![]() | |||||||||||
![]() |
Creates a new UI.
Creates a view for an element. If a subclass wishes to directly implement the factory producing the view(s), it should reimplement this method. By default it simply returns null indicating it is unable to represent the element.
elem | the element |
---|
Creates a view for an element. If a subclass wishes to directly implement the factory producing the view(s), it should reimplement this method. By default it simply returns null indicating it is unable to represent the part of the element.
elem | the element |
---|---|
p0 | the starting offset >= 0 |
p1 | the ending offset >= p0 |
Causes the portion of the view responsible for the given part of the model to be repainted.
p0 | the beginning of the range >= 0 |
---|---|
p1 | the end of the range >= p0 |
Causes the portion of the view responsible for the given part of the model to be repainted. Does nothing if the view is not currently painted.
tc | the text component for which this UI is installed |
---|---|
p0 | the beginning of the range >= 0 |
p1 | the end of the range >= p0 |
Fetches the EditorKit for the UI.
tc | the text component for which this UI is installed |
---|
Gets the maximum size for the editor component.
c | the editor component |
---|
Gets the minimum size for the editor component.
c | the editor component |
---|
Provides a way to determine the next visually represented model location that one might place a caret. Some views may not be visible, they might not be in the same order found in the model, or they just might not allow access to some of the locations in the model.
t | the text component for which this UI is installed |
---|---|
pos | the position to convert >= 0 |
b | the bias for the position |
direction | the direction from the current position that can be thought of as the arrow keys typically found on a keyboard. This may be SwingConstants.WEST, SwingConstants.EAST, SwingConstants.NORTH, or SwingConstants.SOUTH |
biasRet | an array to contain the bias for the returned position |
BadLocationException |
---|
Gets the preferred size for the editor component. If the component has been given a size prior to receiving this request, it will set the size of the view hierarchy to reflect the size of the component before requesting the preferred size of the view hierarchy. This allows formatted views to format to the current component size before answering the request. Other views don't care about currently formatted size and give the same answer either way.
c | the editor component |
---|
Fetches a View with the allocation of the associated text component (i.e. the root of the hierarchy) that can be traversed to determine how the model is being represented spatially.
NOTE:The View hierarchy can be traversed from the root view, and other things can be done as well. Things done in this way cannot be protected like simple method calls through the TextUI. Therefore, proper operation in the presence of concurrency must be arranged by any logic that calls this method!
tc | the text component for which this UI is installed |
---|
Returns the string to be used as the tooltip at the passed in location. This forwards the method onto the root View.
Installs the UI for a component. This does the following things.
c | the editor component |
---|
Converts the given location in the model to a place in the view coordinate system. The component must have a non-zero positive size for this translation to be computed.
tc | the text component for which this UI is installed |
---|---|
pos | the local location in the model to translate >= 0 |
BadLocationException | if the given position does not represent a valid location in the associated document |
---|
Converts the given location in the model to a place in the view coordinate system. The component must have a non-zero positive size for this translation to be computed.
tc | the text component for which this UI is installed |
---|---|
pos | the local location in the model to translate >= 0 |
BadLocationException | if the given position does not represent a valid location in the associated document |
---|
Paints the interface. This is routed to the paintSafely method under the guarantee that the model won't change from the view of this thread while it's rendering (if the associated model is derived from AbstractDocument). This enables the model to potentially be updated asynchronously.
g | the graphics context |
---|---|
c | the editor component |
Deinstalls the UI for a component. This removes the listeners, uninstalls the highlighter, removes views, and nulls out the keymap.
c | the editor component |
---|
Superclass paints background in an uncontrollable way (i.e. one might want an image tiled into the background). To prevent this from happening twice, this method is reimplemented to simply paint.
NOTE: Superclass is also not thread-safe in it's rendering of the background, although that's not an issue with the default rendering.
g | the Graphics context in which to paint |
---|---|
c | the component being painted; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components |
Converts the given place in the view coordinate system to the nearest representative location in the model. The component must have a non-zero positive size for this translation to be computed.
tc | the text component for which this UI is installed |
---|---|
pt | the location in the view to translate. This should be in the same coordinate system as the mouse events. |
biasReturn | filled in by this method to indicate whether the point given is closer to the previous or the next character in the model |
Converts the given place in the view coordinate system to the nearest representative location in the model. The component must have a non-zero positive size for this translation to be computed.
tc | the text component for which this UI is installed |
---|---|
pt | the location in the view to translate. This should be in the same coordinate system as the mouse events. |
Creates the object to use for a caret. By default an instance of BasicCaret is created. This method can be redefined to provide something else that implements the InputPosition interface or a subclass of JCaret.
Creates the object to use for adding highlights. By default an instance of BasicHighlighter is created. This method can be redefined to provide something else that implements the Highlighter interface or a subclass of DefaultHighlighter.
Creates the keymap to use for the text component, and installs any necessary bindings into it. By default, the keymap is shared between all instances of this type of TextUI. The keymap has the name defined by the getKeymapName method. If the keymap is not found, then DEFAULT_KEYMAP from JTextComponent is used.
The set of bindings used to create the keymap is fetched
from the UIManager using a key formed by combining the
getPropertyPrefix()
method
and the string .keyBindings
. The type is expected
to be JTextComponent.KeyBinding[]
.
Fetches the text component associated with this UI implementation. This will be null until the ui has been installed.
Fetches the name of the keymap that will be installed/used by default for this UI. This is implemented to create a name based upon the classname. The name is the the name of the class with the package prefix removed.
Gets the name used as a key to look up properties through the UIManager. This is used as a prefix to all the standard text properties.
Gets the allocation to give the root View. Due to an unfortunate set of historical events this method is inappropriately named. The Rectangle returned has nothing to do with visibility. The component must have a non-zero positive size for this translation to be computed.
Initializes component properties, e.g. font, foreground, background, caret color, selection color, selected text color, disabled text color, and border color. The font, foreground, and background properties are only set if their current value is either null or a UIResource, other properties are set if the current value is null.
Installs listeners for the UI.
Flags model changes. This is called whenever the model has changed. It is implemented to rebuild the view hierarchy to represent the default root element of the associated model.
Paints a background for the view. This will only be called if isOpaque() on the associated component is true. The default is to paint the background color of the component.
g | the graphics context |
---|
Paints the interface safely with a guarantee that the model won't change from the view of this thread. This does the following things, rendering from back to front.
g | the graphics context |
---|
This method gets called when a bound property is changed on the associated JTextComponent. This is a hook which UI implementations may change to reflect how the UI displays bound properties of JTextComponent subclasses. This is implemented to do nothing (i.e. the response to properties in JTextComponent itself are handled prior to calling this method). This implementation updates the background of the text component if the editable and/or enabled state changes.
evt | the property change event |
---|
Sets the current root of the view hierarchy and calls invalidate(). If there were any child components, they will be removed (i.e. there are assumed to have come from components embedded in views).
v | the root view |
---|
Sets the component properties that haven't been explicitly overridden to null. A property is considered overridden if its current value is not a UIResource.
Uninstalls listeners for the UI.