Class JTextComponent
- All Implemented Interfaces:
ImageObserver, MenuContainer, Serializable, Accessible, Scrollable
- Direct Known Subclasses:
JEditorPane, JTextArea, JTextField
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 withinJScrollPane
. The default caret behavior can be changed by theDefaultCaret.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 theTextAction
implementation. The set of commands supported by the text component can be found with thegetActions()
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 extendTextAction
.TextAction
can determine whichJTextComponent
most recently has or had focus and therefore is the subject of the action (In the case that theActionEvent
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 anInputMethodEvent
instead of as a key event. The complete text input is the combination of the characters inkeyTyped
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:
Stages of keyboard and input method event handling 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 aDocumentEvent
which allows the views to stay up to date with the model. This event is sent to observers that have implemented theDocumentListener
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)
andviewToModel(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 thegetPrintable(MessageFormat, 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 JavaBeans
has been added to the java.beans
package.
Please see XMLEncoder
.
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionclass
This class implements accessibility support for theJTextComponent
class.static final class
Represents a drop location forJTextComponent
s.static class
Binding record for creating key bindings.Nested classes/interfaces declared in class JComponent
JComponent.AccessibleJComponent
Modifier and TypeClassDescriptionclass
Inner class of JComponent used to provide default support for accessibility.Nested classes/interfaces declared in class Container
Container.AccessibleAWTContainer
Modifier and TypeClassDescriptionprotected class
Inner class of Container used to provide default support for accessibility.Nested classes/interfaces declared in class Component
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
Modifier and TypeClassDescriptionprotected class
Inner class of Component used to provide default support for accessibility.static enum
Enumeration of the common ways the baseline of a component can change as the size changes.protected class
Inner class for blitting offscreen surfaces to a component.protected class
Inner class for flipping buffers on a component. -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final String
The default keymap that will be shared by allJTextComponent
instances unless they have had a different keymap set.static final String
The bound property name for the focus accelerator.Fields declared in class JComponent
listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
Modifier and TypeFieldDescriptionprotected EventListenerList
A list of event listeners for this component.static final String
The comment to display when the cursor is over the component, also known as a "value tip", "flyover help", or "flyover label".protected ComponentUI
The look and feel delegate for this component.static final int
Constant used by some of the APIs to mean that no condition is defined.static final int
Constant used forregisterKeyboardAction
that means that the command should be invoked when the receiving component is an ancestor of the focused component or is itself the focused component.static final int
Constant used forregisterKeyboardAction
that means that the command should be invoked when the component has the focus.static final int
Constant used forregisterKeyboardAction
that means that the command should be invoked when the receiving component is in the window that has the focus or is itself the focused component.Fields declared in class Component
accessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
Modifier and TypeFieldDescriptionprotected AccessibleContext
TheAccessibleContext
associated with thisComponent
.static final float
Ease-of-use constant forgetAlignmentY
.static final float
Ease-of-use constant forgetAlignmentY
andgetAlignmentX
.static final float
Ease-of-use constant forgetAlignmentX
.static final float
Ease-of-use constant forgetAlignmentX
.static final float
Ease-of-use constant forgetAlignmentY()
.Fields declared in interface ImageObserver
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
Modifier and TypeFieldDescriptionstatic final int
This flag in the infoflags argument to imageUpdate indicates that an image which was being tracked asynchronously was aborted before production was complete.static final int
This flag in the infoflags argument to imageUpdate indicates that a static image which was previously drawn is now complete and can be drawn again in its final form.static final int
This flag in the infoflags argument to imageUpdate indicates that an image which was being tracked asynchronously has encountered an error.static final int
This flag in the infoflags argument to imageUpdate indicates that another complete frame of a multi-frame image which was previously drawn is now available to be drawn again.static final int
This flag in the infoflags argument to imageUpdate indicates that the height of the base image is now available and can be taken from the height argument to the imageUpdate callback method.static final int
This flag in the infoflags argument to imageUpdate indicates that the properties of the image are now available.static final int
This flag in the infoflags argument to imageUpdate indicates that more pixels needed for drawing a scaled variation of the image are available.static final int
This flag in the infoflags argument to imageUpdate indicates that the width of the base image is now available and can be taken from the width argument to the imageUpdate callback method. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
addCaretListener
(CaretListener listener) Adds a caret listener for notification of any changes to the caret.static Keymap
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
Notifies all listeners that have registered interest for notification on this event type.Gets theAccessibleContext
associated with thisJTextComponent
.Action[]
Fetches the command list for the editor.getCaret()
Fetches the caret that allows text-oriented navigation over the view.Fetches the current color used to render the caret.Returns an array of all the caret listeners registered on this text component.int
Returns the position of the text insertion caret for the text component.Fetches the current color used to render the disabled text.Fetches the model associated with the editor.boolean
Returns whether or not automatic drag handling is enabled.Returns the location that this component should visually indicate as the drop location during a DnD operation over the component, ornull
if no location is to currently be shown.final DropMode
Returns the drop mode for this component.char
Returns the key accelerator that will cause the receiving text component to get the focus.Fetches the object responsible for making highlights.Gets the input method request handler which supports requests from input methods for this component.Fetches the keymap currently active in this text component.static Keymap
Fetches a named keymap previously added to the document.Returns the margin between the text component's border and its text.Returns theNavigationFilter
.Returns the preferred size of the viewport for a view component.getPrintable
(MessageFormat headerFormat, MessageFormat footerFormat) Returns aPrintable
to use for printing the content of thisJTextComponent
.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
Returns true if a viewport should always force the height of thisScrollable
to match the height of the viewport.boolean
Returns true if a viewport should always force the width of thisScrollable
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.Returns the selected text contained in thisTextComponent
.Fetches the current color used to render the selected text.Fetches the current color used to render the selection.int
Returns the selected text's end position.int
Returns the selected text's start position.getText()
Returns the text contained in thisTextComponent
.getText
(int offs, int len) Fetches a portion of the text represented by the component.getToolTipText
(MouseEvent event) Returns the string to be used as the tooltip forevent
.getUI()
Fetches the user-interface factory for this text-oriented editor.boolean
Returns the boolean indicating whether thisTextComponent
is editable or not.static void
loadKeymap
(Keymap map, JTextComponent.KeyBinding[] bindings, Action[] actions) Loads a keymap with a bunch of bindings.modelToView
(int pos) Deprecated.modelToView2D
(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 timesetCaretPosition
was called.protected String
Returns a string representation of thisJTextComponent
.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 thisJTextComponent
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 thisJTextComponent
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 thisJTextComponent
.void
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
replaceSelection
(String content) Replaces the currently selected content with new content represented by the given string.protected void
Restores composed text previously saved bysaveComposedText
.protected boolean
saveComposedText
(int pos) Saves composed text around the specified position.void
select
(int selectionStart, int selectionEnd) Selects the text between the specified start and end positions.void
Selects all the text in theTextComponent
.void
Sets the caret to be used.void
Sets the current color used to render the caret.void
setCaretPosition
(int position) Sets the position of the text insertion caret for theTextComponent
.void
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.final void
setDropMode
(DropMode dropMode) Sets the drop mode for this component.void
setEditable
(boolean b) Sets the specified boolean to indicate whether or not thisTextComponent
should be editable.void
setFocusAccelerator
(char aKey) Sets the key accelerator that will cause the receiving text component to get the focus.void
Sets the highlighter to be used.void
Sets the keymap to use for binding events to actions.void
Sets margin space between the text component's border and its text.void
setNavigationFilter
(NavigationFilter filter) Sets theNavigationFilter
.void
Sets the current color used to render the selected text.void
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
Sets the text of thisTextComponent
to the specified text.void
Sets the user-interface factory for this text-oriented editor.void
updateUI()
Reloads the pluggable UI.int
viewToModel
(Point pt) Deprecated.replaced byviewToModel2D(Point2D)
int
viewToModel2D
(Point2D pt) Converts the given place in the view coordinate system to the nearest representative location in the model.void
Stores the contents of the model into the given stream.Methods declared in class JComponent
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, 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, hide, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingOrigin, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeNotify, 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
Modifier and TypeMethodDescriptionvoid
addAncestorListener
(AncestorListener listener) Registerslistener
so that it will receiveAncestorEvents
when it or any of its ancestors move or are made visible or invisible.void
Notifies this component that it now has a parent component.void
Adds aVetoableChangeListener
to the listener list.void
computeVisibleRect
(Rectangle visibleRect) Returns theComponent
's "visible rect rectangle" - the intersection of the visible rectangles for this component and all of its ancestors.boolean
contains
(int x, int y) Gives the UI delegate an opportunity to define the precise shape of this component for the sake of mouse processing.Returns the instance ofJToolTip
that should be used to display the tooltip.void
disable()
Deprecated.As of JDK version 1.1, replaced byjava.awt.Component.setEnabled(boolean)
.void
enable()
Deprecated.As of JDK version 1.1, replaced byjava.awt.Component.setEnabled(boolean)
.void
firePropertyChange
(String propertyName, boolean oldValue, boolean newValue) Support for reporting bound property changes for boolean properties.void
firePropertyChange
(String propertyName, int oldValue, int newValue) Support for reporting bound property changes for integer properties.protected void
fireVetoableChange
(String propertyName, Object oldValue, Object newValue) Supports reporting constrained property changes.getActionForKeyStroke
(KeyStroke aKeyStroke) Returns the object that will perform the action registered for a given keystroke.final ActionMap
Returns theActionMap
used to determine whatAction
to fire for particularKeyStroke
binding.float
OverridesContainer.getAlignmentX
to return the horizontal alignment.float
OverridesContainer.getAlignmentY
to return the vertical alignment.Returns an array of all the ancestor listeners registered on this component.boolean
Gets theautoscrolls
property.int
getBaseline
(int width, int height) Returns the baseline.Returns an enum indicating how the baseline of the component changes as the size changes.Returns the border of this component ornull
if no border is currently set.Stores the bounds of this component into "return value"rv
and returnsrv
.final Object
getClientProperty
(Object key) Returns the value of the property with the specified key.protected Graphics
Returns the graphics object used to paint this component.ReturnsJPopupMenu
that assigned for this component.int
getConditionForKeyStroke
(KeyStroke aKeyStroke) Returns the condition that determines whether a registered action occurs in response to the specified keystroke.int
Returns the state of graphics debugging.static Locale
Returns the default locale used to initialize each JComponent's locale property upon creation.getFontMetrics
(Font font) Gets theFontMetrics
for the specifiedFont
.Returns this component's graphics context, which lets you draw on a component.int
Returns the current height of this component.boolean
Returns true if the JPopupMenu should be inherited from the parent.final InputMap
Returns theInputMap
that is used when the component has focus.final InputMap
getInputMap
(int condition) Returns theInputMap
that is used duringcondition
.Returns the input verifier for this component.If a border has been set on this component, returns the border's insets; otherwise callssuper.getInsets
.Returns anInsets
object containing this component's inset values.<T extends EventListener>
T[]getListeners
(Class<T> listenerType) Returns an array of all the objects currently registered asFooListener
s upon thisJComponent
.getLocation
(Point rv) Stores the x,y origin of this component into "return value"rv
and returnsrv
.If the maximum size has been set to a non-null
value just returns it.If the minimum size has been set to a non-null
value just returns it.Deprecated.As of 1.4, replaced byFocusTraversalPolicy
.getPopupLocation
(MouseEvent event) Returns the preferred location to display the popup menu in this component's coordinate system.If thepreferredSize
has been set to a non-null
value just returns it.Returns theKeyStrokes
that will initiate registered actions.Returns theJRootPane
ancestor for this component.Stores the width/height of this component into "return value"rv
and returnsrv
.getToolTipLocation
(MouseEvent event) Returns the tooltip location in this component's coordinate system.Returns the tooltip string that has been set withsetToolTipText
.Returns the top-level ancestor of this component (the containingWindow
) ornull
if this component has not been added to any container.Gets thetransferHandler
property.Returns theUIDefaults
key used to look up the name of theswing.plaf.ComponentUI
class that defines the look and feel for this component.boolean
Returns the value that indicates whether the input verifier for the current focus owner will be called before this component requests focus.Returns an array of all the vetoable change listeners registered on this component.Returns theComponent
's "visible rectangle" - the intersection of this component's visible rectangle,new Rectangle(0, 0, getWidth(), getHeight())
, and all of its ancestors' visible rectangles.int
getWidth()
Returns the current width of this component.int
getX()
Returns the current x coordinate of the component's origin.int
getY()
Returns the current y coordinate of the component's origin.void
Requests that this Component get the input focus, and that this Component's top-level ancestor become the focused Window.void
hide()
Deprecated.boolean
Returns whether this component should use a buffer to paint.static boolean
Returns true if this component is lightweight, that is, if it doesn't have a native window system peer.boolean
Deprecated.As of 1.4, replaced byComponent.setFocusTraversalKeys(int, Set)
andContainer.setFocusCycleRoot(boolean)
.boolean
isOpaque()
Returns true if this component is completely opaque.boolean
Returns true if this component tiles its children -- that is, if it can guarantee that the children will not overlap.final boolean
Returnstrue
if the current painting operation on this component is part of aprint
operation.protected boolean
Returnstrue
if a paint triggered on a child component should cause painting to originate from this Component, or one of its ancestors.boolean
Returns true if the component is currently painting a tile.boolean
Returnstrue
if thisJComponent
should get focus; otherwise returnsfalse
.boolean
If this method returns true,revalidate
calls by descendants of this component will cause the entire tree beginning with this root to be validated.void
Invoked by Swing to draw components.protected void
Paints the component's border.protected void
Paints this component's children.protected void
Calls the UI delegate's paint method, if the UI delegate is non-null
.void
paintImmediately
(int x, int y, int w, int h) Paints the specified region in this component and all of its descendants that overlap the region, immediately.void
Paints the specified region now.void
Invoke this method to print the component to the specifiedGraphics
.void
Invoke this method to print the component.protected void
Prints the component's border.protected void
Prints this component's children.protected void
This is invoked during a printing operation.protected void
Processes any key events that the component itself recognizes.protected boolean
processKeyBinding
(KeyStroke ks, KeyEvent e, int condition, boolean pressed) Invoked to process the key bindings forks
as the result of theKeyEvent
e
.protected void
OverridesprocessKeyEvent
to process events.protected void
Processes mouse events occurring on this component by dispatching them to any registeredMouseListener
objects, refer toComponent.processMouseEvent(MouseEvent)
for a complete description of this method.protected void
Processes mouse motion events, such as MouseEvent.MOUSE_DRAGGED.final void
putClientProperty
(Object key, Object value) Adds an arbitrary key/value "client property" to this component.void
registerKeyboardAction
(ActionListener anAction, String aCommand, KeyStroke aKeyStroke, int aCondition) This method is now obsolete, please use a combination ofgetActionMap()
andgetInputMap()
for similar behavior.void
registerKeyboardAction
(ActionListener anAction, KeyStroke aKeyStroke, int aCondition) This method is now obsolete, please use a combination ofgetActionMap()
andgetInputMap()
for similar behavior.void
removeAncestorListener
(AncestorListener listener) Unregisterslistener
so that it will no longer receiveAncestorEvents
.void
Notifies this component that it no longer has a parent component.void
Removes aVetoableChangeListener
from the listener list.void
repaint
(long tm, int x, int y, int width, int height) Adds the specified region to the dirty region list if the component is showing.void
Adds the specified region to the dirty region list if the component is showing.boolean
Deprecated.As of 1.4, replaced byFocusTraversalPolicy.getDefaultComponent(Container).requestFocus()
void
Requests that thisComponent
gets the input focus.boolean
requestFocus
(boolean temporary) Requests that thisComponent
gets the input focus.boolean
Requests that thisComponent
gets the input focus.protected boolean
requestFocusInWindow
(boolean temporary) Requests that thisComponent
gets the input focus.void
Unregisters all the bindings in the first tierInputMaps
andActionMap
.void
reshape
(int x, int y, int w, int h) Deprecated.As of JDK 5, replaced byComponent.setBounds(int, int, int, int)
.void
Supports deferred automatic layout.void
scrollRectToVisible
(Rectangle aRect) Forwards thescrollRectToVisible()
message to theJComponent
's parent.final void
Sets theActionMap
toam
.void
setAlignmentX
(float alignmentX) Sets the horizontal alignment.void
setAlignmentY
(float alignmentY) Sets the vertical alignment.void
setAutoscrolls
(boolean autoscrolls) Sets theautoscrolls
property.void
setBackground
(Color bg) Sets the background color of this component.void
Sets the border of this component.void
setComponentPopupMenu
(JPopupMenu popup) Sets theJPopupMenu
for thisJComponent
.void
setDebugGraphicsOptions
(int debugOptions) Enables or disables diagnostic information about every graphics operation performed within the component or one of its children.static void
Sets the default locale used to initialize each JComponent's locale property upon creation.void
setDoubleBuffered
(boolean aFlag) Sets whether this component should use a buffer to paint.void
setEnabled
(boolean enabled) Sets whether or not this component is enabled.void
setFocusTraversalKeys
(int id, Set<? extends AWTKeyStroke> keystrokes) Sets the focus traversal keys for a given traversal operation for this Component.void
Sets the font for this component.void
setForeground
(Color fg) Sets the foreground color of this component.void
setInheritsPopupMenu
(boolean value) Sets whether or notgetComponentPopupMenu
should delegate to the parent if this component does not have aJPopupMenu
assigned to it.final void
setInputMap
(int condition, InputMap map) Sets theInputMap
to use under the conditioncondition
tomap
.void
setInputVerifier
(InputVerifier inputVerifier) Sets the input verifier for this component.void
setMaximumSize
(Dimension maximumSize) Sets the maximum size of this component to a constant value.void
setMinimumSize
(Dimension minimumSize) Sets the minimum size of this component to a constant value.void
setNextFocusableComponent
(Component aComponent) Deprecated.As of 1.4, replaced byFocusTraversalPolicy
void
setOpaque
(boolean isOpaque) If true the component paints every pixel within its bounds.void
setPreferredSize
(Dimension preferredSize) Sets the preferred size of this component.void
setRequestFocusEnabled
(boolean requestFocusEnabled) Provides a hint as to whether or not thisJComponent
should get focus.void
setToolTipText
(String text) Registers the text to display in a tool tip.void
setTransferHandler
(TransferHandler newHandler) Sets theTransferHandler
, which provides support for transfer of data into and out of this component via cut/copy/paste and drag and drop.protected void
setUI
(ComponentUI newUI) Sets the look and feel delegate for this component.void
setVerifyInputWhenFocusTarget
(boolean verifyInputWhenFocusTarget) Sets the value to indicate whether input verifier for the current focus owner will be called before this component requests focus.void
setVisible
(boolean aFlag) Makes the component visible or invisible.void
unregisterKeyboardAction
(KeyStroke aKeyStroke) This method is now obsolete.void
Callspaint
.Methods declared in class 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, transferFocusDownCycle, validate, validateTree
Modifier and TypeMethodDescriptionAppends the specified component to the end of this container.Adds the specified component to this container at the given position.void
Adds the specified component to the end of this container.void
Adds the specified component to this container with the specified constraints at the specified index.Adds the specified component to this container.void
Adds the specified container listener to receive container events from this container.protected void
Adds the specified component to this container at the specified index.void
Adds a PropertyChangeListener to the listener list.void
addPropertyChangeListener
(String propertyName, PropertyChangeListener listener) Adds a PropertyChangeListener to the listener list for a specific property.void
Sets theComponentOrientation
property of this container and all components contained within it.boolean
areFocusTraversalKeysSet
(int id) Returns whether the Set of focus traversal keys for the given focus traversal operation has been explicitly defined for this Container.int
Deprecated.As of JDK version 1.1, replaced by getComponentCount().void
Deprecated.As of JDK version 1.1, replaced bydispatchEvent(AWTEvent e)
void
doLayout()
Causes this container to lay out its components.findComponentAt
(int x, int y) Locates the visible child component that contains the specified position.Locates the visible child component that contains the specified point.getComponent
(int n) Gets the nth component in this container.getComponentAt
(int x, int y) Locates the component that contains the x,y position.Gets the component that contains the specified point.int
Gets the number of components in this panel.Gets all the components in this container.int
getComponentZOrder
(Component comp) Returns the z-order index of the component inside the container.Returns an array of all the container listeners registered on this container.getFocusTraversalKeys
(int id) Returns the Set of focus traversal keys for a given traversal operation for this Container.Returns the focus traversal policy that will manage keyboard traversal of this Container's children, or null if this Container is not a focus cycle root.Gets the layout manager for this container.getMousePosition
(boolean allowChildren) Returns the position of the mouse pointer in thisContainer
's coordinate space if theContainer
is under the mouse pointer, otherwise returnsnull
.insets()
Deprecated.As of JDK version 1.1, replaced bygetInsets()
.void
Invalidates the container.boolean
Checks if the component is contained in the component hierarchy of this container.boolean
Returns whether this Container is the root of a focus traversal cycle.boolean
isFocusCycleRoot
(Container container) Returns whether the specified Container is the focus cycle root of this Container's focus traversal cycle.final boolean
Returns whether this container provides focus traversal policy.boolean
Returns whether the focus traversal policy has been explicitly set for this Container.void
layout()
Deprecated.As of JDK version 1.1, replaced bydoLayout()
.void
list
(PrintStream out, int indent) Prints a listing of this container to the specified output stream.void
list
(PrintWriter out, int indent) Prints out a list, starting at the specified indentation, to the specified print writer.locate
(int x, int y) Deprecated.As of JDK version 1.1, replaced bygetComponentAt(int, int)
.Deprecated.As of JDK version 1.1, replaced bygetMinimumSize()
.void
Paints each of the components in this container.Deprecated.As of JDK version 1.1, replaced bygetPreferredSize()
.void
Prints each of the components in this container.protected void
Processes container events occurring on this container by dispatching them to any registered ContainerListener objects.protected void
Processes events on this container.void
remove
(int index) Removes the component, specified byindex
, from this container.void
Removes the specified component from this container.void
Removes all the components from this container.void
Removes the specified container listener so it no longer receives container events from this container.void
setComponentZOrder
(Component comp, int index) Moves the specified component to the specified z-order index in the container.void
setFocusCycleRoot
(boolean focusCycleRoot) Sets whether this Container is the root of a focus traversal cycle.void
Sets the focus traversal policy that will manage keyboard traversal of this Container's children, if this Container is a focus cycle root.final void
setFocusTraversalPolicyProvider
(boolean provider) Sets whether this container will be used to provide focus traversal policy.void
setLayout
(LayoutManager mgr) Sets the layout manager for this container.void
Transfers the focus down one focus traversal cycle.void
validate()
Validates this container and all of its subcomponents.protected void
Recursively descends the container tree and recomputes the layout for any subtrees marked as needing it (those marked as invalid).Methods declared in class Component
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, 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, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, 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, processInputMethodEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setMixingCutoutShape, setName, setSize, setSize, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
Modifier and TypeMethodDescriptionboolean
Deprecated.As of JDK version 1.1, should register this component as ActionListener on component which fires action events.void
Adds the specified popup menu to the component.void
Adds the specified component listener to receive component events from this component.void
Adds the specified focus listener to receive focus events from this component when this component gains input focus.void
Adds the specified hierarchy bounds listener to receive hierarchy bounds events from this component when the hierarchy to which this container belongs changes.void
Adds the specified hierarchy listener to receive hierarchy changed events from this component when the hierarchy to which this container belongs changes.void
Adds the specified input method listener to receive input method events from this component.void
Adds the specified key listener to receive key events from this component.void
Adds the specified mouse listener to receive mouse events from this component.void
Adds the specified mouse motion listener to receive mouse motion events from this component.void
Adds the specified mouse wheel listener to receive mouse wheel events from this component.bounds()
Deprecated.As of JDK version 1.1, replaced bygetBounds()
.int
checkImage
(Image image, int width, int height, ImageObserver observer) Returns the status of the construction of a screen representation of the specified image.int
checkImage
(Image image, ImageObserver observer) Returns the status of the construction of a screen representation of the specified image.protected AWTEvent
coalesceEvents
(AWTEvent existingEvent, AWTEvent newEvent) Potentially coalesce an event being posted with an existing event.boolean
Checks whether this component "contains" the specified point, where the point's x and y coordinates are defined to be relative to the coordinate system of this component.createImage
(int width, int height) Creates an off-screen drawable image to be used for double buffering.createImage
(ImageProducer producer) Creates an image from the specified image producer.createVolatileImage
(int width, int height) Creates a volatile off-screen drawable image to be used for double buffering.createVolatileImage
(int width, int height, ImageCapabilities caps) Creates a volatile off-screen drawable image, with the given capabilities.protected final void
disableEvents
(long eventsToDisable) Disables the events defined by the specified event mask parameter from being delivered to this component.final void
Dispatches an event to this component or one of its sub components.void
enable
(boolean b) Deprecated.As of JDK version 1.1, replaced bysetEnabled(boolean)
.protected final void
enableEvents
(long eventsToEnable) Enables the events defined by the specified event mask parameter to be delivered to this component.void
enableInputMethods
(boolean enable) Enables or disables input method support for this component.void
firePropertyChange
(String propertyName, byte oldValue, byte newValue) Reports a bound property change.void
firePropertyChange
(String propertyName, char oldValue, char newValue) Reports a bound property change.void
firePropertyChange
(String propertyName, double oldValue, double newValue) Reports a bound property change.void
firePropertyChange
(String propertyName, float oldValue, float newValue) Reports a bound property change.void
firePropertyChange
(String propertyName, long oldValue, long newValue) Reports a bound property change.void
firePropertyChange
(String propertyName, short oldValue, short newValue) Reports a bound property change.protected void
firePropertyChange
(String propertyName, Object oldValue, Object newValue) Support for reporting bound property changes for Object properties.Gets the background color of this component.Gets the bounds of this component in the form of aRectangle
object.Gets the instance ofColorModel
used to display the component on the output device.Returns an array of all the component listeners registered on this component.Retrieves the language-sensitive orientation that is to be used to order the elements or text within this component.Gets the cursor set in the component.Gets theDropTarget
associated with thisComponent
.Returns the Container which is the focus cycle root of this Component's focus traversal cycle.Returns an array of all the focus listeners registered on this component.boolean
Returns whether focus traversal keys are enabled for this Component.getFont()
Gets the font of this component.Gets the foreground color of this component.Gets theGraphicsConfiguration
associated with thisComponent
.Returns an array of all the hierarchy bounds listeners registered on this component.Returns an array of all the hierarchy listeners registered on this component.boolean
Returns whether or not paint messages received from the operating system should be ignored.Gets the input context used by this component for handling the communication with input methods when text is entered in this component.Returns an array of all the input method listeners registered on this component.Returns an array of all the key listeners registered on this component.Gets the locale of this component.Gets the location of this component in the form of a point specifying the component's top-left corner.Gets the location of this component in the form of a point specifying the component's top-left corner in the screen's coordinate space.Returns an array of all the mouse listeners registered on this component.Returns an array of all the mouse motion listeners registered on this component.Returns the position of the mouse pointer in thisComponent
's coordinate space if theComponent
is directly under the mouse pointer, otherwise returnsnull
.Returns an array of all the mouse wheel listeners registered on this component.getName()
Gets the name of the component.Gets the parent of this component.Returns an array of all the property change listeners registered on this component.getPropertyChangeListeners
(String propertyName) Returns an array of all the listeners which have been associated with the named property.getSize()
Returns the size of this component in the form of aDimension
object.Gets the toolkit of this component.final Object
Gets this component's locking object (the object that owns the thread synchronization monitor) for AWT component-tree and layout operations.boolean
Deprecated.As of JDK version 1.1, replaced by processFocusEvent(FocusEvent).boolean
handleEvent
(Event evt) Deprecated.As of JDK version 1.1 replaced by processEvent(AWTEvent).boolean
hasFocus()
Returnstrue
if thisComponent
is the focus owner.boolean
imageUpdate
(Image img, int infoflags, int x, int y, int w, int h) Repaints the component when the image has changed.boolean
inside
(int x, int y) Deprecated.As of JDK version 1.1, replaced by contains(int, int).boolean
Returns whether the background color has been explicitly set for this Component.boolean
Returns whether the cursor has been explicitly set for this Component.boolean
Determines whether this component is displayable.boolean
Determines whether this component is enabled.boolean
Returns whether this Component can be focused.boolean
Returnstrue
if thisComponent
is the focus owner.boolean
Deprecated.As of 1.4, replaced byisFocusable()
.boolean
Returns whether the font has been explicitly set for this Component.boolean
Returns whether the foreground color has been explicitly set for this Component.boolean
A lightweight component doesn't have a native toolkit peer.boolean
Returns true if the maximum size has been set to a non-null
value otherwise returns false.boolean
Returns whether or notsetMinimumSize
has been invoked with a non-null value.boolean
Returns true if the preferred size has been set to a non-null
value otherwise returns false.boolean
Determines whether this component is showing on screen.boolean
isValid()
Determines whether this component is valid.boolean
Determines whether this component should be visible when its parent is visible.boolean
Deprecated.As of JDK version 1.1, replaced by processKeyEvent(KeyEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processKeyEvent(KeyEvent).void
list()
Prints a listing of this component to the standard system output streamSystem.out
.void
list
(PrintStream out) Prints a listing of this component to the specified output stream.void
list
(PrintWriter out) Prints a listing to the specified print writer.location()
Deprecated.As of JDK version 1.1, replaced bygetLocation()
.boolean
Deprecated.As of JDK version 1.1, replaced by processFocusEvent(FocusEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processMouseEvent(MouseEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processMouseMotionEvent(MouseEvent).boolean
mouseEnter
(Event evt, int x, int y) Deprecated.As of JDK version 1.1, replaced by processMouseEvent(MouseEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processMouseEvent(MouseEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processMouseMotionEvent(MouseEvent).boolean
Deprecated.As of JDK version 1.1, replaced by processMouseEvent(MouseEvent).void
move
(int x, int y) Deprecated.As of JDK version 1.1, replaced bysetLocation(int, int)
.void
Deprecated.As of JDK version 1.1, replaced by transferFocus().void
Paints this component and all of its subcomponents.boolean
Deprecated.As of JDK version 1.1, replaced by dispatchEvent(AWTEvent).boolean
prepareImage
(Image image, int width, int height, ImageObserver observer) Prepares an image for rendering on this component at the specified width and height.boolean
prepareImage
(Image image, ImageObserver observer) Prepares an image for rendering on this component.protected void
Processes component events occurring on this component by dispatching them to any registeredComponentListener
objects.protected void
Processes focus events occurring on this component by dispatching them to any registeredFocusListener
objects.protected void
Processes hierarchy bounds events occurring on this component by dispatching them to any registeredHierarchyBoundsListener
objects.protected void
Processes hierarchy events occurring on this component by dispatching them to any registeredHierarchyListener
objects.protected void
Processes input method events occurring on this component by dispatching them to any registeredInputMethodListener
objects.protected void
Processes mouse wheel events occurring on this component by dispatching them to any registeredMouseWheelListener
objects.void
remove
(MenuComponent popup) Removes the specified popup menu from the component.void
Removes the specified component listener so that it no longer receives component events from this component.void
Removes the specified focus listener so that it no longer receives focus events from this component.void
Removes the specified hierarchy bounds listener so that it no longer receives hierarchy bounds events from this component.void
Removes the specified hierarchy listener so that it no longer receives hierarchy changed events from this component.void
Removes the specified input method listener so that it no longer receives input method events from this component.void
Removes the specified key listener so that it no longer receives key events from this component.void
Removes the specified mouse listener so that it no longer receives mouse events from this component.void
Removes the specified mouse motion listener so that it no longer receives mouse motion events from this component.void
Removes the specified mouse wheel listener so that it no longer receives mouse wheel events from this component.void
Removes a PropertyChangeListener from the listener list.void
removePropertyChangeListener
(String propertyName, PropertyChangeListener listener) Removes aPropertyChangeListener
from the listener list for a specific property.void
repaint()
Repaints this component.void
repaint
(int x, int y, int width, int height) Repaints the specified rectangle of this component.void
repaint
(long tm) Repaints the component.protected boolean
requestFocus
(boolean temporary, FocusEvent.Cause cause) Requests by the reason ofcause
that thisComponent
get the input focus, and that thisComponent
's top-level ancestor become the focusedWindow
.void
requestFocus
(FocusEvent.Cause cause) Requests by the reason ofcause
that this Component get the input focus, and that this Component's top-level ancestor become the focused Window.boolean
Requests by the reason ofcause
that this Component get the input focus, if this Component's top-level ancestor is already the focused Window.void
resize
(int width, int height) Deprecated.As of JDK version 1.1, replaced bysetSize(int, int)
.void
Deprecated.As of JDK version 1.1, replaced bysetSize(Dimension)
.void
setBounds
(int x, int y, int width, int height) Moves and resizes this component.void
Moves and resizes this component to conform to the new bounding rectangler
.void
Sets the language-sensitive orientation that is to be used to order the elements or text within this component.void
Sets the cursor image to the specified cursor.void
Associate aDropTarget
with this component.void
setFocusable
(boolean focusable) Sets the focusable state of this Component to the specified value.void
setFocusTraversalKeysEnabled
(boolean focusTraversalKeysEnabled) Sets whether focus traversal keys are enabled for this Component.void
setIgnoreRepaint
(boolean ignoreRepaint) Sets whether or not paint messages received from the operating system should be ignored.void
Sets the locale of this component.void
setLocation
(int x, int y) Moves this component to a new location.void
setLocation
(Point p) Moves this component to a new location.void
setMixingCutoutShape
(Shape shape) Sets a 'mixing-cutout' shape for this lightweight component.void
Sets the name of the component to the specified string.void
setSize
(int width, int height) Resizes this component so that it has widthwidth
and heightheight
.void
Resizes this component so that it has widthd.width
and heightd.height
.void
show()
Deprecated.As of JDK version 1.1, replaced bysetVisible(boolean)
.void
show
(boolean b) Deprecated.As of JDK version 1.1, replaced bysetVisible(boolean)
.size()
Deprecated.As of JDK version 1.1, replaced bygetSize()
.toString()
Returns a string representation of this component and its values.void
Transfers the focus to the next component, as though this Component were the focus owner.void
Transfers the focus to the previous component, as though this Component were the focus owner.void
Transfers the focus up one focus traversal cycle.Methods declared in class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Modifier and TypeMethodDescriptionprotected Object
clone()
Creates and returns a copy of this object.boolean
Indicates whether some other object is "equal to" this one.protected void
finalize()
Deprecated, for removal: This API element is subject to removal in a future version.Finalization is deprecated and subject to removal in a future release.final Class
<?> getClass()
Returns the runtime class of thisObject
.int
hashCode()
Returns a hash code value for this object.final void
notify()
Wakes up a single thread that is waiting on this object's monitor.final void
Wakes up all threads that are waiting on this object's monitor.final void
wait()
Causes the current thread to wait until it is awakened, typically by being notified or interrupted.final void
wait
(long timeoutMillis) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.final void
wait
(long timeoutMillis, int nanos) Causes the current thread to wait until it is awakened, typically by being notified or interrupted, or until a certain amount of real time has elapsed.
-
Field Details
-
FOCUS_ACCELERATOR_KEY
The bound property name for the focus accelerator.- See Also:
-
DEFAULT_KEYMAP
The default keymap that will be shared by allJTextComponent
instances unless they have had a different keymap set.- See Also:
-
-
Constructor Details
-
JTextComponent
public JTextComponent()Creates a newJTextComponent
. Listeners for caret events are established, and the pluggable UI installed. The component is marked as editable. No layout manager is used, because layout is managed by the view subsystem of text. The document model is set tonull
.
-
-
Method Details
-
getUI
Fetches the user-interface factory for this text-oriented editor.- Overrides:
getUI
in classJComponent
- Returns:
- the factory
-
setUI
Sets the user-interface factory for this text-oriented editor.- Parameters:
ui
- the factory
-
updateUI
public void updateUI()Reloads the pluggable UI. The key used to fetch the new interface isgetUIClassID()
. The type of the UI isTextUI
.invalidate
is called after setting the UI.- Overrides:
updateUI
in classJComponent
- See Also:
-
addCaretListener
Adds a caret listener for notification of any changes to the caret.- Parameters:
listener
- the listener to be added- See Also:
-
removeCaretListener
Removes a caret listener.- Parameters:
listener
- the listener to be removed- See Also:
-
getCaretListeners
Returns an array of all the caret listeners registered on this text component.- Returns:
- all of this component's
CaretListener
s or an empty array if no caret listeners are currently registered - Since:
- 1.4
- See Also:
-
fireCaretUpdate
Notifies all listeners that have registered interest for notification on this event type. The event instance is lazily created using the parameters passed into the fire method. The listener list is processed in a last-to-first manner.- Parameters:
e
- the event- See Also:
-
setDocument
@BeanProperty(expert=true, description="the text document model") public void setDocument(Document doc) Associates the editor with a text document. The currently registered factory is used to build a view for the document, which gets displayed by the editor after revalidation. A PropertyChange event ("document") is propagated to each listener.- Parameters:
doc
- the document to display/edit- See Also:
-
getDocument
Fetches the model associated with the editor. This is primarily for the UI to get at the minimal amount of state required to be a text editor. Subclasses will return the actual type of the model which will typically be something that extends Document.- Returns:
- the model
-
getActions
Fetches the command list for the editor. This is the list of commands supported by the plugged-in UI augmented by the collection of commands that the editor itself supports. These are useful for binding to events, such as in a keymap.- Returns:
- the command list
-
setMargin
@BeanProperty(description="desired space between the border and text area") public void setMargin(Insets m) Sets margin space between the text component's border and its text. The text component's defaultBorder
object will use this value to create the proper margin. However, if a non-default border is set on the text component, it is thatBorder
object's responsibility to create the appropriate margin space (else this property will effectively be ignored). This causes a redraw of the component. A PropertyChange event ("margin") is sent to all listeners.- Parameters:
m
- the space between the border and the text
-
getMargin
Returns the margin between the text component's border and its text.- Returns:
- the margin
-
getCaret
Fetches the caret that allows text-oriented navigation over the view.- Returns:
- the caret
-
setCaret
@BeanProperty(expert=true, description="the caret used to select/navigate") public void setCaret(Caret c) Sets the caret to be used. By default this will be set by the UI that gets installed. This can be changed to a custom caret if desired. Setting the caret results in a PropertyChange event ("caret") being fired.- Parameters:
c
- the caret- See Also:
-
getHighlighter
Fetches the object responsible for making highlights.- Returns:
- the highlighter
-
setHighlighter
@BeanProperty(expert=true, description="object responsible for background highlights") public void setHighlighter(Highlighter h) Sets the highlighter to be used. By default this will be set by the UI that gets installed. This can be changed to a custom highlighter if desired. The highlighter can be set tonull
to disable it. A PropertyChange event ("highlighter") is fired when a new highlighter is installed.- Parameters:
h
- the highlighter- See Also:
-
setKeymap
@BeanProperty(description="set of key event to action bindings to use") public void setKeymap(Keymap map) Sets the keymap to use for binding events to actions. Setting tonull
effectively disables keyboard input. A PropertyChange event ("keymap") is fired when a new keymap is installed.- Parameters:
map
- the keymap- See Also:
-
setDragEnabled
@BeanProperty(bound=false, description="determines whether automatic drag handling is enabled") public void setDragEnabled(boolean b) Turns on or off automatic drag handling. In order to enable automatic drag handling, this property should be set totrue
, and the component'sTransferHandler
needs to benon-null
. The default value of thedragEnabled
property isfalse
.The job of honoring this property, and recognizing a user drag gesture, lies with the look and feel implementation, and in particular, the component's
TextUI
. When automatic drag handling is enabled, most look and feels (including those that subclassBasicLookAndFeel
) begin a drag and drop operation whenever the user presses the mouse button over a selection and then moves the mouse a few pixels. Setting this property totrue
can therefore have a subtle effect on how selections behave.If a look and feel is used that ignores this property, you can still begin a drag and drop operation by calling
exportAsDrag
on the component'sTransferHandler
.- Parameters:
b
- whether or not to enable automatic drag handling- Throws:
HeadlessException
- ifb
istrue
andGraphicsEnvironment.isHeadless()
returnstrue
- Since:
- 1.4
- See Also:
-
getDragEnabled
public boolean getDragEnabled()Returns whether or not automatic drag handling is enabled.- Returns:
- the value of the
dragEnabled
property - Since:
- 1.4
- See Also:
-
setDropMode
Sets the drop mode for this component. For backward compatibility, the default for this property isDropMode.USE_SELECTION
. Usage ofDropMode.INSERT
is recommended, however, for an improved user experience. It offers similar behavior of dropping between text locations, but does so without affecting the actual text selection and caret location.JTextComponents
support the following drop modes:DropMode.USE_SELECTION
DropMode.INSERT
The drop mode is only meaningful if this component has a
TransferHandler
that accepts drops.- Parameters:
dropMode
- the drop mode to use- Throws:
IllegalArgumentException
- if the drop mode is unsupported ornull
- Since:
- 1.6
- See Also:
-
getDropMode
Returns the drop mode for this component.- Returns:
- the drop mode for this component
- Since:
- 1.6
- See Also:
-
getDropLocation
Returns the location that this component should visually indicate as the drop location during a DnD operation over the component, ornull
if no location is to currently be shown.This method is not meant for querying the drop location from a
TransferHandler
, as the drop location is only set after theTransferHandler
'scanImport
has returned and has allowed for the location to be shown.When this property changes, a property change event with name "dropLocation" is fired by the component.
- Returns:
- the drop location
- Since:
- 1.6
- See Also:
-
getKeymap
Fetches the keymap currently active in this text component.- Returns:
- the keymap
-
addKeymap
Adds a new keymap into the keymap hierarchy. Keymap bindings resolve from bottom up so an attribute specified in a child will override an attribute specified in the parent.- Parameters:
nm
- the name of the keymap (must be unique within the collection of named keymaps in the document); the name may benull
if the keymap is unnamed, but the caller is responsible for managing the reference returned as an unnamed keymap can't be fetched by nameparent
- the parent keymap; this may benull
if unspecified bindings need not be resolved in some other keymap- Returns:
- the keymap
-
removeKeymap
-
getKeymap
-
loadKeymap
Loads a keymap with a bunch of bindings. This can be used to take a static table of definitions and load them into some keymap. The following example illustrates an example of binding some keys to the cut, copy, and paste actions associated with a JTextComponent. A code fragment to accomplish this might look as follows:
The sets of bindings and actions may be empty but must be non-static final JTextComponent.KeyBinding[] defaultBindings = { new JTextComponent.KeyBinding( KeyStroke.getKeyStroke(KeyEvent.VK_C, InputEvent.CTRL_MASK), DefaultEditorKit.copyAction), new JTextComponent.KeyBinding( KeyStroke.getKeyStroke(KeyEvent.VK_V, InputEvent.CTRL_MASK), DefaultEditorKit.pasteAction), new JTextComponent.KeyBinding( KeyStroke.getKeyStroke(KeyEvent.VK_X, InputEvent.CTRL_MASK), DefaultEditorKit.cutAction), }; JTextComponent c = new JTextPane(); Keymap k = c.getKeymap(); JTextComponent.loadKeymap(k, defaultBindings, c.getActions());
null
.- Parameters:
map
- the keymapbindings
- the bindingsactions
- the set of actions
-
getCaretColor
-
setCaretColor
@BeanProperty(preferred=true, description="the color used to render the caret") public void setCaretColor(Color c) Sets the current color used to render the caret. Setting tonull
effectively restores the default color. Setting the color results in a PropertyChange event ("caretColor") being fired.- Parameters:
c
- the color- See Also:
-
getSelectionColor
Fetches the current color used to render the selection.- Returns:
- the color
-
setSelectionColor
@BeanProperty(preferred=true, description="color used to render selection background") public void setSelectionColor(Color c) Sets the current color used to render the selection. Setting the color tonull
is the same as settingColor.white
. Setting the color results in a PropertyChange event ("selectionColor").- Parameters:
c
- the color- See Also:
-
getSelectedTextColor
Fetches the current color used to render the selected text.- Returns:
- the color
-
setSelectedTextColor
@BeanProperty(preferred=true, description="color used to render selected text") public void setSelectedTextColor(Color c) Sets the current color used to render the selected text. Setting the color tonull
is the same asColor.black
. Setting the color results in a PropertyChange event ("selectedTextColor") being fired.- Parameters:
c
- the color- See Also:
-
getDisabledTextColor
Fetches the current color used to render the disabled text.- Returns:
- the color
-
setDisabledTextColor
@BeanProperty(preferred=true, description="color used to render disabled text") public void setDisabledTextColor(Color c) Sets the current color used to render the disabled text. Setting the color fires off a PropertyChange event ("disabledTextColor").- Parameters:
c
- the color- See Also:
-
replaceSelection
Replaces the currently selected content with new content represented by the given string. If there is no selection this amounts to an insert of the given text. If there is no replacement text this amounts to a removal of the current selection.This is the method that is used by the default implementation of the action for inserting content that gets bound to the keymap actions.
- Parameters:
content
- the content to replace the selection with
-
getText
Fetches a portion of the text represented by the component. Returns an empty string if length is 0.- Parameters:
offs
- the offset ≥ 0len
- the length ≥ 0- Returns:
- the text
- Throws:
BadLocationException
- if the offset or length are invalid
-
modelToView
Deprecated.replaced bymodelToView2D(int)
Converts the given location in the model to a place in the view coordinate system. The component must have a positive size for this translation to be computed (i.e. layout cannot be computed until the component has been sized). The component does not have to be visible or painted.- Parameters:
pos
- the position ≥ 0- Returns:
- the coordinates as a rectangle, with (r.x, r.y) as the location in the coordinate system, or null if the component does not yet have a positive size.
- Throws:
BadLocationException
- if the given position does not represent a valid location in the associated document- See Also:
-
modelToView2D
Converts the given location in the model to a place in the view coordinate system. The component must have a positive size for this translation to be computed (i.e. layout cannot be computed until the component has been sized). The component does not have to be visible or painted.- Parameters:
pos
- the position>= 0
- Returns:
- the coordinates as a rectangle, with (r.x, r.y) as the location in the coordinate system, or null if the component does not yet have a positive size.
- Throws:
BadLocationException
- if the given position does not represent a valid location in the associated document- Since:
- 9
- See Also:
-
viewToModel
Deprecated.replaced byviewToModel2D(Point2D)
Converts the given place in the view coordinate system to the nearest representative location in the model. The component must have a positive size for this translation to be computed (i.e. layout cannot be computed until the component has been sized). The component does not have to be visible or painted.- Parameters:
pt
- the location in the view to translate- Returns:
- the offset ≥ 0 from the start of the document, or -1 if the component does not yet have a positive size.
- See Also:
-
viewToModel2D
Converts the given place in the view coordinate system to the nearest representative location in the model. The component must have a positive size for this translation to be computed (i.e. layout cannot be computed until the component has been sized). The component does not have to be visible or painted.- Parameters:
pt
- the location in the view to translate- Returns:
- the offset
>= 0
from the start of the document, or-1
if the component does not yet have a positive size. - Since:
- 9
- See Also:
-
cut
public void cut()Transfers the currently selected range in the associated text model to the system clipboard, removing the contents from the model. The current selection is reset. Does nothing fornull
selections.- See Also:
-
copy
public void copy()Transfers the currently selected range in the associated text model to the system clipboard, leaving the contents in the text model. The current selection remains intact. Does nothing fornull
selections.- See Also:
-
paste
public void paste()Transfers the contents of the system clipboard into the associated text model. If there is a selection in the associated view, it is replaced with the contents of the clipboard. If there is no selection, the clipboard contents are inserted in front of the current insert position in the associated view. If the clipboard is empty, does nothing.- See Also:
-
moveCaretPosition
public void moveCaretPosition(int pos) Moves the caret to a new position, leaving behind a mark defined by the last timesetCaretPosition
was called. This forms a selection. If the document isnull
, does nothing. The position must be between 0 and the length of the component's text or else an exception is thrown.- Parameters:
pos
- the position- Throws:
IllegalArgumentException
- if the value supplied forposition
is less than zero or greater than the component's text length- See Also:
-
setFocusAccelerator
@BeanProperty(description="accelerator character used to grab focus") public void setFocusAccelerator(char aKey) Sets the key accelerator that will cause the receiving text component to get the focus. The accelerator will be the key combination of the platform-specific modifier key and the character given (converted to upper case). For example, the ALT key is used as a modifier on Windows and the CTRL+ALT combination is used on Mac. By default, there is no focus accelerator key. Any previous key accelerator setting will be superseded. A '\0' key setting will be registered, and has the effect of turning off the focus accelerator. When the new key is set, a PropertyChange event (FOCUS_ACCELERATOR_KEY) will be fired.- Parameters:
aKey
- the key- See Also:
-
getFocusAccelerator
public char getFocusAccelerator()Returns the key accelerator that will cause the receiving text component to get the focus. Return '\0' if no focus accelerator has been set.- Returns:
- the key
-
read
Initializes from a stream. This creates a model of the type appropriate for the component and initializes the model from the stream. By default this will load the model as plain text. Previous contents of the model are discarded.- Parameters:
in
- the stream to read fromdesc
- an object describing the stream; this might be a string, a File, a URL, etc. Some kinds of documents (such as html for example) might be able to make use of this information; if non-null
, it is added as a property of the document- Throws:
IOException
- as thrown by the stream being used to initialize- See Also:
-
write
Stores the contents of the model into the given stream. By default this will store the model as plain text.- Parameters:
out
- the output stream- Throws:
IOException
- on any I/O error
-
setCaretPosition
@BeanProperty(bound=false, description="the caret position") public void setCaretPosition(int position) Sets the position of the text insertion caret for theTextComponent
. Note that the caret tracks change, so this may move if the underlying text of the component is changed. If the document isnull
, does nothing. The position must be between 0 and the length of the component's text or else an exception is thrown.- Parameters:
position
- the position- Throws:
IllegalArgumentException
- if the value supplied forposition
is less than zero or greater than the component's text length
-
getCaretPosition
public int getCaretPosition()Returns the position of the text insertion caret for the text component.- Returns:
- the position of the text insertion caret for the text component ≥ 0
-
setText
Sets the text of thisTextComponent
to the specified text. If the text isnull
or empty, has the effect of simply deleting the old text. When text has been inserted, the resulting caret location is determined by the implementation of the caret class.Note that text is not a bound property, so no
PropertyChangeEvent
is fired when it changes. To listen for changes to the text, useDocumentListener
.- Parameters:
t
- the new text to be set- See Also:
-
getText
Returns the text contained in thisTextComponent
. If the underlying document isnull
, will give aNullPointerException
. Note that text is not a bound property, so noPropertyChangeEvent
is fired when it changes. To listen for changes to the text, useDocumentListener
.- Returns:
- the text
- Throws:
NullPointerException
- if the document isnull
- See Also:
-
getSelectedText
Returns the selected text contained in thisTextComponent
. If the selection isnull
or the document empty, returnsnull
.- Returns:
- the text
- Throws:
IllegalArgumentException
- if the selection doesn't have a valid mapping into the document for some reason- See Also:
-
isEditable
public boolean isEditable()Returns the boolean indicating whether thisTextComponent
is editable or not.- Returns:
- the boolean value
- See Also:
-
setEditable
Sets the specified boolean to indicate whether or not thisTextComponent
should be editable. A PropertyChange event ("editable") is fired when the state is changed.- Parameters:
b
- the boolean to be set- See Also:
-
getSelectionStart
public int getSelectionStart()Returns the selected text's start position. Return 0 for an empty document, or the value of dot if no selection.- Returns:
- the start position ≥ 0
-
setSelectionStart
@BeanProperty(bound=false, description="starting location of the selection.") public void setSelectionStart(int selectionStart) Sets the selection start to the specified position. The new starting point is constrained to be before or at the current selection end.This is available for backward compatibility to code that called this method on
java.awt.TextComponent
. This is implemented to forward to theCaret
implementation which is where the actual selection is maintained.- Parameters:
selectionStart
- the start position of the text ≥ 0
-
getSelectionEnd
public int getSelectionEnd()Returns the selected text's end position. Return 0 if the document is empty, or the value of dot if there is no selection.- Returns:
- the end position ≥ 0
-
setSelectionEnd
@BeanProperty(bound=false, description="ending location of the selection.") public void setSelectionEnd(int selectionEnd) Sets the selection end to the specified position. The new end point is constrained to be at or after the current selection start.This is available for backward compatibility to code that called this method on
java.awt.TextComponent
. This is implemented to forward to theCaret
implementation which is where the actual selection is maintained.- Parameters:
selectionEnd
- the end position of the text ≥ 0
-
select
public void select(int selectionStart, int selectionEnd) Selects the text between the specified start and end positions.This method sets the start and end positions of the selected text, enforcing the restriction that the start position must be greater than or equal to zero. The end position must be greater than or equal to the start position, and less than or equal to the length of the text component's text.
If the caller supplies values that are inconsistent or out of bounds, the method enforces these constraints silently, and without failure. Specifically, if the start position or end position is greater than the length of the text, it is reset to equal the text length. If the start position is less than zero, it is reset to zero, and if the end position is less than the start position, it is reset to the start position.
This call is provided for backward compatibility. It is routed to a call to
setCaretPosition
followed by a call tomoveCaretPosition
. The preferred way to manage selection is by calling those methods directly.- Parameters:
selectionStart
- the start position of the textselectionEnd
- the end position of the text- See Also:
-
selectAll
public void selectAll()Selects all the text in theTextComponent
. Does nothing on anull
or empty document. -
getToolTipText
Returns the string to be used as the tooltip forevent
. This will return one of:- If
setToolTipText
has been invoked with a non-null
value, it will be returned, otherwise - The value from invoking
getToolTipText
on the UI will be returned.
JTextComponent
does not register itself with theToolTipManager
. This means that tooltips will NOT be shown from theTextUI
unlessregisterComponent
has been invoked on theToolTipManager
.- Overrides:
getToolTipText
in classJComponent
- Parameters:
event
- the event in question- Returns:
- the string to be used as the tooltip for
event
- See Also:
- If
-
getPreferredScrollableViewportSize
Returns the preferred size of the viewport for a view component. This is implemented to do the default behavior of returning the preferred size of the component.- Specified by:
getPreferredScrollableViewportSize
in interfaceScrollable
- Returns:
- the
preferredSize
of aJViewport
whose view is thisScrollable
- See Also:
-
getScrollableUnitIncrement
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. Ideally, components should handle a partially exposed row or column by returning the distance required to completely expose the item.The default implementation of this is to simply return 10% of the visible area. Subclasses are likely to be able to provide a much more reasonable value.
- Specified by:
getScrollableUnitIncrement
in interfaceScrollable
- Parameters:
visibleRect
- the view area visible within the viewportorientation
- eitherSwingConstants.VERTICAL
orSwingConstants.HORIZONTAL
direction
- less than zero to scroll up/left, greater than zero for down/right- Returns:
- the "unit" increment for scrolling in the specified direction
- Throws:
IllegalArgumentException
- for an invalid orientation- See Also:
-
getScrollableBlockIncrement
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.The default implementation of this is to simply return the visible area. Subclasses will likely be able to provide a much more reasonable value.
- Specified by:
getScrollableBlockIncrement
in interfaceScrollable
- Parameters:
visibleRect
- the view area visible within the viewportorientation
- eitherSwingConstants.VERTICAL
orSwingConstants.HORIZONTAL
direction
- less than zero to scroll up/left, greater than zero for down/right- Returns:
- the "block" increment for scrolling in the specified direction
- Throws:
IllegalArgumentException
- for an invalid orientation- See Also:
-
getScrollableTracksViewportWidth
Returns true if a viewport should always force the width of thisScrollable
to match the width of the viewport. For example a normal text view that supported line wrapping would return true here, since it would be undesirable for wrapped lines to disappear beyond the right edge of the viewport. Note that returning true for aScrollable
whose ancestor is aJScrollPane
effectively disables horizontal scrolling.Scrolling containers, like
JViewport
, will use this method each time they are validated.- Specified by:
getScrollableTracksViewportWidth
in interfaceScrollable
- Returns:
- true if a viewport should force the
Scrollable
s width to match its own
-
getScrollableTracksViewportHeight
Returns true if a viewport should always force the height of thisScrollable
to match the height of the viewport. For example a columnar text view that flowed text in left to right columns could effectively disable vertical scrolling by returning true here.Scrolling containers, like
JViewport
, will use this method each time they are validated.- Specified by:
getScrollableTracksViewportHeight
in interfaceScrollable
- Returns:
- true if a viewport should force the Scrollables height to match its own
-
print
A convenience print method that displays a print dialog, and then prints thisJTextComponent
in interactive mode with no header or footer text. Note: this method blocks until printing is done.Note: In headless mode, no dialogs will be shown.
This method calls the full featured
print
method to perform printing.- Returns:
true
, unless printing is canceled by the user- Throws:
PrinterException
- if an error in the print system causes the job to be aborted- Since:
- 1.6
- See Also:
-
print
public boolean print(MessageFormat headerFormat, MessageFormat footerFormat) throws PrinterException A convenience print method that displays a print dialog, and then prints thisJTextComponent
in interactive mode with the specified header and footer text. Note: this method blocks until printing is done.Note: In headless mode, no dialogs will be shown.
This method calls the full featured
print
method to perform printing.- Parameters:
headerFormat
- the text, inMessageFormat
, to be used as the header, ornull
for no headerfooterFormat
- the text, inMessageFormat
, to be used as the footer, ornull
for no footer- Returns:
true
, unless printing is canceled by the user- Throws:
PrinterException
- if an error in the print system causes the job to be aborted- Since:
- 1.6
- See Also:
-
print
public boolean print(MessageFormat headerFormat, MessageFormat footerFormat, boolean showPrintDialog, PrintService service, PrintRequestAttributeSet attributes, boolean interactive) throws PrinterException Prints the content of thisJTextComponent
. Note: this method blocks until printing is done.Page header and footer text can be added to the output by providing
MessageFormat
arguments. The printing code requestsStrings
from the formats, providing a single item which may be included in the formatted string: anInteger
representing the current page number.showPrintDialog boolean
parameter allows you to specify whether a print dialog is displayed to the user. When it is, the user may use the dialog to change printing attributes or even cancel the print.service
allows you to provide the initialPrintService
for the print dialog, or to specifyPrintService
to print to when the dialog is not shown.attributes
can be used to provide the initial values for the print dialog, or to supply any needed attributes when the dialog is not shown.attributes
can be used to control how the job will print, for example duplex or single-sided.interactive boolean
parameter allows you to specify whether to perform printing in interactive mode. Iftrue
, a progress dialog, with an abort option, is displayed for the duration of printing. This dialog is modal whenprint
is invoked on the Event Dispatch Thread and non-modal otherwise. Warning: calling this method on the Event Dispatch Thread withinteractive false
blocks all events, including repaints, from being processed until printing is complete. It is only recommended when printing from an application with no visible GUI.Note: In headless mode,
showPrintDialog
andinteractive
parameters are ignored and no dialogs are shown.This method ensures the
document
is not mutated during printing. To indicate it visually,setEnabled(false)
is set for the duration of printing.This method uses
getPrintable(MessageFormat, MessageFormat)
to render document content.This method is thread-safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
Sample Usage. This code snippet shows a cross-platform print dialog and then prints the
JTextComponent
in interactive mode unless the user cancels the dialog:textComponent.print(new MessageFormat("My text component header"), new MessageFormat("Footer. Page - {0}"), true, null, null, true);
Executing this code off the Event Dispatch Thread performs printing on the background. The following pattern might be used for background printing:
FutureTask<Boolean> future = new FutureTask<Boolean>( new Callable<Boolean>() { public Boolean call() { return textComponent.print(.....); } }); executor.execute(future);
- Parameters:
headerFormat
- the text, inMessageFormat
, to be used as the header, ornull
for no headerfooterFormat
- the text, inMessageFormat
, to be used as the footer, ornull
for no footershowPrintDialog
-true
to display a print dialog,false
otherwiseservice
- initialPrintService
, ornull
for the defaultattributes
- the job attributes to be applied to the print job, ornull
for noneinteractive
- whether to print in an interactive mode- Returns:
true
, unless printing is canceled by the user- Throws:
PrinterException
- if an error in the print system causes the job to be aborted- Since:
- 1.6
- See Also:
-
getPrintable
Returns aPrintable
to use for printing the content of thisJTextComponent
. The returnedPrintable
prints the document as it looks on the screen except being reformatted to fit the paper. The returnedPrintable
can be wrapped inside anotherPrintable
in order to create complex reports and documents.The returned
Printable
shares thedocument
with thisJTextComponent
. It is the responsibility of the developer to ensure that thedocument
is not mutated while thisPrintable
is used. Printing behavior is undefined when thedocument
is mutated during printing.Page header and footer text can be added to the output by providing
MessageFormat
arguments. The printing code requestsStrings
from the formats, providing a single item which may be included in the formatted string: anInteger
representing the current page number.The returned
Printable
when printed, formats the document content appropriately for the page size. For correct line wrapping theimageable width
of all pages must be the same. SeePageFormat.getImageableWidth()
.This method is thread-safe, although most Swing methods are not. Please see Concurrency in Swing for more information.
The returned
Printable
can be printed on any thread.This implementation returned
Printable
performs all painting on the Event Dispatch Thread, regardless of what thread it is used on.- Parameters:
headerFormat
- the text, inMessageFormat
, to be used as the header, ornull
for no headerfooterFormat
- the text, inMessageFormat
, to be used as the footer, ornull
for no footer- Returns:
- a
Printable
for use in printing content of thisJTextComponent
- Since:
- 1.6
- See Also:
-
getAccessibleContext
Gets theAccessibleContext
associated with thisJTextComponent
. For text components, theAccessibleContext
takes the form of anAccessibleJTextComponent
. A newAccessibleJTextComponent
instance is created if necessary.- Specified by:
getAccessibleContext
in interfaceAccessible
- Overrides:
getAccessibleContext
in classComponent
- Returns:
- an
AccessibleJTextComponent
that serves as theAccessibleContext
of thisJTextComponent
-
paramString
Returns a string representation of thisJTextComponent
. This method is intended to be used only for debugging purposes, and the content and format of the returned string may vary between implementations. The returned string may be empty but may not benull
.Overriding
paramString
to provide information about the specific new aspects of the JFC components.- Overrides:
paramString
in classJComponent
- Returns:
- a string representation of this
JTextComponent
-
getInputMethodRequests
Description copied from class:Component
Gets the input method request handler which supports requests from input methods for this component. A component that supports on-the-spot text input must override this method to return anInputMethodRequests
instance. At the same time, it also has to handle input method events.- Overrides:
getInputMethodRequests
in classComponent
- Returns:
- the input method request handler for this component,
null
by default - See Also:
-
saveComposedText
protected boolean saveComposedText(int pos) Saves composed text around the specified position. The composed text (if any) around the specified position is saved in a backing store and removed from the document.- Parameters:
pos
- document position to identify the composed text location- Returns:
true
if the composed text exists and is saved,false
otherwise- Since:
- 1.7
- See Also:
-
restoreComposedText
protected void restoreComposedText()Restores composed text previously saved bysaveComposedText
. The saved composed text is inserted back into the document. This method should be invoked only ifsaveComposedText
returnstrue
.- Since:
- 1.7
- See Also:
-
modelToView2D(int)