| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjavax.swing.text.View
javax.swing.text.GlyphView
public class 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 Class Summary | |
|---|---|
| static class | GlyphView.GlyphPainterA class to perform rendering of the glyphs. | 
| Field Summary | 
|---|
| Fields inherited from class javax.swing.text.View | 
|---|
| BadBreakWeight, ExcellentBreakWeight, ForcedBreakWeight, GoodBreakWeight, X_AXIS, Y_AXIS | 
| Fields inherited from 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 | |
|---|---|
| GlyphView(Element elem)Constructs a new view wrapped on an element. | |
| Method Summary | |
|---|---|
|  View | breakView(int axis,
          int p0,
          float pos,
          float len)Breaks this view on the given axis at the given length. | 
|  void | changedUpdate(DocumentEvent e,
              Shape a,
              ViewFactory f)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  Object | clone()Creates a shallow copy. | 
|  View | createFragment(int p0,
               int p1)Creates a view that represents a portion of the element. | 
|  float | getAlignment(int axis)Determines the desired alignment for this view along an axis. | 
|  Color | getBackground()Fetch the background color to use to render the glyphs. | 
|  int | getBreakWeight(int axis,
               float pos,
               float len)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. | 
|  int | getNextVisualPositionFrom(int pos,
                          Position.Bias b,
                          Shape a,
                          int direction,
                          Position.Bias[] biasRet)Provides a way to determine the next visually represented model location that one might place a caret. | 
|  float | getPartialSpan(int p0,
               int p1)Determines the span along the same axis as tab expansion for a portion of the view. | 
|  float | getPreferredSpan(int axis)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(float x,
              TabExpander e)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(int p0,
        int p1)Fetch a reference to the text that occupies the given range. | 
|  void | insertUpdate(DocumentEvent e,
             Shape a,
             ViewFactory f)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(int pos,
            Shape a,
            Position.Bias b)Provides a mapping from the document model coordinate space to the coordinate space of the view mapped to it. | 
|  void | paint(Graphics g,
      Shape a)Renders a portion of a text style run. | 
|  void | removeUpdate(DocumentEvent e,
             Shape a,
             ViewFactory f)Gives notification that something was removed from the document in a location that this view is responsible for. | 
|  void | setGlyphPainter(GlyphView.GlyphPainter p)Sets the painter to use for rendering glyphs. | 
|  int | viewToModel(float x,
            float y,
            Shape a,
            Position.Bias[] biasReturn)Provides a mapping from the view coordinate space to the logical coordinate space of the model. | 
| Methods inherited from class javax.swing.text.View | 
|---|
| append, forwardUpdate, forwardUpdateToView, getAttributes, getChildAllocation, getContainer, getDocument, getElement, getGraphics, getMaximumSpan, getMinimumSpan, getParent, getResizeWeight, getToolTipText, getView, getViewCount, getViewFactory, getViewIndex, getViewIndex, insert, isVisible, modelToView, modelToView, preferenceChanged, remove, removeAll, replace, setParent, setSize, updateChildren, updateLayout, viewToModel | 
| Methods inherited from class java.lang.Object | 
|---|
| equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public GlyphView(Element elem)
elem - the element| Method Detail | 
|---|
protected final Object clone()
clone in class ObjectCloneablepublic GlyphView.GlyphPainter getGlyphPainter()
public void setGlyphPainter(GlyphView.GlyphPainter p)
public Segment getText(int p0,
                       int p1)
p0 - the starting document offset >= 0p1 - the ending document offset >= p0
Segment containing the textpublic Color getBackground()
StyledDocument.getBackground if the associated
 document is a styled document, otherwise it returns null.
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.
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.
public boolean isUnderline()
public boolean isStrikeThrough()
public boolean isSubscript()
public boolean isSuperscript()
public TabExpander getTabExpander()
protected void checkPainter()
public float getTabbedSpan(float x,
                           TabExpander e)
getTabbedSpan in interface TabableViewx - the position the view would be located
  at for the purpose of tab expansion >= 0.e - how to expand the tabs when encountered.
TabableView.getTabbedSpan(float, javax.swing.text.TabExpander)
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.
getPartialSpan in interface TabableViewp0 - the starting document offset >= 0p1 - the ending document offset >= p0
public int getStartOffset()
getStartOffset in class ViewView.getStartOffset()public int getEndOffset()
getEndOffset in class ViewView.getEndOffset()
public void paint(Graphics g,
                  Shape a)
paint in class Viewg - the rendering surface to usea - the allocated region to render intopublic float getPreferredSpan(int axis)
getPreferredSpan in class Viewaxis - may be either View.X_AXIS or View.Y_AXIS
View.getPreferredSpan(int)public float getAlignment(int axis)
getAlignment in class Viewaxis - may be either View.X_AXIS or View.Y_AXIS
public Shape modelToView(int pos,
                         Shape a,
                         Position.Bias b)
                  throws BadLocationException
modelToView in class Viewpos - the position to convert >= 0a - the allocated region to render intob - either Position.Bias.Forward
                or Position.Bias.Backward
BadLocationException - if the given position does not represent a
   valid location in the associated documentView.modelToView(int, java.awt.Shape, javax.swing.text.Position.Bias)
public int viewToModel(float x,
                       float y,
                       Shape a,
                       Position.Bias[] biasReturn)
viewToModel in class Viewx - the X coordinate >= 0y - the Y coordinate >= 0a - the allocated region to render intobiasReturn - either Position.Bias.Forward
  or Position.Bias.Backward is returned as the
  zero-th element of this array
View.viewToModel(float, float, java.awt.Shape, javax.swing.text.Position.Bias[])
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.
getBreakWeight in class Viewaxis - may be either View.X_AXIS or View.Y_AXISpos - 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.
LabelView, 
ParagraphView, 
View.BadBreakWeight, 
View.GoodBreakWeight, 
View.ExcellentBreakWeight, 
View.ForcedBreakWeight
public View breakView(int axis,
                      int p0,
                      float pos,
                      float len)
breakView in class Viewaxis - may be either View.X_AXIS or View.Y_AXISp0 - 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.
View.breakView(int, int, float, float)
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.
createFragment in class Viewp0 - 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.
LabelView
public int getNextVisualPositionFrom(int pos,
                                     Position.Bias b,
                                     Shape a,
                                     int direction,
                                     Position.Bias[] biasRet)
                              throws BadLocationException
getNextVisualPositionFrom in class Viewpos - the position to convert >= 0a - the allocated region to render intodirection - 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
public void insertUpdate(DocumentEvent e,
                         Shape a,
                         ViewFactory f)
insertUpdate in class Viewe - the change information from the associated documenta - the current allocation of the viewf - the factory to use to rebuild if the view has childrenView.insertUpdate(javax.swing.event.DocumentEvent, java.awt.Shape, javax.swing.text.ViewFactory)
public void removeUpdate(DocumentEvent e,
                         Shape a,
                         ViewFactory f)
removeUpdate in class Viewe - the change information from the associated documenta - the current allocation of the viewf - the factory to use to rebuild if the view has childrenView.removeUpdate(javax.swing.event.DocumentEvent, java.awt.Shape, javax.swing.text.ViewFactory)
public void changedUpdate(DocumentEvent e,
                          Shape a,
                          ViewFactory f)
changedUpdate in class Viewe - the change information from the associated documenta - the current allocation of the viewf - the factory to use to rebuild if the view has childrenView.changedUpdate(javax.swing.event.DocumentEvent, java.awt.Shape, javax.swing.text.ViewFactory)| 
 | Java™ Platform Standard Ed. 6 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
Copyright 2006 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.