Package docking.widgets.fieldpanel.field
Class AbstractTextFieldElement
java.lang.Object
docking.widgets.fieldpanel.field.AbstractTextFieldElement
- All Implemented Interfaces:
FieldElement
- Direct Known Subclasses:
AnnotatedTextFieldElement
,ClangFieldElement
,TextFieldElement
An object that wraps a string and provides data that describes how to render
that string.
This class was created as a place to house attributes of rendering that are not described by Java's Font object, like underlining.
-
Field Summary
Modifier and TypeFieldDescriptionprotected AttributedString
the attributed string displayed by this field elementprotected int
the offset within the field's row where this element beginsprotected int
the row within the field where this element begins -
Constructor Summary
ModifierConstructorDescriptionprotected
AbstractTextFieldElement
(AttributedString attributedString, int row, int column) -
Method Summary
Modifier and TypeMethodDescriptionchar
charAt
(int index) Returns the character at the given index.int
getCharacterIndexForDataLocation
(int dataRow, int dataColumn) Returns the character index appropriate for the given data locationgetColor
(int charIndex) Returns the color for a given character within this element, since different colors may be applied to different characters.getDataLocationForCharacterIndex
(int characterIndex) Translates the given character index to a data location related to the data model, as determined by the FieldFactory.getFieldElement
(int characterOffset) Returns the inner-most FieldElement inside this field element at the given locationint
Returns the amount of height above the baseline of this element.int
Returns the amount of height below the baseline of this element.int
getMaxCharactersForWidth
(int width) As the name implies, this method returns the maximum number of characters from this field element that will fit within the given width.int
Returns the string width of this element.getText()
Returns the text contained by this field element.int
length()
Returns the length of the text within this element.void
paint
(JComponent c, Graphics g, int x, int y) Paints the text contained in this field element at the given x,y screen coordinate using the given Graphics object.substring
(int start) Returns a new FieldElement containing just the characters beginning at the given index.toString()
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface docking.widgets.fieldpanel.field.FieldElement
replaceAll, substring
-
Field Details
-
attributedString
the attributed string displayed by this field element -
row
protected int rowthe row within the field where this element begins -
column
protected int columnthe offset within the field's row where this element begins
-
-
Constructor Details
-
AbstractTextFieldElement
-
-
Method Details
-
getText
Description copied from interface:FieldElement
Returns the text contained by this field element.- Specified by:
getText
in interfaceFieldElement
- Returns:
- the text contained by this field element.
-
charAt
public char charAt(int index) Description copied from interface:FieldElement
Returns the character at the given index.- Specified by:
charAt
in interfaceFieldElement
- Parameters:
index
- the index of the character in this field element.- Returns:
- the character at the given index.
-
length
public int length()Description copied from interface:FieldElement
Returns the length of the text within this element. This is a convenience method for callinggetText().length()
.- Specified by:
length
in interfaceFieldElement
- Returns:
- the length of the text within this element.
-
getStringWidth
public int getStringWidth()Description copied from interface:FieldElement
Returns the string width of this element. The width is based upon the associated FontMetrics object within this element.- Specified by:
getStringWidth
in interfaceFieldElement
- Returns:
- the string width of this element.
-
getHeightAbove
public int getHeightAbove()Description copied from interface:FieldElement
Returns the amount of height above the baseline of this element.- Specified by:
getHeightAbove
in interfaceFieldElement
- Returns:
- the amount of height above the baseline of this element.
-
getHeightBelow
public int getHeightBelow()Description copied from interface:FieldElement
Returns the amount of height below the baseline of this element.- Specified by:
getHeightBelow
in interfaceFieldElement
- Returns:
- the amount of height below the baseline of this element.
-
getMaxCharactersForWidth
public int getMaxCharactersForWidth(int width) Description copied from interface:FieldElement
As the name implies, this method returns the maximum number of characters from this field element that will fit within the given width.- Specified by:
getMaxCharactersForWidth
in interfaceFieldElement
- Parameters:
width
- The width constraint- Returns:
- the maximum number of characters from this field element that will fit within the given width.
-
getColor
Description copied from interface:FieldElement
Returns the color for a given character within this element, since different colors may be applied to different characters.- Specified by:
getColor
in interfaceFieldElement
- Parameters:
charIndex
- The character index- Returns:
- the color for a given character within this element.
-
getFieldElement
Description copied from interface:FieldElement
Returns the inner-most FieldElement inside this field element at the given location- Specified by:
getFieldElement
in interfaceFieldElement
- Parameters:
characterOffset
- the character offset.- Returns:
- the inner-most FieldElement inside this field element at the given location
-
substring
Description copied from interface:FieldElement
Returns a new FieldElement containing just the characters beginning at the given index.- Specified by:
substring
in interfaceFieldElement
- Parameters:
start
- The starting index (inclusive) from which to substring this element.- Returns:
- a new FieldElement containing just the characters beginning at the given index.
-
toString
-
getDataLocationForCharacterIndex
Description copied from interface:FieldElement
Translates the given character index to a data location related to the data model, as determined by the FieldFactory.- Specified by:
getDataLocationForCharacterIndex
in interfaceFieldElement
- Parameters:
characterIndex
- The character index to translate.- Returns:
- The data location in the model coordinates.
-
getCharacterIndexForDataLocation
public int getCharacterIndexForDataLocation(int dataRow, int dataColumn) Description copied from interface:FieldElement
Returns the character index appropriate for the given data location- Specified by:
getCharacterIndexForDataLocation
in interfaceFieldElement
- Parameters:
dataRow
- the row in the data model as determined by the creating field factory.dataColumn
- the column in the data model as determined by the creating field factory.- Returns:
- the character index appropriate for the given data location; -1 if this field does not contain the given location
-
paint
Description copied from interface:FieldElement
Paints the text contained in this field element at the given x,y screen coordinate using the given Graphics object.- Specified by:
paint
in interfaceFieldElement
- Parameters:
c
- the component being painted.g
- the Graphics object used to paint the field text.x
- the horizontal screen position to painty
- the vertical screen position to paint.
-