Class GlyphView
- All Implemented Interfaces:
-
Cloneable
,SwingConstants
,TabableView
- Direct Known Subclasses:
LabelView
public class GlyphView extends View implements TabableView, Cloneable
The view supports breaking for the purpose of formatting. The fragments produced by breaking share the view that has primary responsibility for the element (i.e. they are nested classes and carry only a small amount of state of their own) so they can share its resources.
Since this view represents text that may have tabs embedded in it, it implements the TabableView
interface. Tabs will only be expanded if this view is embedded in a container that does tab expansion. ParagraphView is an example of a container that does tab expansion.
- Since:
- 1.3
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
static class |
GlyphView.GlyphPainter |
A class to perform rendering of the glyphs. |
Field Summary
Fields declared in class javax.swing.text.View
BadBreakWeight, ExcellentBreakWeight, ForcedBreakWeight, GoodBreakWeight, X_AXIS, Y_AXIS
Fields declared in interface javax.swing.SwingConstants
BOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NEXT, NORTH, NORTH_EAST, NORTH_WEST, PREVIOUS, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST
Constructor Summary
Constructor | Description |
---|---|
GlyphView |
Constructs a new view wrapped on an element. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
View |
breakView |
Breaks this view on the given axis at the given length. |
void |
changedUpdate |
Gives notification from the document that attributes were changed in a location that this view is responsible for. |
protected void |
checkPainter() |
Check to see that a glyph painter exists. |
protected final Object |
clone() |
Creates a shallow copy. |
View |
createFragment |
Creates a view that represents a portion of the element. |
float |
getAlignment |
Determines the desired alignment for this view along an axis. |
Color |
getBackground() |
Fetch the background color to use to render the glyphs. |
int |
getBreakWeight |
Determines how attractive a break opportunity in this view is. |
int |
getEndOffset() |
Fetches the portion of the model that this view is responsible for. |
Font |
getFont() |
Fetch the font that the glyphs should be based upon. |
Color |
getForeground() |
Fetch the foreground color to use to render the glyphs. |
GlyphView.GlyphPainter |
getGlyphPainter() |
Fetch the currently installed glyph painter. |
float |
getMinimumSpan |
Determines the minimum span for this view along an axis. |
int |
getNextVisualPositionFrom |
Provides a way to determine the next visually represented model location that one might place a caret. |
float |
getPartialSpan |
Determines the span along the same axis as tab expansion for a portion of the view. |
float |
getPreferredSpan |
Determines the preferred span for this view along an axis. |
int |
getStartOffset() |
Fetches the portion of the model that this view is responsible for. |
float |
getTabbedSpan |
Determines the desired span when using the given tab expansion implementation. |
TabExpander |
getTabExpander() |
Fetch the TabExpander to use if tabs are present in this view. |
Segment |
getText |
Fetch a reference to the text that occupies the given range. |
void |
insertUpdate |
Gives notification that something was inserted into the document in a location that this view is responsible for. |
boolean |
isStrikeThrough() |
Determine if the glyphs should have a strikethrough line. |
boolean |
isSubscript() |
Determine if the glyphs should be rendered as superscript. |
boolean |
isSuperscript() |
Determine if the glyphs should be rendered as subscript. |
boolean |
isUnderline() |
Determine if the glyphs should be underlined. |
Shape |
modelToView |
Provides a mapping from the document model coordinate space to the coordinate space of the view mapped to it. |
void |
paint |
Renders a portion of a text style run. |
void |
removeUpdate |
Gives notification that something was removed from the document in a location that this view is responsible for. |
void |
setGlyphPainter |
Sets the painter to use for rendering glyphs. |
int |
viewToModel |
Provides a mapping from the view coordinate space to the logical coordinate space of the model. |
Methods declared in class javax.swing.text.View
append, forwardUpdate, forwardUpdateToView, getAttributes, getChildAllocation, getContainer, getDocument, getElement, getGraphics, getMaximumSpan, getParent, getResizeWeight, getToolTipText, getView, getViewCount, getViewFactory, getViewIndex, getViewIndex, insert, isVisible, modelToView, modelToView, preferenceChanged, remove, removeAll, replace, setParent, setSize, updateChildren, updateLayout, viewToModel
Constructor Details
GlyphView
public GlyphView(Element elem)
- Parameters:
-
elem
- the element
Method Details
clone
protected final Object clone()
getGlyphPainter
public GlyphView.GlyphPainter getGlyphPainter()
- Returns:
- the currently installed glyph painter
setGlyphPainter
public void setGlyphPainter(GlyphView.GlyphPainter p)
- Parameters:
-
p
- the painter to use for rendering glyphs
getText
public Segment getText(int p0, int p1)
- Parameters:
-
p0
- the starting document offset >= 0 -
p1
- the ending document offset >= p0 - Returns:
- the
Segment
containing the text
getBackground
public Color getBackground()
StyledDocument.getBackground
if the associated document is a styled document, otherwise it returns null.- Returns:
- the background color to use to render the glyphs
getForeground
public Color getForeground()
StyledDocument.getBackground
if the associated document is a StyledDocument. If the associated document is not a StyledDocument, the associated components foreground color is used. If there is no associated component, null is returned.- Returns:
- the foreground color to use to render the glyphs
getFont
public Font getFont()
StyledDocument.getFont
if the associated document is a StyledDocument. If the associated document is not a StyledDocument, the associated components font is used. If there is no associated component, null is returned.- Returns:
- the font that the glyphs should be based upon
isUnderline
public boolean isUnderline()
- Returns:
- if the glyphs should be underlined
isStrikeThrough
public boolean isStrikeThrough()
- Returns:
- if the glyphs should have a strikethrough line
isSubscript
public boolean isSubscript()
- Returns:
- if the glyphs should be rendered as superscript
isSuperscript
public boolean isSuperscript()
- Returns:
- if the glyphs should be rendered as subscript
getTabExpander
public TabExpander getTabExpander()
- Returns:
- the TabExpander to use if tabs are present in this view
checkPainter
protected void checkPainter()
getTabbedSpan
public float getTabbedSpan(float x, TabExpander e)
- Specified by:
-
getTabbedSpan
in interfaceTabableView
- Parameters:
-
x
- the position the view would be located at for the purpose of tab expansion >= 0. -
e
- how to expand the tabs when encountered. - Returns:
- the desired span >= 0
- See Also:
getPartialSpan
public float getPartialSpan(int p0, int p1)
This method can be called while servicing the getTabbedSpan or getPreferredSize. It has to arrange for its own text buffer to make the measurements.
- Specified by:
-
getPartialSpan
in interfaceTabableView
- Parameters:
-
p0
- the starting document offset >= 0 -
p1
- the ending document offset >= p0 - Returns:
- the span >= 0
getStartOffset
public int getStartOffset()
- Overrides:
-
getStartOffset
in classView
- Returns:
- the starting offset into the model
- See Also:
getEndOffset
public int getEndOffset()
- Overrides:
-
getEndOffset
in classView
- Returns:
- the ending offset into the model
- See Also:
paint
public void paint(Graphics g, Shape a)
getMinimumSpan
public float getMinimumSpan(int axis)
This implementation returns the longest non-breakable area within the view as a minimum span for View.X_AXIS
.
- Overrides:
-
getMinimumSpan
in classView
- Parameters:
-
axis
- may be eitherView.X_AXIS
orView.Y_AXIS
- Returns:
- the minimum span the view can be rendered into
- Throws:
-
IllegalArgumentException
- if theaxis
parameter is invalid - See Also:
getPreferredSpan
public float getPreferredSpan(int axis)
- Specified by:
-
getPreferredSpan
in classView
- Parameters:
-
axis
- may be either View.X_AXIS or View.Y_AXIS - Returns:
- the span the view would like to be rendered into >= 0. Typically the view is told to render into the span that is returned, although there is no guarantee. The parent may choose to resize or break the view.
getAlignment
public float getAlignment(int axis)
- Overrides:
-
getAlignment
in classView
- Parameters:
-
axis
- may be either View.X_AXIS or View.Y_AXIS - Returns:
- the desired alignment. This should be a value between 0.0 and 1.0 inclusive, where 0 indicates alignment at the origin and 1.0 indicates alignment to the full span away from the origin. An alignment of 0.5 would be the center of the view.
modelToView
public Shape modelToView(int pos, Shape a, Position.Bias b) throws BadLocationException
- Specified by:
-
modelToView
in classView
- Parameters:
-
pos
- the position to convert >= 0 -
a
- the allocated region to render into -
b
- eitherPosition.Bias.Forward
orPosition.Bias.Backward
- Returns:
- the bounding box of the given position
- Throws:
-
BadLocationException
- if the given position does not represent a valid location in the associated document - See Also:
viewToModel
public int viewToModel(float x, float y, Shape a, Position.Bias[] biasReturn)
- Specified by:
-
viewToModel
in classView
- Parameters:
-
x
- the X coordinate >= 0 -
y
- the Y coordinate >= 0 -
a
- the allocated region to render into -
biasReturn
- eitherPosition.Bias.Forward
orPosition.Bias.Backward
is returned as the zero-th element of this array - Returns:
- the location within the model that best represents the given point of view >= 0
- See Also:
getBreakWeight
public int getBreakWeight(int axis, float pos, float len)
breakView
on in the process of formatting. The higher the weight, the more attractive the break. A value equal to or lower than View.BadBreakWeight
should not be considered for a break. A value greater than or equal to View.ForcedBreakWeight
should be broken. This is implemented to forward to the superclass for the Y_AXIS. Along the X_AXIS the following values may be returned.
- View.ExcellentBreakWeight
- if there is whitespace proceeding the desired break location.
- View.BadBreakWeight
- if the desired break location results in a break location of the starting offset.
- View.GoodBreakWeight
- if the other conditions don't occur.
- Overrides:
-
getBreakWeight
in classView
- Parameters:
-
axis
- may be either View.X_AXIS or View.Y_AXIS -
pos
- the potential location of the start of the broken view >= 0. This may be useful for calculating tab positions. -
len
- specifies the relative length from pos where a potential break is desired >= 0. - Returns:
- the weight, which should be a value between View.ForcedBreakWeight and View.BadBreakWeight.
- See Also:
breakView
public View breakView(int axis, int p0, float pos, float len)
- Overrides:
-
breakView
in classView
- Parameters:
-
axis
- may be either View.X_AXIS or View.Y_AXIS -
p0
- the location in the model where the fragment should start it's representation >= 0. -
pos
- the position along the axis that the broken view would occupy >= 0. This may be useful for things like tab calculations. -
len
- specifies the distance along the axis where a potential break is desired >= 0. - Returns:
- the fragment of the view that represents the given span, if the view can be broken. If the view doesn't support breaking behavior, the view itself is returned.
- See Also:
createFragment
public View createFragment(int p0, int p1)
This view does support fragmenting. It is implemented to return a nested class that shares state in this view representing only a portion of the view.
- Overrides:
-
createFragment
in classView
- Parameters:
-
p0
- the starting offset >= 0. This should be a value greater or equal to the element starting offset and less than the element ending offset. -
p1
- the ending offset > p0. This should be a value less than or equal to the elements end offset and greater than the elements starting offset. - Returns:
- the view fragment, or itself if the view doesn't support breaking into fragments
- See Also:
getNextVisualPositionFrom
public int getNextVisualPositionFrom(int pos, Position.Bias b, Shape a, int direction, Position.Bias[] biasRet) throws BadLocationException
BadLocationException
will be thrown.- Overrides:
-
getNextVisualPositionFrom
in classView
- Parameters:
-
pos
- the position to convert -
a
- the allocated region to render into -
direction
- the direction from the current position that can be thought of as the arrow keys typically found on a keyboard. This may be SwingConstants.WEST, SwingConstants.EAST, SwingConstants.NORTH, or SwingConstants.SOUTH. -
b
- the bias -
biasRet
- the returned bias - Returns:
- the location within the model that best represents the next location visual position.
- Throws:
-
BadLocationException
- the given position is not a valid position within the document -
IllegalArgumentException
- for an invalid direction
insertUpdate
public void insertUpdate(DocumentEvent e, Shape a, ViewFactory f)
- Overrides:
-
insertUpdate
in classView
- Parameters:
-
e
- the change information from the associated document -
a
- the current allocation of the view -
f
- the factory to use to rebuild if the view has children - See Also:
removeUpdate
public void removeUpdate(DocumentEvent e, Shape a, ViewFactory f)
- Overrides:
-
removeUpdate
in classView
- Parameters:
-
e
- the change information from the associated document -
a
- the current allocation of the view -
f
- the factory to use to rebuild if the view has children - See Also:
changedUpdate
public void changedUpdate(DocumentEvent e, Shape a, ViewFactory f)
- Overrides:
-
changedUpdate
in classView
- Parameters:
-
e
- the change information from the associated document -
a
- the current allocation of the view -
f
- the factory to use to rebuild if the view has children - See Also:
© 1993, 2021, 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.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/javax/swing/text/GlyphView.html