Class BoxView
- All Implemented Interfaces:
- SwingConstants
- Direct Known Subclasses:
- BlockView,- FlowView,- TableView,- TableView.TableCell,- TableView.TableRow,- WrappedPlainView,- ZoneView
 Layout for each axis is handled separately by the methods
 layoutMajorAxis and layoutMinorAxis.
 Subclasses can change the layout algorithm by
 reimplementing these methods.    These methods will be called
 as necessary depending upon whether or not there is cached
 layout information and the cache is considered
 valid.  These methods are typically called if the given size
 along the axis changes, or if layoutChanged is
 called to force an updated layout.  The layoutChanged
 method invalidates cached layout information, if there is any.
 The requirements published to the parent view are calculated by
 the methods calculateMajorAxisRequirements
 and  calculateMinorAxisRequirements.
 If the layout algorithm is changed, these methods will
 likely need to be reimplemented.
- 
Field SummaryFields declared in class javax.swing.text.ViewBadBreakWeight, ExcellentBreakWeight, ForcedBreakWeight, GoodBreakWeight, X_AXIS, Y_AXISFields declared in interface javax.swing.SwingConstantsBOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NEXT, NORTH, NORTH_EAST, NORTH_WEST, PREVIOUS, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidbaselineLayout(int targetSpan, int axis, int[] offsets, int[] spans) Computes the location and extent of each child view in thisBoxViewgiven thetargetSpan, which is the width (or height) of the region we have to work with.protected SizeRequirementsbaselineRequirements(int axis, SizeRequirements r) Calculates the size requirements for thisBoxViewby examining the size of each child view.protected SizeRequirementscalculateMajorAxisRequirements(int axis, SizeRequirements r) Calculates the size requirements for the major axisaxis.protected SizeRequirementscalculateMinorAxisRequirements(int axis, SizeRequirements r) Calculates the size requirements for the minor axisaxis.protected voidchildAllocation(int index, Rectangle alloc) Allocates a region for a child view.protected booleanflipEastAndWestAtEnds(int position, Position.Bias bias) Determines in which direction the next view lays.protected voidForwards the givenDocumentEventto the child views that need to be notified of the change to the model.floatgetAlignment(int axis) Determines the desired alignment for this view along an axis.intgetAxis()Fetches the tile axis property.getChildAllocation(int index, Shape a) Fetches the allocation for the given child view.intReturns the current height of the box.floatgetMaximumSpan(int axis) Determines the maximum span for this view along an axis.floatgetMinimumSpan(int axis) Determines the minimum span for this view along an axis.protected intgetOffset(int axis, int childIndex) Fetches the offset of a particular child's current layout.floatgetPreferredSpan(int axis) Determines the preferred span for this view along an axis.intgetResizeWeight(int axis) Gets the resize weight.protected intgetSpan(int axis, int childIndex) Fetches the span of a particular child's current layout.protected ViewgetViewAtPoint(int x, int y, Rectangle alloc) Fetches the child view at the given coordinates.intgetWidth()Returns the current width of the box.protected booleanDetermines if a point falls after an allocated region.protected booleanAre the allocations for the children still valid?protected booleanDetermines if a point falls before an allocated region.protected booleanisLayoutValid(int axis) Determines if the layout is valid along the given axis.protected voidlayout(int width, int height) Perform layout on the boxvoidlayoutChanged(int axis) Invalidates the layout along an axis.protected voidlayoutMajorAxis(int targetSpan, int axis, int[] offsets, int[] spans) Performs layout for the major axis of the box (i.e. the axis that it represents).protected voidlayoutMinorAxis(int targetSpan, int axis, int[] offsets, int[] spans) Performs layout for the minor axis of the box (i.e. the axis orthogonal to the axis that it represents).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.voidRenders theBoxViewusing the given rendering surface and area on that surface.protected voidpaintChild(Graphics g, Rectangle alloc, int index) Paints a child.voidpreferenceChanged(View child, boolean width, boolean height) This is called by a child to indicate its preferred span has changed.voidInvalidates the layout and resizes the cache of requests/allocations.voidsetAxis(int axis) Sets the tile axis property.voidsetSize(float width, float height) Sets the size of the view.intviewToModel(float x, float y, Shape a, Position.Bias[] bias) Provides a mapping from the view coordinate space to the logical coordinate space of the model.Methods declared in class javax.swing.text.CompositeViewgetBottomInset, getInsideAllocation, getLeftInset, getNextEastWestVisualPositionFrom, getNextNorthSouthVisualPositionFrom, getNextVisualPositionFrom, getRightInset, getTopInset, getView, getViewAtPosition, getViewCount, getViewIndex, getViewIndexAtPosition, loadChildren, modelToView, setInsets, setParagraphInsets, setParentMethods declared in class javax.swing.text.Viewappend, breakView, changedUpdate, createFragment, forwardUpdateToView, getAttributes, getBreakWeight, getContainer, getDocument, getElement, getEndOffset, getGraphics, getParent, getStartOffset, getToolTipText, getViewFactory, getViewIndex, insert, insertUpdate, isVisible, modelToView, remove, removeAll, removeUpdate, updateChildren, updateLayout, viewToModel
- 
Constructor Details- 
BoxViewConstructs aBoxView.- Parameters:
- elem- the element this view is responsible for
- axis- either- View.X_AXISor- View.Y_AXIS
 
 
- 
- 
Method Details- 
getAxispublic int getAxis()Fetches the tile axis property. This is the axis along which the child views are tiled.- Returns:
- the major axis of the box, either
  View.X_AXISorView.Y_AXIS
