| JavaTM 2 Platform Std. Ed. v1.6.0
javax.swing.text
Class JTextComponent
java.lang.Object
java.awt.Component
java.awt.Container
javax.swing.JComponent
javax.swing.text.JTextComponent
- All Implemented Interfaces:
- ImageObserver, MenuContainer, Serializable, Accessible, Scrollable
- Direct Known Subclasses:
- JEditorPane, JTextArea, JTextField
public abstract class JTextComponent - extends JComponent
- implements Scrollable, Accessible
JTextComponent is the base class for swing text
components. It tries to be compatible with the
java.awt.TextComponent class
where it can reasonably do so. Also provided are other services
for additional flexibility (beyond the pluggable UI and bean
support).
You can find information on how to use the functionality
this class provides in
General Rules for Using Text Components,
a section in The Java Tutorial.
- Caret Changes
-
The caret is a pluggable object in swing text components.
Notification of changes to the caret position and the selection
are sent to implementations of the
CaretListener
interface that have been registered with the text component.
The UI will install a default caret unless a customized caret
has been set.
By default the caret tracks all the document changes
performed on the Event Dispatching Thread and updates it's position
accordingly if an insertion occurs before or at the caret position
or a removal occurs before the caret position. DefaultCaret
tries to make itself visible which may lead to scrolling
of a text component within JScrollPane. The default caret
behavior can be changed by the DefaultCaret.setUpdatePolicy(int) method.
Note: Non-editable text components also have a caret though
it may not be painted.
- Commands
-
Text components provide a number of commands that can be used
to manipulate the component. This is essentially the way that
the component expresses its capabilities. These are expressed
in terms of the swing
Action interface,
using the TextAction implementation.
The set of commands supported by the text component can be
found with the getActions() method. These actions
can be bound to key events, fired from buttons, etc.
- Text Input
-
The text components support flexible and internationalized text input, using
keymaps and the input method framework, while maintaining compatibility with
the AWT listener model.
A Keymap lets an application bind key
strokes to actions.
In order to allow keymaps to be shared across multiple text components, they
can use actions that extend TextAction.
TextAction can determine which JTextComponent
most recently has or had focus and therefore is the subject of
the action (In the case that the ActionEvent
sent to the action doesn't contain the target text component as its source).
The input method framework
lets text components interact with input methods, separate software
components that preprocess events to let users enter thousands of
different characters using keyboards with far fewer keys.
JTextComponent is an active client of
the framework, so it implements the preferred user interface for interacting
with input methods. As a consequence, some key events do not reach the text
component because they are handled by an input method, and some text input
reaches the text component as committed text within an InputMethodEvent instead of as a key event.
The complete text input is the combination of the characters in
keyTyped key events and committed text in input method events.
The AWT listener model lets applications attach event listeners to
components in order to bind events to actions. Swing encourages the
use of keymaps instead of listeners, but maintains compatibility
with listeners by giving the listeners a chance to steal an event
by consuming it.
Keyboard event and input method events are handled in the following stages,
with each stage capable of consuming the event:
Stage |
KeyEvent |
InputMethodEvent |
| 1. |
input methods |
(generated here) |
| 2. |
focus manager |
|
| 3. |
registered key listeners |
registered input method listeners |
| 4. |
|
input method handling in JTextComponent |
| 5. | keymap handling using the current keymap |
| 6. | keyboard handling in JComponent (e.g. accelerators, component navigation, etc.) |
|
To maintain compatibility with applications that listen to key
events but are not aware of input method events, the input
method handling in stage 4 provides a compatibility mode for
components that do not process input method events. For these
components, the committed text is converted to keyTyped key events
and processed in the key event pipeline starting at stage 3
instead of in the input method event pipeline.
By default the component will create a keymap (named DEFAULT_KEYMAP)
that is shared by all JTextComponent instances as the default keymap.
Typically a look-and-feel implementation will install a different keymap
that resolves to the default keymap for those bindings not found in the
different keymap. The minimal bindings include:
- inserting content into the editor for the
printable keys.
- removing content with the backspace and del
keys.
- caret movement forward and backward
- Model/View Split
-
The text components have a model-view split. A text component pulls
together the objects used to represent the model, view, and controller.
The text document model may be shared by other views which act as observers
of the model (e.g. a document may be shared by multiple components).

The model is defined by the Document interface.
This is intended to provide a flexible text storage mechanism
that tracks change during edits and can be extended to more sophisticated
models. The model interfaces are meant to capture the capabilities of
expression given by SGML, a system used to express a wide variety of
content.
Each modification to the document causes notification of the
details of the change to be sent to all observers in the form of a
DocumentEvent which allows the views to stay up to date with the model.
This event is sent to observers that have implemented the
DocumentListener
interface and registered interest with the model being observed.
- Location Information
-
The capability of determining the location of text in
the view is provided. There are two methods,
modelToView(int)
and viewToModel(java.awt.Point) for determining this information.
- Undo/Redo support
-
Support for an edit history mechanism is provided to allow
undo/redo operations. The text component does not itself
provide the history buffer by default, but does provide
the
UndoableEdit records that can be used in conjunction
with a history buffer to provide the undo/redo support.
The support is provided by the Document model, which allows
one to attach UndoableEditListener implementations.
- Thread Safety
-
The swing text components provide some support of thread
safe operations. Because of the high level of configurability
of the text components, it is possible to circumvent the
protection provided. The protection primarily comes from
the model, so the documentation of
AbstractDocument
describes the assumptions of the protection provided.
The methods that are safe to call asynchronously are marked
with comments.
- Newlines
-
For a discussion on how newlines are handled, see
DefaultEditorKit.
- Printing support
-
Several
print methods are provided for basic
document printing. If more advanced printing is needed, use the
getPrintable(java.text.MessageFormat, java.text.MessageFormat) 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.
- See Also:
Document,
DocumentEvent,
DocumentListener,
Caret,
CaretEvent,
CaretListener,
TextUI,
View,
ViewFactory
|
Field Summary |
static String |
DEFAULT_KEYMAP
The default keymap that will be shared by all
JTextComponent instances unless they
have had a different keymap set. |
static String |
FOCUS_ACCELERATOR_KEY
The bound property name for the focus accelerator. |
|
Method Summary |
void |
addCaretListener(CaretListener listener)
Adds a caret listener for notification of any changes
to the caret. |
void |
addInputMethodListener(InputMethodListener l)
Adds the specified input method listener to receive
input method events from this component. |
static Keymap |
addKeymap(String nm,
Keymap parent)
Adds a new keymap into the keymap hierarchy. |
void |
copy()
Transfers the currently selected range in the associated
text model to the system clipboard, leaving the contents
in the text model. |
void |
cut()
Transfers the currently selected range in the associated
text model to the system clipboard, removing the contents
from the model. |
protected void |
fireCaretUpdate(CaretEvent e)
Notifies all listeners that have registered interest for
notification on this event type. |
AccessibleContext |
getAccessibleContext()
Gets the AccessibleContext associated with this
JTextComponent. |
Action[] |
getActions()
Fetches the command list for the editor. |
Caret |
getCaret()
Fetches the caret that allows text-oriented navigation over
the view. |
Color |
getCaretColor()
Fetches the current color used to render the
caret. |
CaretListener[] |
getCaretListeners()
Returns an array of all the caret listeners
registered on this text component. |
int |
getCaretPosition()
Returns the position of the text insertion caret for the
text component. |
Color |
getDisabledTextColor()
Fetches the current color used to render the
disabled text. |
Document |
getDocument()
Fetches the model associated with the editor. |
boolean |
getDragEnabled()
Returns whether or not automatic drag handling is enabled. |
JTextComponent.DropLocation |
getDropLocation()
Returns the location that this component should visually indicate
as the drop location during a DnD operation over the component,
or null if no location is to currently be shown. |
DropMode |
getDropMode()
Returns the drop mode for this component. |
char |
getFocusAccelerator()
Returns the key accelerator that will cause the receiving
text component to get the focus. |
Highlighter |
getHighlighter()
Fetches the object responsible for making highlights. |
InputMethodRequests |
getInputMethodRequests()
Gets the input method request handler which supports
requests from input methods for this component. |
Keymap |
getKeymap()
Fetches the keymap currently active in this text
component. |
static Keymap |
getKeymap(String nm)
Fetches a named keymap previously added to the document. |
Insets |
getMargin()
Returns the margin between the text component's border and
its text. |
NavigationFilter |
getNavigationFilter()
Returns the NavigationFilter. |
Dimension |
getPreferredScrollableViewportSize()
Returns the preferred size of the viewport for a view component. |
Printable |
getPrintable(MessageFormat headerFormat,
MessageFormat footerFormat)
Returns a Printable to use for printing the content of this
JTextComponent. |
int |
getScrollableBlockIncrement(Rectangle visibleRect,
int orientation,
int direction)
Components that display logical rows or columns should compute
the scroll increment that will completely expose one block
of rows or columns, depending on the value of orientation. |
boolean |
getScrollableTracksViewportHeight()
Returns true if a viewport should always force the height of this
Scrollable to match the height of the viewport. |
boolean |
getScrollableTracksViewportWidth()
Returns true if a viewport should always force the width of this
Scrollable to match the width of the viewport. |
int |
getScrollableUnitIncrement(Rectangle visibleRect,
int orientation,
int direction)
Components that display logical rows or columns should compute
the scroll increment that will completely expose one new row
or column, depending on the value of orientation. |
String |
getSelectedText()
Returns the selected text contained in this
TextComponent. |
Color |
getSelectedTextColor()
Fetches the current color used to render the
selected text. |
Color |
getSelectionColor()
Fetches the current color used to render the
selection. |
int |
getSelectionEnd()
Returns the selected text's end position. |
int |
getSelectionStart()
Returns the selected text's start position. |
String |
getText()
Returns the text contained in this TextComponent. |
String |
getText(int offs,
int len)
Fetches a portion of the text represented by the
component. |
String |
getToolTipText(MouseEvent event)
Returns the string to be used as the tooltip for event. |
TextUI |
getUI()
Fetches the user-interface factory for this text-oriented editor. |
boolean |
isEditable()
Returns the boolean indicating whether this
TextComponent is editable or not. |
static void |
loadKeymap(Keymap map,
JTextComponent.KeyBinding[] bindings,
Action[] actions)
Loads a keymap with a bunch of
bindings. |
Rectangle |
modelToView(int pos)
Converts the given location in the model to a place in
the view coordinate system. |
void |
moveCaretPosition(int pos)
Moves the caret to a new position, leaving behind a mark
defined by the last time setCaretPosition was
called. |
protected String |
paramString()
Returns a string representation of this JTextComponent. |
void |
paste()
Transfers the contents of the system clipboard into the
associated text model. |
boolean |
print()
A convenience print method that displays a print dialog, and then
prints this JTextComponent in interactive mode with no
header or footer text. |
boolean |
print(MessageFormat headerFormat,
MessageFormat footerFormat)
A convenience print method that displays a print dialog, and then
prints this JTextComponent in interactive mode with
the specified header and footer text. |
boolean |
print(MessageFormat headerFormat,
MessageFormat footerFormat,
boolean showPrintDialog,
PrintService service,
PrintRequestAttributeSet attributes,
boolean interactive)
Prints the content of this JTextComponent. |
protected void |
processInputMethodEvent(InputMethodEvent e)
Processes input method events occurring on this component by
dispatching them to any registered
InputMethodListener objects. |
void |
read(Reader in,
Object desc)
Initializes from a stream. |
void |
removeCaretListener(CaretListener listener)
Removes a caret listener. |
static Keymap |
removeKeymap(String nm)
Removes a named keymap previously added to the document. |
void |
removeNotify()
Notifies this component that it no longer has a parent component. |
void |
replaceSelection(String content)
Replaces the currently selected content with new content
represented by the given string. |
void |
select(int selectionStart,
int selectionEnd)
Selects the text between the specified start and end positions. |
void |
selectAll()
Selects all the text in the TextComponent. |
void |
setCaret(Caret c)
Sets the caret to be used. |
void |
setCaretColor(Color c)
Sets the current color used to render the caret. |
void |
setCaretPosition(int position)
Sets the position of the text insertion caret for the
TextComponent. |
void |
setComponentOrientation(ComponentOrientation o)
Sets the language-sensitive orientation that is to be used to order
the elements or text within this component. |
void |
setDisabledTextColor(Color c)
Sets the current color used to render the
disabled text. |
void |
setDocument(Document doc)
Associates the editor with a text document. |
void |
setDragEnabled(boolean b)
Turns on or off automatic drag handling. |
void |
setDropMode(DropMode dropMode)
Sets the drop mode for this component. |
void |
setEditable(boolean b)
Sets the specified boolean to indicate whether or not this
TextComponent should be editable. |
void |
setFocusAccelerator(char aKey)
Sets the key accelerator that will cause the receiving text
component to get the focus. |
void |
setHighlighter(Highlighter h)
Sets the highlighter to be used. |
void |
setKeymap(Keymap map)
Sets the keymap to use for binding events to
actions. |
void |
setMargin(Insets m)
Sets margin space between the text component's border
and its text. |
void |
setNavigationFilter(NavigationFilter filter)
Sets the NavigationFilter. |
void |
setSelectedTextColor(Color c)
Sets the current color used to render the selected text. |
void |
setSelectionColor(Color c)
Sets the current color used to render the selection. |
void |
setSelectionEnd(int selectionEnd)
Sets the selection end to the specified position. |
void |
setSelectionStart(int selectionStart)
Sets the selection start to the specified position. |
void |
setText(String t)
Sets the text of this TextComponent
to the specified text. |
void |
setUI(TextUI ui)
Sets the user-interface factory for this text-oriented editor. |
void |
updateUI()
Reloads the pluggable UI. |
int |
viewToModel(Point pt)
Converts the given place in the view coordinate system
to the nearest representative location in the model. |
void |
write(Writer out)
Stores the contents of the model into the given
stream. |
| Methods inherited from class javax.swing.JComponent |
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, getBaseline, getBaselineResizeBehavior, getBorder, getBounds, getClientProperty, getComponentGraphics, getComponentPopupMenu, getConditionForKeyStroke, getDebugGraphicsOptions, getDefaultLocale, getFontMetrics, getGraphics, getHeight, getInheritsPopupMenu, getInputMap, getInputMap, getInputVerifier, getInsets, getInsets, getListeners, getLocation, getMaximumSize, getMinimumSize, getNextFocusableComponent, getPopupLocation, getPreferredSize, getRegisteredKeyStrokes, getRootPane, getSize, getToolTipLocation, getToolTipText, getTopLevelAncestor, getTransferHandler, getUIClassID, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeVetoableChangeListener, repaint, repaint, requestDefaultFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, resetKeyboardActions, reshape, revalidate, scrollRectToVisible, setActionMap, setAlignmentX, setAlignmentY, setAutoscrolls, setBackground, setBorder, setComponentPopupMenu, setDebugGraphicsOptions, setDefaultLocale, setDoubleBuffered, setEnabled, setFocusTraversalKeys, setFont, setForeground, setInheritsPopupMenu, setInputMap, setInputVerifier, setMaximumSize, setMinimumSize, setNextFocusableComponent, setOpaque, setPreferredSize, setRequestFocusEnabled, setToolTipText, setTransferHandler, setUI, setVerifyInputWhenFocusTarget, setVisible, unregisterKeyboardAction, update |
| Methods inherited from class java.awt.Container |
add, add, add, add, add, addContainerListener, addImpl, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, getMousePosition, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setComponentZOrder, setFocusCycleRoot, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setLayout, transferFocusBackward, transferFocusDownCycle, validate, validateTree |
| Methods inherited from class java.awt.Component |
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBackground, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getForeground, getGraphicsConfiguration, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPeer, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, hide, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, postEvent, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, resize, resize, setBounds, setBounds, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, | |