Class AsyncBoxView
- All Implemented Interfaces:
SwingConstants
public class AsyncBoxView extends View
While the child view is being accessed a read lock is acquired on the associated document so that the model is stable while being accessed.
- Since:
- 1.3
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
class |
AsyncBoxView.ChildLocator |
A class to manage the effective position of the child views in a localized area while changes are being made around the localized area. |
class |
AsyncBoxView.ChildState |
A record representing the layout state of a child view. |
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected AsyncBoxView.ChildLocator |
locator |
Object that manages the offsets of the children. |
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 |
---|---|
AsyncBoxView |
Construct a box view that does asynchronous layout. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
protected AsyncBoxView.ChildState |
createChildState |
New ChildState records are created through this method to allow subclasses the extend the ChildState records to do/hold more. |
protected void |
flushRequirementChanges() |
Publish the changes in preferences upward to the parent view. |
float |
getBottomInset() |
Get the bottom part of the margin around the view. |
Shape |
getChildAllocation |
Fetches the allocation for the given child view. |
protected AsyncBoxView.ChildState |
getChildState |
Fetch the object representing the layout state of of the child at the given index. |
protected boolean |
getEstimatedMajorSpan() |
Is the major span currently estimated? |
protected float |
getInsetSpan |
Fetch the span along an axis that is taken up by the insets. |
protected LayoutQueue |
getLayoutQueue() |
Fetch the queue to use for layout. |
float |
getLeftInset() |
Get the left part of the margin around the view. |
int |
getMajorAxis() |
Fetch the major axis (the axis the children are tiled along). |
float |
getMaximumSpan |
Determines the maximum span for this view along an axis. |
float |
getMinimumSpan |
Determines the minimum span for this view along an axis. |
int |
getMinorAxis() |
Fetch the minor axis (the axis orthogonal to the tiled axis). |
int |
getNextVisualPositionFrom |
Provides a way to determine the next visually represented model location that one might place a caret. |
float |
getPreferredSpan |
Determines the preferred span for this view along an axis. |
float |
getRightInset() |
Get the right part of the margin around the view. |
float |
getTopInset() |
Get the top part of the margin around the view. |
View |
getView |
Gets the nth child view. |
int |
getViewCount() |
Returns the number of views in this view. |
int |
getViewIndex |
Returns the child view index representing the given position in the model. |
protected int |
getViewIndexAtPosition |
Fetches the child view index representing the given position in the model. |
protected void |
loadChildren |
Loads all of the children to initialize the view. |
protected void |
majorRequirementChange |
Requirements changed along the major axis. |
protected void |
minorRequirementChange |
Requirements changed along the minor axis. |
Shape |
modelToView |
Provides a mapping from the document model coordinate space to the coordinate space of the view mapped to it. |
void |
paint |
Render the view using the given allocation and rendering surface. |
void |
preferenceChanged |
Child views can call this on the parent to indicate that the preference has changed and should be reconsidered for layout. |
void |
replace |
Calls the superclass to update the child views, and updates the status records for the children. |
void |
setBottomInset |
Set the bottom part of the margin around the view. |
protected void |
setEstimatedMajorSpan |
Set the estimatedMajorSpan property that determines if the major span should be treated as being estimated. |
void |
setLeftInset |
Set the left part of the margin around the view. |
void |
setParent |
Sets the parent of the view. |
void |
setRightInset |
Set the right part of the margin around the view. |
void |
setSize |
Sets the size of the view. |
void |
setTopInset |
Set the top part of the margin around the view. |
protected void |
updateLayout |
Update the layout in response to receiving notification of change from the model. |
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, breakView, changedUpdate, createFragment, forwardUpdate, forwardUpdateToView, getAlignment, getAttributes, getBreakWeight, getContainer, getDocument, getElement, getEndOffset, getGraphics, getParent, getResizeWeight, getStartOffset, getToolTipText, getViewFactory, getViewIndex, insert, insertUpdate, isVisible, modelToView, modelToView, remove, removeAll, removeUpdate, updateChildren, viewToModel
Field Details
locator
protected AsyncBoxView.ChildLocator locator
Constructor Details
AsyncBoxView
public AsyncBoxView(Element elem, int axis)
- Parameters:
-
elem
- the element of the model to represent -
axis
- the axis to tile along. This can be either X_AXIS or Y_AXIS.
Method Details
getMajorAxis
public int getMajorAxis()
- Returns:
- the major axis
getMinorAxis
public int getMinorAxis()
- Returns:
- the minor axis
getTopInset
public float getTopInset()
- Returns:
- the top part of the margin around the view
setTopInset
public void setTopInset(float i)
- Parameters:
-
i
- the value of the inset
getBottomInset
public float getBottomInset()
- Returns:
- the bottom part of the margin around the view
setBottomInset
public void setBottomInset(float i)
- Parameters:
-
i
- the value of the inset
getLeftInset
public float getLeftInset()
- Returns:
- the left part of the margin around the view
setLeftInset
public void setLeftInset(float i)
- Parameters:
-
i
- the value of the inset
getRightInset
public float getRightInset()
- Returns:
- the right part of the margin around the view
setRightInset
public void setRightInset(float i)
- Parameters:
-
i
- the value of the inset
getInsetSpan
protected float getInsetSpan(int axis)
- Parameters:
-
axis
- the axis to determine the total insets along, either X_AXIS or Y_AXIS. - Returns:
- the span along an axis that is taken up by the insets
- Since:
- 1.4
setEstimatedMajorSpan
protected void setEstimatedMajorSpan(boolean isEstimated)
- Parameters:
-
isEstimated
- new value for the estimatedMajorSpan property - Since:
- 1.4
getEstimatedMajorSpan
protected boolean getEstimatedMajorSpan()
- Returns:
- whether or not the major span currently estimated
- Since:
- 1.4
getChildState
protected AsyncBoxView.ChildState getChildState(int index)
- Parameters:
-
index
- the child index. This should be a value >= 0 and < getViewCount(). - Returns:
- the object representing the layout state of of the child at the given index
getLayoutQueue
protected LayoutQueue getLayoutQueue()
- Returns:
- the queue to use for layout
createChildState
protected AsyncBoxView.ChildState createChildState(View v)
- Parameters:
-
v
- the view - Returns:
- new child state
majorRequirementChange
protected void majorRequirementChange(AsyncBoxView.ChildState cs, float delta)
This is implemented to mark the major axis as having changed so that a future check to see if the requirements need to be published to the parent view will consider the major axis. If the span along the major axis is not estimated, it is updated by the given delta to reflect the incremental change. The delta is ignored if the major span is estimated.
- Parameters:
-
cs
- the child state -
delta
- the delta
minorRequirementChange
protected void minorRequirementChange(AsyncBoxView.ChildState cs)
- Parameters:
-
cs
- the child state
flushRequirementChanges
protected void flushRequirementChanges()
replace
public void replace(int offset, int length, View[] views)
loadChildren
protected void loadChildren(ViewFactory f)
setParent
method. Subclasses can reimplement this to initialize their child views in a different manner. The default implementation creates a child view for each child element. Normally a write-lock is held on the Document while the children are being changed, which keeps the rendering and layout threads safe. The exception to this is when the view is initialized to represent an existing element (via this method), so it is synchronized to exclude preferenceChanged while we are initializing.
- Parameters:
-
f
- the view factory - See Also:
getViewIndexAtPosition
protected int getViewIndexAtPosition(int pos, Position.Bias b)
- Parameters:
-
pos
- the position >= 0 -
b
- the position bias - Returns:
- index of the view representing the given position, or -1 if no view represents that position
updateLayout
protected void updateLayout(DocumentEvent.ElementChange ec, DocumentEvent e, Shape a)
- Overrides:
-
updateLayout
in classView
- Parameters:
-
ec
- changes to the element this view is responsible for (may be null if there were no changes). -
e
- the change information from the associated document -
a
- the current allocation of the view - See Also:
setParent
public void setParent(View parent)
loadChildren
method if this view does not already have children. The children should not be loaded in the constructor because the act of setting the parent may cause them to try to search up the hierarchy (to get the hosting Container for example). If this view has children (the view is being moved from one place in the view hierarchy to another), the loadChildren
method will not be called.preferenceChanged
public void preferenceChanged(View child, boolean width, boolean height)
- Overrides:
-
preferenceChanged
in classView
- Parameters:
-
child
- the child view -
width
- true if the width preference has changed -
height
- true if the height preference has changed - See Also:
setSize
public void setSize(float width, float height)
Since the major axis is updated asynchronously and should be the sum of the tiled children the call is ignored for the major axis. Since the minor axis is flexible, work is queued to resize the children if the minor span changes.
paint
public void paint(Graphics g, Shape alloc)
This is implemented to determine whether or not the desired region to be rendered (i.e. the unclipped area) is up to date or not. If up-to-date the children are rendered. If not up-to-date, a task to build the desired area is placed on the layout queue as a high priority task. This keeps by event thread moving by rendering if ready, and postponing until a later time if not ready (since paint requests can be rescheduled).
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.
- Throws:
-
IllegalArgumentException
- for an invalid axis type
getMinimumSpan
public float getMinimumSpan(int axis)
- Overrides:
-
getMinimumSpan
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.
- Throws:
-
IllegalArgumentException
- for an invalid axis type - See Also:
getMaximumSpan
public float getMaximumSpan(int axis)
- Overrides:
-
getMaximumSpan
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.
- Throws:
-
IllegalArgumentException
- for an invalid axis type - See Also:
getViewCount
public int getViewCount()
- Overrides:
-
getViewCount
in classView
- Returns:
- the number of views >= 0
- See Also:
getView
public View getView(int n)
getChildAllocation
public Shape getChildAllocation(int index, Shape a)
- Overrides:
-
getChildAllocation
in classView
- Parameters:
-
index
- the index of the child, >= 0 && < getViewCount() -
a
- the allocation to this view. - Returns:
- the allocation to the child
getViewIndex
public int getViewIndex(int pos, Position.Bias b)
- Overrides:
-
getViewIndex
in classView
- Parameters:
-
pos
- the position >= 0 -
b
- the bias - Returns:
- index of the view representing the given position, or -1 if no view represents that position
- Since:
- 1.3
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
- the bias toward the previous character or the next character represented by the offset, in case the position is a boundary of two views. - Returns:
- the bounding box of the given position is returned
- Throws:
-
BadLocationException
- if the given position does not represent a valid location in the associated document -
IllegalArgumentException
- for an invalid bias argument - See Also:
viewToModel
public int viewToModel(float x, float y, Shape a, Position.Bias[] biasReturn)
This is expected to be called by the GUI thread, holding a read-lock on the associated model. It is implemented to locate the child view and determine it's allocation with a lock on the ChildLocator object, and to call viewToModel on the child view with a lock on the ChildState object to avoid interaction with the layout thread.
- Specified by:
-
viewToModel
in classView
- Parameters:
-
x
- the X coordinate >= 0 -
y
- the Y coordinate >= 0 -
a
- the allocated region to render into -
biasReturn
- the returned bias - Returns:
- the location within the model that best represents the given point in the view >= 0. The biasReturn argument will be filled in to indicate that the point given is closer to the next character in the model or the previous character in the model.
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 one of the following:SwingConstants.WEST
SwingConstants.EAST
SwingConstants.NORTH
SwingConstants.SOUTH
-
biasRet
- an array contain the bias that was checked -
b
- the 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
- ifdirection
is invalid
© 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/AsyncBoxView.html