Class BlockView
java.lang.Object
javax.swing.text.View
javax.swing.text.CompositeView
javax.swing.text.BoxView
javax.swing.text.html.BlockView
- All Implemented Interfaces:
SwingConstants
- Direct Known Subclasses:
ListView
A view implementation to display a block (as a box)
with CSS specifications.
-
Field Summary
Fields inherited from class View
BadBreakWeight, ExcellentBreakWeight, ForcedBreakWeight, GoodBreakWeight, X_AXIS, Y_AXISFields inherited from interface 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
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected SizeRequirementscalculateMajorAxisRequirements(int axis, SizeRequirements r) Calculate the requirements of the block along the major axis (i.e. the axis along with it tiles).protected SizeRequirementscalculateMinorAxisRequirements(int axis, SizeRequirements r) Calculate the requirements of the block along the minor axis (i.e. the axis orthogonal to the axis along with it tiles).voidchangedUpdate(DocumentEvent changes, Shape a, ViewFactory f) Gives notification from the document that attributes were changed in a location that this view is responsible for.floatgetAlignment(int axis) Gets the alignment.Fetches the attributes to use when rendering.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.floatgetPreferredSpan(int axis) Determines the preferred span for this view along an axis.intgetResizeWeight(int axis) Gets the resize weight.protected StyleSheetConvenient method to get the StyleSheet.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).voidRenders using the given rendering surface and area on that surface.voidEstablishes the parent view for this view.protected voidUpdate any cached values that come from attributes.Methods inherited from class BoxView
baselineLayout, baselineRequirements, childAllocation, flipEastAndWestAtEnds, forwardUpdate, getAxis, getChildAllocation, getHeight, getOffset, getSpan, getViewAtPoint, getWidth, isAfter, isAllocationValid, isBefore, isLayoutValid, layout, layoutChanged, layoutMajorAxis, modelToView, paintChild, preferenceChanged, replace, setAxis, setSize, viewToModelMethods inherited from class CompositeView
getBottomInset, getInsideAllocation, getLeftInset, getNextEastWestVisualPositionFrom, getNextNorthSouthVisualPositionFrom, getNextVisualPositionFrom, getRightInset, getTopInset, getView, getViewAtPosition, getViewCount, getViewIndex, getViewIndexAtPosition, loadChildren, modelToView, setInsets, setParagraphInsetsMethods inherited from class View
append, breakView, createFragment, forwardUpdateToView, getBreakWeight, getContainer, getDocument, getElement, getEndOffset, getGraphics, getParent, getStartOffset, getToolTipText, getViewFactory, getViewIndex, insert, insertUpdate, isVisible, modelToView, remove, removeAll, removeUpdate, updateChildren, updateLayout, viewToModel
-
Constructor Details
-
BlockView
Creates a new view that represents an html box. This can be used for a number of elements.- Parameters:
elem- the element to create a view foraxis- either View.X_AXIS or View.Y_AXIS
-
-
Method Details
-
setParent
Establishes the parent view for this view. This is guaranteed to be called before any other methods if the parent view is functioning properly.This is implemented to forward to the superclass as well as call the
setPropertiesFromAttributes()method to set the paragraph properties from the css attributes. The call is made at this time to ensure the ability to resolve upward through the parents view attributes.- Overrides:
setParentin classCompositeView- Parameters:
parent- the new parent, or null if the view is being removed from a parent it was previously added to
-
calculateMajorAxisRequirements
Calculate the requirements of the block along the major axis (i.e. the axis along with it tiles). This is implemented to provide the superclass behavior and then adjust it if the CSS width or height attribute is specified and applicable to the axis.- Overrides:
calculateMajorAxisRequirementsin classBoxView- Parameters:
axis- the axis being studiedr- theSizeRequirementsobject; ifnullone will be created- Returns:
- the newly initialized
SizeRequirementsobject - See Also:
-
calculateMinorAxisRequirements
Calculate the requirements of the block along the minor axis (i.e. the axis orthogonal to the axis along with it tiles). This is implemented to provide the superclass behavior and then adjust it if the CSS width or height attribute is specified and applicable to the axis.- Overrides:
calculateMinorAxisRequirementsin classBoxView- Parameters:
axis- the axis being studiedr- theSizeRequirementsobject; ifnullone will be created- Returns:
- the newly initialized
SizeRequirementsobject - See Also:
-
layoutMinorAxis
protected 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.- Overrides:
layoutMinorAxisin classBoxView- Parameters:
targetSpan- the total span given to the view, which would be used to layout the children.axis- the axis being laid outoffsets- 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 methodspans- the span of each child view; this is a return value and is filled in by the implementation of this method
-
paint
Renders using the given rendering surface and area on that surface. This is implemented to delegate to the css box painter to paint the border and background prior to the interior. -
getAttributes
Fetches the attributes to use when rendering. This is implemented to multiplex the attributes specified in the model with a StyleSheet.- Overrides:
getAttributesin classView- Returns:
- the attributes to use when rendering
-
getResizeWeight
public int getResizeWeight(int axis) Gets the resize weight.- Overrides:
getResizeWeightin classBoxView- Parameters:
axis- may be either X_AXIS or Y_AXIS- Returns:
- the weight
- Throws:
IllegalArgumentException- for an invalid axis
-
getAlignment
public float getAlignment(int axis) Gets the alignment.- Overrides:
getAlignmentin classBoxView- Parameters:
axis- may be either X_AXIS or Y_AXIS- Returns:
- the alignment
-
changedUpdate
Description copied from class:ViewGives notification from the document that attributes were changed in a location that this view is responsible for. To reduce the burden to subclasses, this functionality is spread out into the following calls that subclasses can reimplement:updateChildrenis called if there were any changes to the element this view is responsible for. If this view has child views that are represent the child elements, then this method should do whatever is necessary to make sure the child views correctly represent the model.forwardUpdateis called to forward the DocumentEvent to the appropriate child views.updateLayoutis called to give the view a chance to either repair its layout, to reschedule layout, or do nothing.
- Overrides:
changedUpdatein classView- Parameters:
changes- the change information from the associated documenta- the current allocation of the viewf- the factory to use to rebuild if the view has children- See Also:
-
getPreferredSpan
public float getPreferredSpan(int axis) Determines the preferred span for this view along an axis.- Overrides:
getPreferredSpanin classBoxView- Parameters:
axis- may be eitherView.X_AXISorView.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) Determines the minimum span for this view along an axis.- Overrides:
getMinimumSpanin classBoxView- Parameters:
axis- may be eitherView.X_AXISorView.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) Determines the maximum span for this view along an axis.- Overrides:
getMaximumSpanin classBoxView- Parameters:
axis- may be eitherView.X_AXISorView.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:
-
setPropertiesFromAttributes
protected void setPropertiesFromAttributes()Update any cached values that come from attributes. -
getStyleSheet
Convenient method to get the StyleSheet.- Returns:
- the StyleSheet
-