- Since:
- 1.3
 
- 
setAxispublic void setAxis(int axis) Sets the tile axis property. This is the axis along which the child views are tiled.- Parameters:
- axis- either- View.X_AXISor- View.Y_AXIS
- Since:
- 1.3
 
- 
layoutChangedpublic void layoutChanged(int axis) Invalidates the layout along an axis. This happens automatically if the preferences have changed for any of the child views. In some cases the layout may need to be recalculated when the preferences have not changed. The layout can be marked as invalid by calling this method. The layout will be updated the next time thesetSizemethod is called on this view (typically in paint).- Parameters:
- axis- either- View.X_AXISor- View.Y_AXIS
- Since:
- 1.3
 
- 
isLayoutValidprotected boolean isLayoutValid(int axis) Determines if the layout is valid along the given axis.- Parameters:
- axis- either- View.X_AXISor- View.Y_AXIS
- Returns:
- trueif the layout is valid along the given axis, otherwise- false
- Since:
- 1.4
 
- 
paintChildPaints a child. By default that is all it does, but a subclass can use this to paint things relative to the child.- Parameters:
- g- the graphics context
- alloc- the allocated region to paint into
- index- the child index, >= 0 && < getViewCount()
 
- 
replaceInvalidates the layout and resizes the cache of requests/allocations. The child allocations can still be accessed for the old layout, but the new children will have an offset and span of 0.- Overrides:
- replacein class- CompositeView
- Parameters:
- index- the starting index into the child views to insert the new views; this should be a value >= 0 and <= getViewCount
- length- the number of existing child views to remove; This should be a value >= 0 and <= (getViewCount() - offset)
- elems- the child views to add; this value can be- nullto indicate no children are being added (useful to remove)
 
- 
forwardUpdateprotected void forwardUpdate(DocumentEvent.ElementChange ec, DocumentEvent e, Shape a, ViewFactory f) Forwards the givenDocumentEventto the child views that need to be notified of the change to the model. If a child changed its requirements and the allocation was valid prior to forwarding the portion of the box from the starting child to the end of the box will be repainted.- Overrides:
- forwardUpdatein class- View
- Parameters:
- ec- changes to the element this view is responsible for (may be- nullif there were no changes)
- 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
- Since:
- 1.3
- See Also:
 
- 
preferenceChangedThis is called by a child to indicate its preferred span has changed. This is implemented to throw away cached layout information so that new calculations will be done the next time the children need an allocation.- Overrides:
- preferenceChangedin class- View
- Parameters:
- child- the child view
- width- true if the width preference should change
- height- true if the height preference should change
- See Also:
 
- 
getResizeWeightpublic int getResizeWeight(int axis) Gets the resize weight. A value of 0 or less is not resizable.- Overrides:
- getResizeWeightin class- View
- Parameters:
- axis- may be either- View.X_AXISor- View.Y_AXIS
- Returns:
- the weight
- Throws:
- IllegalArgumentException- for an invalid axis
 
