public class JTextComponent.AccessibleJTextComponent extends JComponent.AccessibleJComponent implements AccessibleText, CaretListener, DocumentListener, AccessibleAction, AccessibleEditableText, AccessibleExtendedText
This class implements accessibility support for the JTextComponent
class. It provides an implementation of the Java Accessibility API appropriate to menu user-interface elements.
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
.
JComponent.AccessibleJComponent.AccessibleContainerHandler, JComponent.AccessibleJComponent.AccessibleFocusHandler
Component.AccessibleAWTComponent.AccessibleAWTComponentHandler, Component.AccessibleAWTComponent.AccessibleAWTFocusHandler
accessibleFocusHandler
accessibleContainerHandler
accessibleAWTComponentHandler, accessibleAWTFocusHandler
ACCESSIBLE_ACTION_PROPERTY, ACCESSIBLE_ACTIVE_DESCENDANT_PROPERTY, ACCESSIBLE_CARET_PROPERTY, ACCESSIBLE_CHILD_PROPERTY, ACCESSIBLE_COMPONENT_BOUNDS_CHANGED, ACCESSIBLE_DESCRIPTION_PROPERTY, ACCESSIBLE_HYPERTEXT_OFFSET, ACCESSIBLE_INVALIDATE_CHILDREN, ACCESSIBLE_NAME_PROPERTY, ACCESSIBLE_SELECTION_PROPERTY, ACCESSIBLE_STATE_PROPERTY, ACCESSIBLE_TABLE_CAPTION_CHANGED, ACCESSIBLE_TABLE_COLUMN_DESCRIPTION_CHANGED, ACCESSIBLE_TABLE_COLUMN_HEADER_CHANGED, ACCESSIBLE_TABLE_MODEL_CHANGED, ACCESSIBLE_TABLE_ROW_DESCRIPTION_CHANGED, ACCESSIBLE_TABLE_ROW_HEADER_CHANGED, ACCESSIBLE_TABLE_SUMMARY_CHANGED, ACCESSIBLE_TEXT_ATTRIBUTES_CHANGED, ACCESSIBLE_TEXT_PROPERTY, ACCESSIBLE_VALUE_PROPERTY, ACCESSIBLE_VISIBLE_DATA_PROPERTY, accessibleDescription, accessibleName, accessibleParent
CLICK, DECREMENT, INCREMENT, TOGGLE_EXPAND, TOGGLE_POPUP
CHARACTER, SENTENCE, WORD
ATTRIBUTE_RUN, LINE
public AccessibleJTextComponent()
Constructs an AccessibleJTextComponent. Adds a listener to track caret change.
public void caretUpdate(CaretEvent e)
Handles caret updates (fire appropriate property change event, which are AccessibleContext.ACCESSIBLE_CARET_PROPERTY and AccessibleContext.ACCESSIBLE_SELECTION_PROPERTY). This keeps track of the dot position internally. When the caret moves, the internal position is updated after firing the event.
caretUpdate
in interface CaretListener
e
- the CaretEventpublic void insertUpdate(DocumentEvent e)
Handles document insert (fire appropriate property change event which is AccessibleContext.ACCESSIBLE_TEXT_PROPERTY). This tracks the changed offset via the event.
insertUpdate
in interface DocumentListener
e
- the DocumentEventpublic void removeUpdate(DocumentEvent e)
Handles document remove (fire appropriate property change event, which is AccessibleContext.ACCESSIBLE_TEXT_PROPERTY). This tracks the changed offset via the event.
removeUpdate
in interface DocumentListener
e
- the DocumentEventpublic void changedUpdate(DocumentEvent e)
Handles document remove (fire appropriate property change event, which is AccessibleContext.ACCESSIBLE_TEXT_PROPERTY). This tracks the changed offset via the event.
changedUpdate
in interface DocumentListener
e
- the DocumentEventpublic AccessibleStateSet getAccessibleStateSet()
Gets the state set of the JTextComponent. The AccessibleStateSet of an object is composed of a set of unique AccessibleState's. A change in the AccessibleStateSet of an object will cause a PropertyChangeEvent to be fired for the AccessibleContext.ACCESSIBLE_STATE_PROPERTY property.
getAccessibleStateSet
in class JComponent.AccessibleJComponent
AccessibleStateSet
, AccessibleState
, JComponent.AccessibleJComponent.addPropertyChangeListener(java.beans.PropertyChangeListener)
public AccessibleRole getAccessibleRole()
Gets the role of this object.
getAccessibleRole
in class JComponent.AccessibleJComponent
AccessibleRole
public AccessibleText getAccessibleText()
Get the AccessibleText associated with this object. In the implementation of the Java Accessibility API for this class, return this object, which is responsible for implementing the AccessibleText interface on behalf of itself.
getAccessibleText
in class AccessibleContext
AccessibleText
public int getIndexAtPoint(Point p)
Given a point in local coordinates, return the zero-based index of the character under that Point. If the point is invalid, this method returns -1.
getIndexAtPoint
in interface AccessibleText
p
- the Point in local coordinatespublic Rectangle getCharacterBounds(int i)
Determines the bounding box of the character at the given index into the string. The bounds are returned in local coordinates. If the index is invalid a null rectangle is returned. The screen coordinates returned are "unscrolled coordinates" if the JTextComponent is contained in a JScrollPane in which case the resulting rectangle should be composed with the parent coordinates. A good algorithm to use is:
Accessible a: AccessibleText at = a.getAccessibleText(); AccessibleComponent ac = a.getAccessibleComponent(); Rectangle r = at.getCharacterBounds(); Point p = ac.getLocation(); r.x += p.x; r.y += p.y;Note: the JTextComponent must have a valid size (e.g. have been added to a parent container whose ancestor container is a valid top-level window) for this method to be able to return a meaningful (non-null) value.
getCharacterBounds
in interface AccessibleText
i
- the index into the String ≥ 0public int getCharCount()
Returns the number of characters (valid indices)
getCharCount
in interface AccessibleText
public int getCaretPosition()
Returns the zero-based offset of the caret. Note: The character to the right of the caret will have the same index value as the offset (the caret is between two characters).
getCaretPosition
in interface AccessibleText
public AttributeSet getCharacterAttribute(int i)
Returns the AttributeSet for a given character (at a given index).
getCharacterAttribute
in interface AccessibleText
i
- the zero-based index into the textpublic int getSelectionStart()
Returns the start offset within the selected text. If there is no selection, but there is a caret, the start and end offsets will be the same. Return 0 if the text is empty, or the caret position if no selection.
getSelectionStart
in interface AccessibleText
public int getSelectionEnd()
Returns the end offset within the selected text. If there is no selection, but there is a caret, the start and end offsets will be the same. Return 0 if the text is empty, or the caret position if no selection.
getSelectionEnd
in interface AccessibleText
public String getSelectedText()
Returns the portion of the text that is selected.
getSelectedText
in interface AccessibleText
public String getAtIndex(int part, int index)
Returns the String at a given index. Whitespace between words is treated as a word.
getAtIndex
in interface AccessibleText
part
- the CHARACTER, WORD, or SENTENCE to retrieveindex
- an index within the textpublic String getAfterIndex(int part, int index)
Returns the String after a given index. Whitespace between words is treated as a word.
getAfterIndex
in interface AccessibleText
part
- the CHARACTER, WORD, or SENTENCE to retrieveindex
- an index within the textpublic String getBeforeIndex(int part, int index)
Returns the String before a given index. Whitespace between words is treated a word.
getBeforeIndex
in interface AccessibleText
part
- the CHARACTER, WORD, or SENTENCE to retrieveindex
- an index within the textpublic AccessibleEditableText getAccessibleEditableText()
Returns the AccessibleEditableText interface for this text component.
getAccessibleEditableText
in class AccessibleContext
AccessibleEditableText
public void setTextContents(String s)
Sets the text contents to the specified string.
setTextContents
in interface AccessibleEditableText
s
- the string to set the text contentspublic void insertTextAtIndex(int index, String s)
Inserts the specified string at the given index
insertTextAtIndex
in interface AccessibleEditableText
index
- the index in the text where the string will be inserteds
- the string to insert in the textpublic String getTextRange(int startIndex, int endIndex)
Returns the text string between two indices.
getTextRange
in interface AccessibleEditableText
getTextRange
in interface AccessibleExtendedText
startIndex
- the starting index in the textendIndex
- the ending index in the textpublic void delete(int startIndex, int endIndex)
Deletes the text between two indices
delete
in interface AccessibleEditableText
startIndex
- the starting index in the textendIndex
- the ending index in the textpublic void cut(int startIndex, int endIndex)
Cuts the text between two indices into the system clipboard.
cut
in interface AccessibleEditableText
startIndex
- the starting index in the textendIndex
- the ending index in the textpublic void paste(int startIndex)
Pastes the text from the system clipboard into the text starting at the specified index.
paste
in interface AccessibleEditableText
startIndex
- the starting index in the textpublic void replaceText(int startIndex, int endIndex, String s)
Replaces the text between two indices with the specified string.
replaceText
in interface AccessibleEditableText
startIndex
- the starting index in the textendIndex
- the ending index in the texts
- the string to replace the text between two indicespublic void selectText(int startIndex, int endIndex)
Selects the text between two indices.
selectText
in interface AccessibleEditableText
startIndex
- the starting index in the textendIndex
- the ending index in the textpublic void setAttributes(int startIndex, int endIndex, AttributeSet as)
Sets attributes for the text between two indices.
setAttributes
in interface AccessibleEditableText
startIndex
- the starting index in the textendIndex
- the ending index in the textas
- the attribute setAttributeSet
public AccessibleTextSequence getTextSequenceAt(int part, int index)
Returns the AccessibleTextSequence
at a given index
.
getTextSequenceAt
in interface AccessibleExtendedText
part
- the CHARACTER
, WORD
, SENTENCE
, LINE
or ATTRIBUTE_RUN
to retrieveindex
- an index within the textAccessibleTextSequence
specifying the text if part
and index
are valid. Otherwise, null
is returnedAccessibleText.CHARACTER
, AccessibleText.WORD
, AccessibleText.SENTENCE
, AccessibleExtendedText.LINE
, AccessibleExtendedText.ATTRIBUTE_RUN
public AccessibleTextSequence getTextSequenceAfter(int part, int index)
Returns the AccessibleTextSequence
after a given index
.
getTextSequenceAfter
in interface AccessibleExtendedText
part
- the CHARACTER
, WORD
, SENTENCE
, LINE
or ATTRIBUTE_RUN
to retrieveindex
- an index within the textAccessibleTextSequence
specifying the text if part
and index
are valid. Otherwise, null
is returnedAccessibleText.CHARACTER
, AccessibleText.WORD
, AccessibleText.SENTENCE
, AccessibleExtendedText.LINE
, AccessibleExtendedText.ATTRIBUTE_RUN
public AccessibleTextSequence getTextSequenceBefore(int part, int index)
Returns the AccessibleTextSequence
before a given index
.
getTextSequenceBefore
in interface AccessibleExtendedText
part
- the CHARACTER
, WORD
, SENTENCE
, LINE
or ATTRIBUTE_RUN
to retrieveindex
- an index within the textAccessibleTextSequence
specifying the text if part
and index
are valid. Otherwise, null
is returnedAccessibleText.CHARACTER
, AccessibleText.WORD
, AccessibleText.SENTENCE
, AccessibleExtendedText.LINE
, AccessibleExtendedText.ATTRIBUTE_RUN
public Rectangle getTextBounds(int startIndex, int endIndex)
Returns the Rectangle
enclosing the text between two indicies.
getTextBounds
in interface AccessibleExtendedText
startIndex
- the start index in the textendIndex
- the end index in the textnull
is returnedpublic AccessibleAction getAccessibleAction()
Description copied from class: AccessibleContext
Gets the AccessibleAction associated with this object that supports one or more actions.
getAccessibleAction
in class AccessibleContext
AccessibleAction
public int getAccessibleActionCount()
Returns the number of accessible actions available in this object If there are more than one, the first one is considered the "default" action of the object.
getAccessibleActionCount
in interface AccessibleAction
public String getAccessibleActionDescription(int i)
Returns a description of the specified action of the object.
getAccessibleActionDescription
in interface AccessibleAction
i
- zero-based index of the actionsgetAccessibleActionCount()
public boolean doAccessibleAction(int i)
Performs the specified Action on the object
doAccessibleAction
in interface AccessibleAction
i
- zero-based index of actionsgetAccessibleActionCount()
© 1993–2017, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.