java.lang.Object | ||
↳ | javax.swing.text.View | |
↳ | javax.swing.text.GlyphView |
![]() |
![]() |
A GlyphView is a styled chunk of text that represents a view mapped over an element in the text model. This view is generally responsible for displaying text glyphs using character level attributes in some way. An implementation of the GlyphPainter class is used to do the actual rendering and model/view translations. This separates rendering from layout and management of the association with the model.
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.
Nested Classes | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
GlyphView.GlyphPainter | A class to perform rendering of the glyphs. |
[Expand]
Inherited Constants | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() | |||||||||||
![]() |
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Constructs a new view wrapped on an element.
|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Breaks this view on the given axis at the given length.
| |||||||||||
Gives notification from the document that attributes were changed
in a location that this view is responsible for.
| |||||||||||
Creates a view that represents a portion of the element.
| |||||||||||
Determines the desired alignment for this view along an
axis.
| |||||||||||
Fetch the background color to use to render the
glyphs.
| |||||||||||
Determines how attractive a break opportunity in
this view is.
| |||||||||||
Fetches the portion of the model that this view is responsible for.
| |||||||||||
Fetch the font that the glyphs should be based
upon.
| |||||||||||
Fetch the foreground color to use to render the
glyphs.
| |||||||||||
Fetch the currently installed glyph painter.
| |||||||||||
Provides a way to determine the next visually represented model
location that one might place a caret.
| |||||||||||
Determines the span along the same axis as tab
expansion for a portion of the view.
| |||||||||||
Determines the preferred span for this view along an
axis.
| |||||||||||
Fetches the portion of the model that this view is responsible for.
| |||||||||||
Fetch the TabExpander to use if tabs are present in this view.
| |||||||||||
Determines the desired span when using the given
tab expansion implementation.
| |||||||||||
Fetch a reference to the text that occupies
the given range.
| |||||||||||
Gives notification that something was inserted into
the document in a location that this view is responsible for.
| |||||||||||
Determine if the glyphs should have a strikethrough
line.
| |||||||||||
Determine if the glyphs should be rendered as superscript.
| |||||||||||
Determine if the glyphs should be rendered as subscript.
| |||||||||||
Determine if the glyphs should be underlined.
| |||||||||||
Provides a mapping from the document model coordinate space
to the coordinate space of the view mapped to it.
| |||||||||||
Renders a portion of a text style run.
| |||||||||||
Gives notification that something was removed from the document
in a location that this view is responsible for.
| |||||||||||
Sets the painter to use for rendering glyphs.
| |||||||||||
Provides a mapping from the view coordinate space to the logical
coordinate space of the model.
|
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Check to see that a glyph painter exists.
| |||||||||||
Creates a shallow copy.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() | |||||||||||
![]() | |||||||||||
![]() |
Constructs a new view wrapped on an element.
elem | the element |
---|
Breaks this view on the given axis at the given length. This is implemented to attempt to break on a whitespace location, and returns a fragment with the whitespace at the end. If a whitespace location can't be found, the nearest character is used.
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. |
Gives notification from the document that attributes were changed in a location that this view is responsible for. This is implemented to call preferenceChanged along both the horizontal and vertical axis.
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 |
Creates a view that represents a portion of the element. This is potentially useful during formatting operations for taking measurements of fragments of the view. If the view doesn't support fragmenting (the default), it should return itself.
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.
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. |
Determines the desired alignment for this view along an axis. For the label, the alignment is along the font baseline for the y axis, and the superclasses alignment along the x axis.
axis | may be either View.X_AXIS or View.Y_AXIS |
---|
Fetch the background color to use to render the
glyphs. If there is no background color, null should
be returned. This is implemented to call
StyledDocument.getBackground
if the associated
document is a styled document, otherwise it returns null.
Determines how attractive a break opportunity in
this view is. This can be used for determining which
view is the most attractive to call 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.
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. |
Fetches the portion of the model that this view is responsible for.
Fetch the font that the glyphs should be based
upon. This is implemented to call
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.
Fetch the foreground color to use to render the
glyphs. If there is no foreground color, null should
be returned. This is implemented to call
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.
Fetch the currently installed glyph painter. If a painter has not yet been installed, and a default was not yet needed, null is returned.
Provides a way to determine the next visually represented model location that one might place a caret. Some views may not be visible, they might not be in the same order found in the model, or they just might not allow access to some of the locations in the model.
pos | the position to convert >= 0 |
---|---|
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. |
BadLocationException | |
IllegalArgumentException | for an invalid direction |
BadLocationException |
Determines the span along the same axis as tab expansion for a portion of the view. This is intended for use by the TabExpander for cases where the tab expansion involves aligning the portion of text that doesn't have whitespace relative to the tab stop. There is therefore an assumption that the range given does not contain tabs.
This method can be called while servicing the getTabbedSpan or getPreferredSize. It has to arrange for its own text buffer to make the measurements.
p0 | the starting document offset >= 0 |
---|---|
p1 | the ending document offset >= p0 |
Determines the preferred span for this view along an axis.
axis | may be either View.X_AXIS or View.Y_AXIS |
---|
Fetches the portion of the model that this view is responsible for.
Determines the desired span when using the given tab expansion implementation.
x | the position the view would be located at for the purpose of tab expansion >= 0. |
---|---|
e | how to expand the tabs when encountered. |
Fetch a reference to the text that occupies the given range. This is normally used by the GlyphPainter to determine what characters it should render glyphs for.
p0 | the starting document offset >= 0 |
---|---|
p1 | the ending document offset >= p0 |
Segment
containing the text
Gives notification that something was inserted into the document in a location that this view is responsible for. This is implemented to call preferenceChanged along the axis the glyphs are rendered.
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 |
Determine if the glyphs should have a strikethrough line. If true, a line should be drawn through the center of the glyphs.
Determine if the glyphs should be rendered as superscript.
Determine if the glyphs should be rendered as subscript.
Determine if the glyphs should be underlined. If true, an underline should be drawn through the baseline.
Provides a mapping from the document model coordinate space to the coordinate space of the view mapped to it.
pos | the position to convert >= 0 |
---|---|
a | the allocated region to render into |
b | either Position.Bias.Forward
or Position.Bias.Backward |
BadLocationException | if the given position does not represent a valid location in the associated document |
---|
Renders a portion of a text style run.
g | the rendering surface to use |
---|---|
a | the allocated region to render into |
Gives notification that something was removed from the document in a location that this view is responsible for. This is implemented to call preferenceChanged along the axis the glyphs are rendered.
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 |
Sets the painter to use for rendering glyphs.
Provides a mapping from the view coordinate space to the logical coordinate space of the model.
x | the X coordinate >= 0 |
---|---|
y | the Y coordinate >= 0 |
a | the allocated region to render into |
biasReturn | either Position.Bias.Forward
or Position.Bias.Backward is returned as the
zero-th element of this array |
Check to see that a glyph painter exists. If a painter doesn't exist, a default glyph painter will be installed.
Creates a shallow copy. This is used by the createFragment and breakView methods.