- 
setSizepublic void setSize(float width, float height) Sets the size of the view. This should cause layout of the view if the view caches any layout information. This is implemented to call the layout method with the sizes inside of the insets.
- 
paintRenders theBoxViewusing the given rendering surface and area on that surface. Only the children that intersect the clip bounds of the givenGraphicswill be rendered.
- 
getChildAllocationFetches the allocation for the given child view. This enables finding out where various views are located. This is implemented to returnnullif the layout is invalid, otherwise the superclass behavior is executed.- Overrides:
- getChildAllocationin class- CompositeView
- Parameters:
- index- the index of the child, >= 0 && > getViewCount()
- a- the allocation to this view
- Returns:
- the allocation to the child; or nullifaisnull; ornullif the layout is invalid
 
- 
modelToViewProvides a mapping from the document model coordinate space to the coordinate space of the view mapped to it. This makes sure the allocation is valid before calling the superclass.- Overrides:
- modelToViewin class- CompositeView
- Parameters:
- pos- the position to convert >= 0
- a- the allocated region to render into
- b- a bias value of either- Position.Bias.Forwardor- Position.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:
 
- 
viewToModelProvides a mapping from the view coordinate space to the logical coordinate space of the model.- Overrides:
- viewToModelin class- CompositeView
- Parameters:
- x- x coordinate of the view location to convert >= 0
- y- y coordinate of the view location to convert >= 0
- a- the allocated region to render into
- bias- either- Position.Bias.Forwardor- Position.Bias.Backward
- Returns:
- the location within the model that best represents the given point in the view >= 0
- See Also:
 
- 
getAlignmentpublic float getAlignment(int axis) Determines the desired alignment for this view along an axis. This is implemented to give the total alignment needed to position the children with the alignment points lined up along the axis orthogonal to the axis that is being tiled. The axis being tiled will request to be centered (i.e. 0.5f).- Overrides:
- getAlignmentin class- View
- Parameters:
- axis- may be either- View.X_AXISor- View.Y_AXIS
- Returns:
- the desired alignment >= 0.0f && <= 1.0f; this should be a value between 0.0 and 1.0 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
- Throws:
- IllegalArgumentException- for an invalid axis
 
- 
getPreferredSpanpublic float getPreferredSpan(int axis) Determines the preferred span for this view along an axis.- Specified by:
- getPreferredSpanin class- View
- Parameters:
- axis- may be either- View.X_AXISor- 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
 
- 
getMinimumSpanpublic float getMinimumSpan(int axis) Determines the minimum span for this view along an axis.- Overrides:
- getMinimumSpanin class- View
- Parameters:
- axis- may be either- View.X_AXISor- 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:
 
- 
getMaximumSpanpublic float getMaximumSpan(int axis) Determines the maximum span for this view along an axis.- Overrides:
- getMaximumSpanin class- View
- Parameters:
- axis- may be either- View.X_AXISor- 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:
 
- 
isAllocationValidprotected boolean isAllocationValid()Are the allocations for the children still valid?- Returns:
- true if allocations still valid
 
- 
isBeforeDetermines if a point falls before an allocated region.- Specified by:
- isBeforein class- CompositeView
- Parameters:
- x- the X coordinate >= 0
- y- the Y coordinate >= 0
- innerAlloc- the allocated region; this is the area inside of the insets
- Returns:
- true if the point lies before the region else false
 
- 
isAfterDetermines if a point falls after an allocated region.- Specified by:
- isAfterin class- CompositeView
- Parameters:
- x- the X coordinate >= 0
- y- the Y coordinate >= 0
- innerAlloc- the allocated region; this is the area inside of the insets
- Returns:
- true if the point lies after the region else false
 
- 
getViewAtPointFetches the child view at the given coordinates.- Specified by:
- getViewAtPointin class- CompositeView
- Parameters:
- x- the X coordinate >= 0
- y- the Y coordinate >= 0
- alloc- the parents inner allocation on entry, which should be changed to the child's allocation on exit
- Returns:
- the view
 
- 
childAllocationAllocates a region for a child view.- Specified by:
- childAllocationin class- CompositeView
- Parameters:
- index- the index of the child view to allocate, >= 0 && < getViewCount()
- alloc- the allocated region
 
- 
layoutprotected void layout(int width, int height) Perform layout on the box- Parameters:
- width- the width (inside of the insets) >= 0
- height- the height (inside of the insets) >= 0
 
