|
JSR-209 (Final Release) | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectjava.awt.Component
java.awt.Container
javax.swing.JComponent
javax.swing.text.JTextComponent
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.
CaretListener
interface that have been registered with the text component.
The UI will install a default caret unless a customized caret
has been set.
Action
interface,
using the TextAction
implementation.
The set of commands supported by the text component can be
found with the getActions()
method. These actions
can be bound to key events, fired from buttons, etc.
A Keymap
lets an application bind key
strokes to actions.
In order to allow keymaps to be shared across multiple text components, they
can use actions that extend TextAction
.
TextAction
can determine which JTextComponent
most recently has or had focus and therefore is the subject of
the action (In the case that the ActionEvent
sent to the action doesn't contain the target text component as its source).
The input method framework
lets text components interact with input methods, separate software
components that preprocess events to let users enter thousands of
different characters using keyboards with far fewer keys.
JTextComponent
is an active client of
the framework, so it implements the preferred user interface for interacting
with input methods. As a consequence, some key events do not reach the text
component because they are handled by an input method, and some text input
reaches the text component as committed text within an InputMethodEvent
instead of as a key event.
The complete text input is the combination of the characters in
keyTyped
key events and committed text in input method events.
The AWT listener model lets applications attach event listeners to components in order to bind events to actions. Swing encourages the use of keymaps instead of listeners, but maintains compatibility with listeners by giving the listeners a chance to steal an event by consuming it.
Keyboard event and input method events are handled in the following stages, with each stage capable of consuming the event:
Stage |
KeyEvent |
InputMethodEvent |
---|---|---|
1. | input methods | (generated here) |
2. | focus manager | |
3. | registered key listeners | registered input method listeners |
4. | input method handling in JTextComponent | |
5. | keymap handling using the current keymap | |
6. | keyboard handling in JComponent (e.g. accelerators, component navigation, etc.) |
To maintain compatibility with applications that listen to key events but are not aware of input method events, the input method handling in stage 4 provides a compatibility mode for components that do not process input method events. For these components, the committed text is converted to keyTyped key events and processed in the key event pipeline starting at stage 3 instead of in the input method event pipeline.
By default the component will create a keymap (named DEFAULT_KEYMAP) that is shared by all JTextComponent instances as the default keymap. Typically a look-and-feel implementation will install a different keymap that resolves to the default keymap for those bindings not found in the different keymap. The minimal bindings include:
The model is defined by the Document
interface.
This is intended to provide a flexible text storage mechanism
that tracks change during edits and can be extended to more sophisticated
models. The model interfaces are meant to capture the capabilities of
expression given by SGML, a system used to express a wide variety of
content.
Each modification to the document causes notification of the
details of the change to be sent to all observers in the form of a
DocumentEvent
which allows the views to stay up to date with the model.
This event is sent to observers that have implemented the
DocumentListener
interface and registered interest with the model being observed.
modelToView(int)
and viewToModel(java.awt.Point)
for determining this information.
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.
AbstractDocument
describes the assumptions of the protection provided.
The methods that are safe to call asynchronously are marked
with comments.
Implementations of AGUI may employ the following restrictions:
Implementations of AGUI may employ the following clarifications:
Warning:
Serialized objects of this class will not be compatible with
future Swing releases. The current serialization support is
appropriate for short term storage or RMI between applications running
the same version of Swing. As of 1.4, support for long term storage
of all JavaBeansTM
has been added to the
Restrictions
Clarifications
DefaultEditorKit
class which is removed from this JSR however should still be respected
for upward compatibility.)
There are two properties which deal with newlines. The system
property, line.separator, is defined to be platform-dependent,
either "\n", "\r", or "\r\n". There is also a property called EndOfLineStringProperty, which is
defined automatically when a document is loaded, to be the first
occurrence of any of the newline characters. When a document is
loaded, EndOfLineStringProperty is set appropriately, and when
the document is written back out, the EndOfLineStringProperty is
used. But while the document is in memory, the "\n" character is
used to define a newline, regardless of how the newline is
defined when the document is on disk. Therefore, for searching
purposes, "\n" should always be used. When a new document is
created, and the EndOfLineStringProperty has not been defined, it
will use the System property when writing out the document.
Note that EndOfLineStringProperty is set on the Document using the
get/setProperty methods. Subclasses may override this behavior.JTextComponent
are called. In all implementations
calls to methods that operate on the clipboard are expected to operate
among instances of JTextComponent
. The following methods are
that operate on the clipboard are:
setFocusAccelerator(char)
to fail silently if this method can not
be supported by the platform. If this method is restricted the following
side effects will occur:
java.beans
package.
Please see java.beans.XMLEncoder
.
Document
,
DocumentEvent
,
DocumentListener
,
Caret
,
CaretEvent
,
CaretListener
,
View
,
ViewFactory
Nested Class Summary | |
static class |
JTextComponent.KeyBinding
Binding record for creating key bindings. |
Field Summary | |
static java.lang.String |
DEFAULT_KEYMAP
The default keymap that will be shared by all JTextComponent instances unless they
have had a different keymap set. |
static java.lang.String |
FOCUS_ACCELERATOR_KEY
The bound property name for the focus accelerator. |
Fields inherited from class javax.swing.JComponent |
listenerList, TOOL_TIP_TEXT_KEY, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW |
Fields inherited from class java.awt.Component |
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT |
Fields inherited from interface java.awt.image.ImageObserver |
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH |
Constructor Summary | |
JTextComponent()
Creates a new JTextComponent . |
Method Summary | |
void |
addCaretListener(CaretListener listener)
Adds a caret listener for notification of any changes to the caret. |
void |
addInputMethodListener(java.awt.event.InputMethodListener l)
|
static Keymap |
addKeymap(java.lang.String nm,
Keymap parent)
Adds a new keymap into the keymap hierarchy. |
void |
copy()
Transfers the currently selected range in the associated text model to the system clipboard, leaving the contents in the text model. |
void |
cut()
Transfers the currently selected range in the associated text model to the system clipboard, removing the contents from the model. |
protected void |
fireCaretUpdate(CaretEvent e)
Notifies all listeners that have registered interest for notification on this event type. |
Action[] |
getActions()
Fetches the command list for the editor. |
Caret |
getCaret()
Fetches the caret that allows text-oriented navigation over the view. |
Color |
getCaretColor()
Fetches the current color used to render the caret. |
CaretListener[] |
getCaretListeners()
Returns an array of all the caret listeners registered on this text component. |
int |
getCaretPosition()
Returns the position of the text insertion caret for the text component. |
Color |
getDisabledTextColor()
Fetches the current color used to render the selected text. |
Document |
getDocument()
Fetches the model associated with the editor. |
char |
getFocusAccelerator()
Returns the key accelerator that will cause the receiving text component to get the focus. |
Highlighter |
getHighlighter()
Fetches the object responsible for making highlights. |
java.awt.im.InputMethodRequests |
getInputMethodRequests()
|
Keymap |
getKeymap()
Fetches the keymap currently active in this text component. |
static Keymap |
getKeymap(java.lang.String nm)
Fetches a named keymap previously added to the document. |
java.awt.Insets |
getMargin()
Returns the margin between the text component's border and its text. |
NavigationFilter |
getNavigationFilter()
Returns the NavigationFilter . |
Dimension |
getPreferredScrollableViewportSize()
Returns the preferred size of the viewport for a view component. |
int |
getScrollableBlockIncrement(Rectangle visibleRect,
int orientation,
int direction)
Components that display logical rows or columns should compute the scroll increment that will completely expose one block of rows or columns, depending on the value of orientation. |
boolean |
getScrollableTracksViewportHeight()
Returns true if a viewport should always force the height of this Scrollable to match the height of the viewport. |
boolean |
getScrollableTracksViewportWidth()
Returns true if a viewport should always force the width of this Scrollable to match the width of the viewport. |
int |
getScrollableUnitIncrement(Rectangle visibleRect,
int orientation,
int direction)
Components that display logical rows or columns should compute the scroll increment that will completely expose one new row or column, depending on the value of orientation. |
java.lang.String |
getSelectedText()
Returns the selected text contained in this TextComponent . |
Color |
getSelectedTextColor()
Fetches the current color used to render the selected text. |
Color |
getSelectionColor()
Fetches the current color used to render the selection. |
int |
getSelectionEnd()
Returns the selected text's end position. |
int |
getSelectionStart()
Returns the selected text's start position. |
java.lang.String |
getText()
Returns the text contained in this TextComponent . |
java.lang.String |
getText(int offs,
int len)
Fetches a portion of the text represented by the component. |
boolean |
isEditable()
Returns the boolean indicating whether this TextComponent is editable or not. |
static void |
loadKeymap(Keymap map,
JTextComponent.KeyBinding[] bindings,
Action[] actions)
Loads a keymap with a bunch of bindings. |
Rectangle |
modelToView(int pos)
Converts the given location in the model to a place in the view coordinate system. |
void |
moveCaretPosition(int pos)
Moves the caret to a new position, leaving behind a mark defined by the last time setCaretPosition was
called. |
protected java.lang.String |
paramString()
Returns a string representation of this JTextComponent . |
void |
paste()
Transfers the contents of the system clipboard into the associated text model. |
protected void |
processInputMethodEvent(java.awt.event.InputMethodEvent e)
|
void |
read(java.io.Reader in,
java.lang.Object desc)
Initializes from a stream. |
void |
removeCaretListener(CaretListener listener)
Removes a caret listener. |
static Keymap |
removeKeymap(java.lang.String nm)
Removes a named keymap previously added to the document. |
void |
removeNotify()
Notifies this component that it no longer has a parent component. |
void |
replaceSelection(java.lang.String content)
Replaces the currently selected content with new content represented by the given string. |
void |
select(int selectionStart,
int selectionEnd)
Selects the text between the specified start and end positions. |
void |
selectAll()
Selects all the text in the TextComponent . |
void |
setCaret(Caret c)
Sets the caret to be used. |
void |
setCaretColor(Color c)
Sets the current color used to render the caret. |
void |
setCaretPosition(int position)
Sets the position of the text insertion caret for the TextComponent . |
void |
setDisabledTextColor(Color c)
Sets the current color used to render the disabled text. |
void |
setDocument(Document doc)
Associates the editor with a text document. |
void |
setEditable(boolean b)
Sets the specified boolean to indicate whether or not this TextComponent should be editable. |
void |
setFocusAccelerator(char aKey)
Sets the key accelerator that will cause the receiving text component to get the focus. |
void |
setHighlighter(Highlighter h)
Sets the highlighter to be used. |
void |
setKeymap(Keymap map)
Sets the keymap to use for binding events to actions. |
void |
setMargin(java.awt.Insets m)
Sets margin space between the text component's border and its text. |
void |
setNavigationFilter(NavigationFilter filter)
Sets the NavigationFilter . |
void |
setSelectedTextColor(Color c)
Sets the current color used to render the selected text. |
void |
setSelectionColor(Color c)
Sets the current color used to render the selection. |
void |
setSelectionEnd(int selectionEnd)
Sets the selection end to the specified position. |
void |
setSelectionStart(int selectionStart)
Sets the selection start to the specified position. |
void |
setText(java.lang.String t)
Sets the text of this TextComponent
to the specified text. |
int |
viewToModel(Point pt)
Converts the given place in the view coordinate system to the nearest representative location in the model. |
void |
write(java.io.Writer out)
Stores the contents of the model into the given stream. |
Methods inherited from class java.awt.Container |
add, add, add, add, add, addContainerListener, addImpl, areFocusTraversalKeysSet, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicySet, list, list, paintComponents, printComponents, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setFocusCycleRoot, setFocusTraversalKeys, setFocusTraversalPolicy, setLayout, transferFocusBackward, transferFocusDownCycle, validate, validateTree |
Methods inherited from class java.awt.Component |
addComponentListener, addFocusListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enableEvents, enableInputMethods, getBackground, getBounds, getColorModel, getComponentListeners, getCursor, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getFontMetrics, getForeground, getGraphicsConfiguration, getIgnoreRepaint, getInputContext, getInputMethodListeners, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMouseWheelListeners, getName, getParent, getSize, getToolkit, getTreeLock, hasFocus, imageUpdate, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isShowing, isValid, isVisible, list, list, list, paintAll, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processMouseEvent, processMouseWheelEvent, removeComponentListener, removeFocusListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, repaint, repaint, repaint, setBounds, setBounds, setCursor, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setName, setSize, setSize, toString, transferFocus, transferFocusUpCycle |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
public static final java.lang.String FOCUS_ACCELERATOR_KEY
public static final java.lang.String DEFAULT_KEYMAP
JTextComponent
instances unless they
have had a different keymap set.
Constructor Detail |
public JTextComponent()
JTextComponent
.
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 to null
.
Method Detail |
public void addCaretListener(CaretListener listener)
listener
- the listener to be addedCaretEvent
public void removeCaretListener(CaretListener listener)
listener
- the listener to be removedCaretEvent
public CaretListener[] getCaretListeners()
CaretListener
s
or an empty
array if no caret listeners are currently registeredaddCaretListener(javax.swing.event.CaretListener)
,
removeCaretListener(javax.swing.event.CaretListener)
protected void fireCaretUpdate(CaretEvent e)
e
- the eventEventListenerList
public void setDocument(Document doc)
doc
- the document to display/editgetDocument()
public Document getDocument()
public Action[] getActions()
public void setMargin(java.awt.Insets m)
Border
object will use this value to create the proper margin.
However, if a non-default border is set on the text component,
it is that Border
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.
m
- the space between the border and the textpublic java.awt.Insets getMargin()
public void setNavigationFilter(NavigationFilter filter)
NavigationFilter
. NavigationFilter
is used by DefaultCaret
and the default cursor movement
actions as a way to restrict the cursor movement.
public NavigationFilter getNavigationFilter()
NavigationFilter
. NavigationFilter
is used by DefaultCaret
and the default cursor movement
actions as a way to restrict the cursor movement. A null return value
implies the cursor movement and selection should not be restricted.
public Caret getCaret()
public void setCaret(Caret c)
c
- the caretgetCaret()
public Highlighter getHighlighter()
public void setHighlighter(Highlighter h)
null
to disable it.
A PropertyChange event ("highlighter") is fired
when a new highlighter is installed.
h
- the highlightergetHighlighter()
public void setKeymap(Keymap map)
null
effectively disables
keyboard input.
A PropertyChange event ("keymap") is fired when a new keymap
is installed.
map
- the keymapgetKeymap()
public Keymap getKeymap()
public static Keymap addKeymap(java.lang.String nm, Keymap parent)
nm
- the name of the keymap (must be unique within the
collection of named keymaps in the document); the name may
be null
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 be null
if
unspecified bindings need not be resolved in some other keymap
public static Keymap removeKeymap(java.lang.String nm)
null
names may not be removed in this way.
nm
- the name of the keymap to remove
public static Keymap getKeymap(java.lang.String nm)
null
-named keymaps.
nm
- the name of the keymap
public static void loadKeymap(Keymap map, JTextComponent.KeyBinding[] bindings, Action[] actions)
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:
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());
The sets of bindings and actions may be empty but must be
non-null
.
map
- the keymapbindings
- the bindingsactions
- the set of actionspublic Color getCaretColor()
public void setCaretColor(Color c)
null
effectively restores the default color.
Setting the color results in a PropertyChange event ("caretColor")
being fired.
c
- the colorgetCaretColor()
public Color getSelectionColor()
public void setSelectionColor(Color c)
null
is the same as setting
Color.white
. Setting the color results in a
PropertyChange event ("selectionColor").
c
- the colorgetSelectionColor()
public Color getSelectedTextColor()
public void setSelectedTextColor(Color c)
null
is the same as
Color.black
. Setting the color results in a
PropertyChange event ("selectedTextColor") being fired.
c
- the colorgetSelectedTextColor()
public Color getDisabledTextColor()
public void setDisabledTextColor(Color c)
c
- the colorgetDisabledTextColor()
public void replaceSelection(java.lang.String content)
This is the method that is used by the default implementation of the action for inserting content that gets bound to the keymap actions.
This method is thread safe, although most Swing methods are not. Please see Threads and Swing for more information.
content
- the content to replace the selection withpublic java.lang.String getText(int offs, int len) throws BadLocationException
offs
- the offset >= 0len
- the length >= 0
BadLocationException
- if the offset or length are invalidpublic Rectangle modelToView(int pos) throws BadLocationException
pos
- the position >= 0
BadLocationException
- if the given position does not
represent a valid location in the associated documentpublic int viewToModel(Point pt)
pt
- the location in the view to translate
public void cut()
null
selections.
public void copy()
null
selections.
public void paste()
public void moveCaretPosition(int pos)
setCaretPosition
was
called. This forms a selection.
If the document is null
, does nothing. The position
must be between 0 and the length of the component's text or else
an exception is thrown.
pos
- the position
java.lang.IllegalArgumentException
- if the value supplied
for position
is less than zero or greater
than the component's text lengthsetCaretPosition(int)
public void setFocusAccelerator(char aKey)
aKey
- the keygetFocusAccelerator()
public char getFocusAccelerator()
public void read(java.io.Reader in, java.lang.Object desc) throws java.io.IOException
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
java.io.IOException
- as thrown by the stream being
used to initializeEditorKit.createDefaultDocument()
,
setDocument(javax.swing.text.Document)
,
PlainDocument
public void write(java.io.Writer out) throws java.io.IOException
out
- the output stream
java.io.IOException
- on any I/O errorpublic void removeNotify()
JComponent
KeyboardAction
s
set up in the the chain of parent components are removed.
removeNotify
in class JComponent
JComponent.registerKeyboardAction(java.awt.event.ActionListener, java.lang.String, javax.swing.KeyStroke, int)
public void setCaretPosition(int position)
TextComponent
. Note that the caret tracks change,
so this may move if the underlying text of the component is changed.
If the document is null
, does nothing. The position
must be between 0 and the length of the component's text or else
an exception is thrown.
position
- the position
java.lang.IllegalArgumentException
- if the value supplied
for position
is less than zero or greater
than the component's text lengthpublic int getCaretPosition()
public void setText(java.lang.String t)
TextComponent
to the specified text. If the text is null
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.
This method is thread safe, although most Swing methods are not. Please see Threads and Swing for more information.
t
- the new text to be setgetText(int, int)
,
DefaultCaret
public java.lang.String getText()
TextComponent
.
If the underlying document is null
,
will give a NullPointerException
.
java.lang.NullPointerException
- if the document is null
setText(java.lang.String)
public java.lang.String getSelectedText()
TextComponent
. If the selection is
null
or the document empty, returns null
.
java.lang.IllegalArgumentException
- if the selection doesn't
have a valid mapping into the document for some reasonsetText(java.lang.String)
public boolean isEditable()
TextComponent
is editable or not.
setEditable(boolean)
public void setEditable(boolean b)
TextComponent
should be editable.
A PropertyChange event ("editable") is fired when the
state is changed.
b
- the boolean to be setisEditable()
public int getSelectionStart()
public void setSelectionStart(int selectionStart)
This is available for backward compatibility to code
that called this method on java.awt.TextComponent
.
This is implemented to forward to the Caret
implementation which is where the actual selection is maintained.
selectionStart
- the start position of the text >= 0public int getSelectionEnd()
public void setSelectionEnd(int selectionEnd)
This is available for backward compatibility to code
that called this method on java.awt.TextComponent
.
This is implemented to forward to the Caret
implementation which is where the actual selection is maintained.
selectionEnd
- the end position of the text >= 0public void select(int selectionStart, int selectionEnd)
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 to moveCaretPosition
.
The preferred way to manage selection is by calling
those methods directly.
selectionStart
- the start position of the textselectionEnd
- the end position of the textsetCaretPosition(int)
,
moveCaretPosition(int)
public void selectAll()
TextComponent
.
Does nothing on a null
or empty document.
public Dimension getPreferredScrollableViewportSize()
getPreferredScrollableViewportSize
in interface Scrollable
preferredSize
of a JViewport
whose view is this Scrollable
JComponent.getPreferredSize()
public int getScrollableUnitIncrement(Rectangle visibleRect, int orientation, int direction)
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.
getScrollableUnitIncrement
in interface Scrollable
visibleRect
- the view area visible within the viewportorientation
- either SwingConstants.VERTICAL
or
SwingConstants.HORIZONTAL
direction
- less than zero to scroll up/left, greater than
zero for down/right
java.lang.IllegalArgumentException
- for an invalid orientationJScrollBar.setUnitIncrement(int)
public int getScrollableBlockIncrement(Rectangle visibleRect, int orientation, int direction)
The default implementation of this is to simply return the visible area. Subclasses will likely be able to provide a much more reasonable value.
getScrollableBlockIncrement
in interface Scrollable
visibleRect
- the view area visible within the viewportorientation
- either SwingConstants.VERTICAL
or
SwingConstants.HORIZONTAL
direction
- less than zero to scroll up/left, greater than zero
for down/right
java.lang.IllegalArgumentException
- for an invalid orientationJScrollBar.setBlockIncrement(int)
public boolean getScrollableTracksViewportWidth()
Scrollable
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 a
Scrollable
whose ancestor is a JScrollPane
effectively disables horizontal scrolling.
Scrolling containers, like JViewport
,
will use this method each time they are validated.
getScrollableTracksViewportWidth
in interface Scrollable
Scrollable
s
width to match its ownpublic boolean getScrollableTracksViewportHeight()
Scrollable
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.
getScrollableTracksViewportHeight
in interface Scrollable
protected java.lang.String paramString()
JTextComponent
.
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
be null
.
Overriding paramString
to provide information about the
specific new aspects of the JFC components.
paramString
in class JComponent
JTextComponent
protected void processInputMethodEvent(java.awt.event.InputMethodEvent e)
public java.awt.im.InputMethodRequests getInputMethodRequests()
public void addInputMethodListener(java.awt.event.InputMethodListener l)
|
JSR-209 (Final Release) | ||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |