Class BlockBox
java.lang.Object
com.openhtmltopdf.render.Box
com.openhtmltopdf.render.BlockBox
- All Implemented Interfaces:
InlinePaintable, Styleable, DisplayListItem
- Direct Known Subclasses:
AnonymousBlockBox, FlowingColumnBox, FlowingColumnContainerBox, MarginBox, TableBox, TableCellBox, TableRowBox, TableSectionBox, ViewportBox
A block box as defined in the CSS spec. It also provides a base class for
other kinds of block content (for example table rows or cells).
See
BlockBox.ContentType-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic enumWhat type of direct child content this block box contains.private static classstatic classNested classes/interfaces inherited from class Box
Box.ChildIteratorOfType<T> -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate booleanprivate BlockBox.ContentTypeprivate intprivate booleanprivate CascadedStyleprivate CascadedStyleprivate FloatedBoxDataprivate booleanprivate booleanprivate intprivate MarkerDataprivate intprivate booleanprivate intprivate booleanprivate booleanprivate BlockBox.MarginCollapseResultprivate PersistentBFCprivate ReplacedElementprivate Boxprivate booleanprotected static final intstatic final intstatic final intstatic final intFields inherited from class Box
CHILDREN_FLUX, DONE, DUMP_LAYOUT, DUMP_RENDER, FLUX, LINE_SEPARATOR, NOTHING -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected voidprivate voidprotected voidappendPositioningInfo(StringBuilder result) private voidprivate voidintvoidvoidprotected voidcalcChildPaintingInfo(CssContext c, PaintingInfo result, boolean useCache) private voidvoidprotected voidcalcDimensions(LayoutContext c, int cssWidth) private intprivate voidprotected intvoidintprotected voidcalcLayoutHeight(LayoutContext c, BorderPropertySet border, RectPropertySet margin, RectPropertySet padding) Oh oh! Up to this method height is used to track content height.private voidcalcMinMaxCSSMinMaxWidth(LayoutContext c, RectPropertySet margin, BorderPropertySet border, RectPropertySet padding) voidprivate voidprivate voidprivate intprivate intprivate intprivate voidbooleanprotected voidChecks if this box established a block formatting context and if so removes the last bfc from the stack.protected voidChecks if this box establishes a block formatting context and if so creates one and pushes it to the stack of bfcs.protected booleancheckPushLayer(LayoutContext c, CalculatedStyle style) private voidcollapseBottomMargin(LayoutContext c, boolean calculationRoot, BlockBox.MarginCollapseResult result) private voidprotected voidprivate voidcollapseTopMargin(LayoutContext c, boolean calculationRoot, BlockBox.MarginCollapseResult result) copyOf()voidprivate voidCreates the replaced element as required.dump(LayoutContext c, String indent, int which) voidprivate LineBoxprivate LineBoxprivate voidfindLastNthLineBox(int count) intfindOffset(Box box) protected intintprivate intprotected intprotected intprivate intprivate intprivate intprivate intprotected intprotected intgetCSSWidth(CssContext c, boolean shrinkingToFit) protected Stringintintintprotected BlockBoxgetNextCollapsableSibling(BlockBox.MarginCollapseResult collapsedMargin) protected intgetPaintingClipEdge(CssContext cssCtx) voidinitStaticPos(LayoutContext c, BlockBox parent, int childOffset) protected booleanbooleanbooleanbooleanbooleanprivate booleanprotected booleanbooleanbooleanbooleanisInline()protected booleanbooleanbooleanprotected booleanprotected booleanbooleanbooleanprivate booleanbooleanprivate booleanprivate booleanbooleanUsing the css: -fs-page-break-min-height: 5cm; on a block element you can force a pagebreak before this block, if not enough space (e.g.booleanprotected booleanbooleanprivate booleanprivate voidvoidvoidlayout(LayoutContext c, int contentStart) protected voidlayoutChildren(LayoutContext c, int contentStart) protected voidlayoutInlineChildren(LayoutContext c, int contentStart, int breakAtLine, boolean tryAgain) private MarkerData.GlyphMarkermakeGlyphMarker(StrutMetrics strutMetrics) private MarkerData.ImageMarkermakeImageMarker(LayoutContext c, StrutMetrics structMetrics, String image) private MarkerData.TextMarkermakeTextMarker(LayoutContext c, IdentValue listStyle) voidvoidvoidvoidpositionAbsolute(CssContext cssCtx, int direction) voidprotected voidpropagateExtraSpace(LayoutContext c, ContentLimitContainer parentContainer, ContentLimitContainer currentContainer, int extraTop, int extraBottom) private voidvoidResponsible for resetting the state of the box before a repeat call tolayout(LayoutContext)or other layout methods.protected voidresolveAutoMargins(LayoutContext c, int cssWidth, RectPropertySet padding, BorderPropertySet border) private voidsatisfyWidowsAndOrphans(LayoutContext c, int contentStart, boolean tryAgain) TERMINOLOGY: Orphans refers to the number of lines of content in this box before the first page break.voidsetBottomMarginCalculated(boolean bottomMarginCalculated) voidsetChildrenContentType(BlockBox.ContentType contentType) protected voidsetChildrenHeight(int childrenHeight) private voidsetCollapsedBottomMargin(LayoutContext c, RectPropertySet margin, BlockBox.MarginCollapseResult collapsedMargin) protected voidsetDimensionsCalculated(boolean dimensionsCalculated) voidsetElement(Element element) voidsetFirstLetterStyle(CascadedStyle firstLetterStyle) voidsetFirstLineStyle(CascadedStyle firstLineStyle) voidsetFloatedBoxData(FloatedBoxData floatedBoxData) voidsetFromCaptionedTable(boolean fromTable) voidsetInlineContent(List<Styleable> inlineContent) Inline content is created by the box builder.voidsetListCounter(int listCounter) voidsetMarkerData(MarkerData markerData) protected voidsetMaxWidth(int maxWidth) protected voidsetMinMaxCalculated(boolean minMaxCalculated) protected voidsetMinWidth(int minWidth) voidsetNeedPageClear(boolean needPageClear) protected voidsetNeedShrinkToFitCalculatation(boolean needShrinkToFitCalculatation) voidsetPersistentBFC(PersistentBFC persistentBFC) voidsetReplacedElement(ReplacedElement replacedElement) voidsetStaticEquivalent(Box staticEquivalent) voidsetTopMarginCalculated(boolean topMarginCalculated) booleanprivate voidSize a replaced element taking into account size properties including min/max, border-box/content-box and the natural size/aspect ratio of the replaced object.voidvoidstyleText(LayoutContext c, CalculatedStyle style) toString()Methods inherited from class Box
addAllChildren, addChild, addChildForLayout, analyzePageBreaks, ancestors, ancestorsWhile, calcPaintingInfo, collectText, connectChildrenToCurrentLayer, crossesPageBreak, detach, dumpBoxes, exportPageBoxText, exportText, find, findAncestor, findColumnBreakOpportunities, forcePageBreakAfter, forcePageBreakBefore, forcePageBreakBefore, getAbsoluteClipBox, getAbsX, getAbsY, getAccessibilityObject, getBorder, getBorderBox, getBorderBoxHeight, getBorderBoxWidth, getBorderEdge, getBorderSides, getBoxDimensions, getChild, getChildCount, getChildIterator, getChildIteratorOfType, getChildren, getChildrenClipEdge, getClipBox, getContainingBlock, getContainingBlockWidth, getContainingLayer, getContentAreaEdge, getContentWidth, getEffBackgroundColor, getEffectiveWidth, getElement, getElementBoxes, getHeight, getIndex, getLayer, getLeftMBP, getMargin, getMarginBorderPadding, getMarginEdge, getMarginEdge, getNext, getNextSibling, getPadding, getPaddingEdge, getPaddingWidth, getPaintingBorderEdge, getPaintingInfo, getPaintingPaddingEdge, getParent, getParentClipBox, getPrevious, getPreviousSibling, getPseudoElementOrClass, getRelativeOffset, getRightMBP, getState, getStyle, getStyleMargin, getStyleMargin, getTx, getTy, getWidth, getX, getY, hasNonTextContent, hasRootElementBackground, initContainingLayer, intersects, isAnonymous, isBody, isContainedInMarginBox, isFirstChild, isInDocumentFlow, isInitialContainingBlock, isMarginAreaRoot, isRoot, isStyled, isTerminalColumnBreak, moveIfGreater, paintBackground, paintBorder, paintRootElementBackground, positionRelative, removeAllChildren, removeChild, removeChild, resetChildren, resetChildren, resetTopMargin, rootBox, setAbsX, setAbsY, setAccessiblityObject, setAnonymous, setBorderBoxHeight, setBorderBoxWidth, setBoxDimensions, setContainingBlock, setContainingLayer, setContentWidth, setHeight, setIndex, setLayer, setLeftMBP, setMarginBottom, setMarginLeft, setMarginRight, setMarginTop, setParent, setPseudoElementOrClass, setRelativeOffset, setRightMBP, setState, setStyle, setTx, setTy, setX, setY, stateToString
-
Field Details
-
POSITION_VERTICALLY
public static final int POSITION_VERTICALLY- See Also:
-
POSITION_HORIZONTALLY
public static final int POSITION_HORIZONTALLY- See Also:
-
POSITION_BOTH
public static final int POSITION_BOTH- See Also:
-
NO_BASELINE
protected static final int NO_BASELINE- See Also:
-
_markerData
-
_listCounter
private int _listCounter -
_persistentBFC
-
_staticEquivalent
-
_needPageClear
private boolean _needPageClear -
_replacedElement
-
_childrenContentType
-
_inlineContent
-
_topMarginCalculated
private boolean _topMarginCalculated -
_bottomMarginCalculated
private boolean _bottomMarginCalculated -
_pendingCollapseCalculation
-
_minWidth
private int _minWidth -
_maxWidth
private int _maxWidth -
_minMaxCalculated
private boolean _minMaxCalculated -
_dimensionsCalculated
private boolean _dimensionsCalculated -
_needShrinkToFitCalculatation
private boolean _needShrinkToFitCalculatation -
_firstLineStyle
-
_firstLetterStyle
-
_floatedBoxData
-
_childrenHeight
private int _childrenHeight -
_fromCaptionedTable
private boolean _fromCaptionedTable -
_isReplaced
private boolean _isReplaced
-
-
Constructor Details
-
BlockBox
public BlockBox()
-
-
Method Details
-
setElement
- Specified by:
setElementin interfaceStyleable- Overrides:
setElementin classBox
-
copyOf
-
getExtraBoxDescription
-
toString
-
appendPositioningInfo
-
dump
-
isListItem
public boolean isListItem() -
paintListMarker
-
getPaintingClipEdge
- Overrides:
getPaintingClipEdgein classBox
-
paintInline
- Specified by:
paintInlinein interfaceInlinePaintable
-
isInline
public boolean isInline() -
getLineBox
-
paintDebugOutline
-
getMarkerData
-
setMarkerData
-
createMarkerData
-
makeGlyphMarker
-
makeImageMarker
private MarkerData.ImageMarker makeImageMarker(LayoutContext c, StrutMetrics structMetrics, String image) -
makeTextMarker
-
getListCounter
public int getListCounter() -
setListCounter
public void setListCounter(int listCounter) -
getPersistentBFC
-
setPersistentBFC
-
getStaticEquivalent
-
setStaticEquivalent
-
shouldBeReplaced
public boolean shouldBeReplaced() -
isReplaced
public boolean isReplaced() -
calcCanvasLocation
public void calcCanvasLocation()- Specified by:
calcCanvasLocationin classBox
-
calcInitialFloatedCanvasLocation
-
calcChildLocations
public void calcChildLocations()- Overrides:
calcChildLocationsin classBox
-
isNeedPageClear
public boolean isNeedPageClear() -
setNeedPageClear
public void setNeedPageClear(boolean needPageClear) -
alignToStaticEquivalent
private void alignToStaticEquivalent() -
positionAbsolute
-
isPageBreakNeededBecauseOfMinHeight
Using the css: -fs-page-break-min-height: 5cm; on a block element you can force a pagebreak before this block, if not enough space (e.g. 5cm in this case) is remaining on the current page for the block.- Returns:
- true if a pagebreak is needed before this block because there is not enough space left on the current page.
-
positionAbsoluteOnPage
-
getReplacedElement
-
setReplacedElement
-
reset
Description copied from class:BoxResponsible for resetting the state of the box before a repeat call tolayout(LayoutContext)or other layout methods.
Any layout operation that is not idempotent MUST be reset in this method. Layout may be called several times on the one box. -
calcPinnedContentWidth
-
calcPinnedHeight
-
resolveAutoMargins
protected void resolveAutoMargins(LayoutContext c, int cssWidth, RectPropertySet padding, BorderPropertySet border) -
calcEffPageRelativeWidth
-
createReplaced
Creates the replaced element as required. This method should be idempotent. -
sizeReplacedElement
Size a replaced element taking into account size properties including min/max, border-box/content-box and the natural size/aspect ratio of the replaced object. This method may be called multiple times so must be idempotent. -
calcDimensions
-
calcDimensions
-
calcClearance
-
calcExtraPageClearance
-
addBoxID
-
layout
-
layout
-
checkPushLayer
-
checkPopBfc
Checks if this box established a block formatting context and if so removes the last bfc from the stack. See alsocheckPushBfc(LayoutContext) -
checkPushBfc
Checks if this box establishes a block formatting context and if so creates one and pushes it to the stack of bfcs. See alsocheckPopBfc(LayoutContext) -
isAllowHeightToShrink
protected boolean isAllowHeightToShrink() -
getPageClearance
protected int getPageClearance() -
calcLayoutHeight
protected void calcLayoutHeight(LayoutContext c, BorderPropertySet border, RectPropertySet margin, RectPropertySet padding) Oh oh! Up to this method height is used to track content height. After this method it is used to track total layout height! -
calcShrinkToFitWidthIfNeeded
-
applyCSSMinMaxWidth
-
applyCSSMinMaxHeight
-
ensureChildren
-
layoutChildren
-
layoutInlineChildren
protected void layoutInlineChildren(LayoutContext c, int contentStart, int breakAtLine, boolean tryAgain) -
justifyText
-
satisfyWidowsAndOrphans
TERMINOLOGY: Orphans refers to the number of lines of content in this box before the first page break. Widows refers to the number of lines of content on the last page.
METHOD AIM: This method aims (but can not guarantee) to satisfy theorphansandwidowsCSS properties. Each of these provide a number specifying a minimum number of content lines.
HOW: By inserting page breaks, either before this box or between certain lines in this box.
PREREQUISITES: That the content of this box isCONTENT_INLINEand layout has been done on this box. This means that the children of this box will consist entirely of LineBox objects. -
getChildrenContentType
-
setChildrenContentType
-
getInlineContent
-
setInlineContent
Inline content is created by the box builder. It is important to note that the inline content here is stored in the pre-layout state. Ie. It has not been flowed out intoLineBoxandInlineLayoutBoxobjects but is stored asInlineBoxand block boxes that are laid out inline such as inline-block and inline-table.
During layout inline-content is laid out into lines and so on but the inline content is left untouched so as to be able to run layout multiple times to satisfy constraints.
This method should be called withsetChildrenContentType(ContentType)set toBlockBox.ContentType.INLINEas block boxes can not contain mixed content. -
isSkipWhenCollapsingMargins
protected boolean isSkipWhenCollapsingMargins() -
isMayCollapseMarginsWithChildren
protected boolean isMayCollapseMarginsWithChildren() -
collapseMargins
-
setCollapsedBottomMargin
private void setCollapsedBottomMargin(LayoutContext c, RectPropertySet margin, BlockBox.MarginCollapseResult collapsedMargin) -
getNextCollapsableSibling
-
collapseTopMargin
private void collapseTopMargin(LayoutContext c, boolean calculationRoot, BlockBox.MarginCollapseResult result) -
collapseBottomMargin
private void collapseBottomMargin(LayoutContext c, boolean calculationRoot, BlockBox.MarginCollapseResult result) -
isNoTopPaddingOrBorder
-
isNoBottomPaddingOrBorder
-
collapseEmptySubtreeMargins
-
isVerticalMarginsAdjoin
-
isTopMarginCalculated
public boolean isTopMarginCalculated() -
setTopMarginCalculated
public void setTopMarginCalculated(boolean topMarginCalculated) -
isBottomMarginCalculated
public boolean isBottomMarginCalculated() -
setBottomMarginCalculated
public void setBottomMarginCalculated(boolean bottomMarginCalculated) -
getCSSWidth
-
getCSSWidth
-
getCSSFitToWidth
-
getCSSHeight
-
isAutoHeight
public boolean isAutoHeight() -
getCSSMinWidth
-
getCSSMaxWidth
-
getCSSMinHeight
-
getCSSMaxHeight
-
getContainingBlockCSSHeight
-
calcShrinkToFitWidth
-
getAvailableWidth
-
isFixedWidthAdvisoryOnly
protected boolean isFixedWidthAdvisoryOnly() -
recalcMargin
-
calcMinMaxWidth
-
calcMinMaxCSSMinMaxWidth
private void calcMinMaxCSSMinMaxWidth(LayoutContext c, RectPropertySet margin, BorderPropertySet border, RectPropertySet padding) -
calcMinMaxWidthBlockChildren
-
calcMinMaxWidthInlineChildren
-
getMaxWidth
public int getMaxWidth() -
setMaxWidth
protected void setMaxWidth(int maxWidth) -
getMinWidth
public int getMinWidth() -
setMinWidth
protected void setMinWidth(int minWidth) -
styleText
-
styleText
-
calcChildPaintingInfo
- Overrides:
calcChildPaintingInfoin classBox
-
getFirstLetterStyle
-
setFirstLetterStyle
-
getFirstLineStyle
-
setFirstLineStyle
-
isMinMaxCalculated
protected boolean isMinMaxCalculated() -
setMinMaxCalculated
protected void setMinMaxCalculated(boolean minMaxCalculated) -
setDimensionsCalculated
protected void setDimensionsCalculated(boolean dimensionsCalculated) -
isDimensionsCalculated
private boolean isDimensionsCalculated() -
setNeedShrinkToFitCalculatation
protected void setNeedShrinkToFitCalculatation(boolean needShrinkToFitCalculatation) -
isNeedShrinkToFitCalculatation
private boolean isNeedShrinkToFitCalculatation() -
initStaticPos
-
calcBaseline
-
calcInitialBreakAtLine
-
isCurrentBreakAtLineContext
-
calcBreakAtLineContext
-
calcInlineBaseline
-
findOffset
-
findLastNthLineBox
-
findLastLineBox
-
findLastLineBox
-
findFirstLineBox
-
isNeedsKeepWithInline
-
isFloated
public boolean isFloated() -
getFloatedBoxData
-
setFloatedBoxData
-
getChildrenHeight
public int getChildrenHeight() -
setChildrenHeight
protected void setChildrenHeight(int childrenHeight) -
isFromCaptionedTable
public boolean isFromCaptionedTable() -
setFromCaptionedTable
public void setFromCaptionedTable(boolean fromTable) -
isInlineBlock
protected boolean isInlineBlock()- Overrides:
isInlineBlockin classBox
-
isInMainFlow
public boolean isInMainFlow() -
getDocumentParent
- Overrides:
getDocumentParentin classBox
-
isContainsInlineContent
-
checkPageContext
-
isNeedsClipOnPaint
-
propagateExtraSpace
protected void propagateExtraSpace(LayoutContext c, ContentLimitContainer parentContainer, ContentLimitContainer currentContainer, int extraTop, int extraBottom)
-