- 
getWidthpublic int getWidth()Returns the current width of the box. This is the width that it was last allocated.- Returns:
- the current width of the box
 
- 
getHeightpublic int getHeight()Returns the current height of the box. This is the height that it was last allocated.- Returns:
- the current height of the box
 
- 
layoutMajorAxisprotected void layoutMajorAxis(int targetSpan, int axis, int[] offsets, int[] spans) Performs layout for the major axis of the box (i.e. the axis that it represents). The results of the layout (the offset and span for each children) are placed in the given arrays which represent the allocations to the children along the major axis.- Parameters:
- targetSpan- the total span given to the view, which would be used to layout the children
- axis- the axis being laid out
- offsets- the offsets from the origin of the view for each of the child views; this is a return value and is filled in by the implementation of this method
- spans- the span of each child view; this is a return value and is filled in by the implementation of this method
 
- 
layoutMinorAxisprotected void layoutMinorAxis(int targetSpan, int axis, int[] offsets, int[] spans) Performs layout for the minor axis of the box (i.e. the axis orthogonal to the axis that it represents). The results of the layout (the offset and span for each children) are placed in the given arrays which represent the allocations to the children along the minor axis.- Parameters:
- targetSpan- the total span given to the view, which would be used to layout the children
- axis- the axis being laid out
- offsets- the offsets from the origin of the view for each of the child views; this is a return value and is filled in by the implementation of this method
- spans- the span of each child view; this is a return value and is filled in by the implementation of this method
 
- 
calculateMajorAxisRequirementsCalculates the size requirements for the major axisaxis.- Parameters:
- axis- the axis being studied
- r- the- SizeRequirementsobject; if- nullone will be created
- Returns:
- the newly initialized SizeRequirementsobject
- See Also:
 
- 
calculateMinorAxisRequirementsCalculates the size requirements for the minor axisaxis.- Parameters:
- axis- the axis being studied
- r- the- SizeRequirementsobject; if- nullone will be created
- Returns:
- the newly initialized SizeRequirementsobject
- See Also:
 
- 
baselineLayoutprotected void baselineLayout(int targetSpan, int axis, int[] offsets, int[] spans) Computes the location and extent of each child view in thisBoxViewgiven thetargetSpan, which is the width (or height) of the region we have to work with.- Parameters:
- targetSpan- the total span given to the view, which would be used to layout the children
- axis- the axis being studied, either- View.X_AXISor- View.Y_AXIS
- offsets- an empty array filled by this method with values specifying the location of each child view
- spans- an empty array filled by this method with values specifying the extent of each child view
 
- 
baselineRequirementsCalculates the size requirements for thisBoxViewby examining the size of each child view.- Parameters:
- axis- the axis being studied
- r- the- SizeRequirementsobject; if- nullone will be created
- Returns:
- the newly initialized SizeRequirementsobject
 
- 
getOffsetprotected int getOffset(int axis, int childIndex) Fetches the offset of a particular child's current layout.- Parameters:
- axis- the axis being studied
- childIndex- the index of the requested child
- Returns:
- the offset (location) for the specified child
 
- 
getSpanprotected int getSpan(int axis, int childIndex) Fetches the span of a particular child's current layout.- Parameters:
- axis- the axis being studied
- childIndex- the index of the requested child
- Returns:
- the span (width or height) of the specified child
 
- 
flipEastAndWestAtEndsDetermines in which direction the next view lays. Consider the View at index n. Typically theViews are laid out from left to right, so that theViewto the EAST will be at index n + 1, and theViewto the WEST will be at index n - 1. In certain situations, such as with bidirectional text, it is possible that theViewto EAST is not at index n + 1, but rather at index n - 1, or that theViewto the WEST is not at index n - 1, but index n + 1. In this case this method would return true, indicating theViews are laid out in descending order. Otherwise the method would return false indicating theViews are laid out in ascending order.If the receiver is laying its Views along theY_AXIS, this will return the value from invoking the same method on theViewresponsible for renderingpositionandbias. Otherwise this will return false.- Overrides:
- flipEastAndWestAtEndsin class- CompositeView
- Parameters:
- position- position into the model
- bias- either- Position.Bias.Forwardor- Position.Bias.Backward
- Returns:
- true if the Views surrounding theViewresponding for renderingpositionandbiasare laid out in descending order; otherwise false
 
 
-