1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
15 * The Original Code is mozilla.org code.
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
24 * Alternatively, the contents of this file may be used under the terms of
25 * either of the GNU General Public License Version 2 or later (the "GPL"),
26 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
36 * ***** END LICENSE BLOCK ***** */
37 #ifndef nsTableRowFrame_h__
38 #define nsTableRowFrame_h__
41 #include "nsHTMLContainerFrame.h"
42 #include "nsTablePainter.h"
45 class nsTableCellFrame
;
46 struct nsTableCellReflowState
;
48 // This is also used on rows, from nsTableRowGroupFrame.h
49 // #define NS_REPEATED_ROW_OR_ROWGROUP 0x10000000
51 // Indicates whether this row has any cells that have
52 // non-auto-height and rowspan=1
53 #define NS_ROW_HAS_CELL_WITH_STYLE_HEIGHT 0x20000000
55 #define NS_TABLE_ROW_HAS_UNPAGINATED_HEIGHT 0x40000000
58 * nsTableRowFrame is the frame that maps table rows
59 * (HTML tag TR). This class cannot be reused
60 * outside of an nsTableRowGroupFrame. It assumes that its parent is an nsTableRowGroupFrame,
61 * and its children are nsTableCellFrames.
64 * @see nsTableRowGroupFrame
65 * @see nsTableCellFrame
67 class nsTableRowFrame
: public nsHTMLContainerFrame
71 NS_DECLARE_FRAME_ACCESSOR(nsTableRowFrame
)
74 virtual ~nsTableRowFrame();
76 NS_IMETHOD
Init(nsIContent
* aContent
,
78 nsIFrame
* aPrevInFlow
);
79 /** @see nsIFrame::DidSetStyleContext */
80 virtual void DidSetStyleContext(nsStyleContext
* aOldStyleContext
);
82 NS_IMETHOD
AppendFrames(nsIAtom
* aListName
,
83 nsFrameList
& aFrameList
);
84 NS_IMETHOD
InsertFrames(nsIAtom
* aListName
,
86 nsFrameList
& aFrameList
);
87 NS_IMETHOD
RemoveFrame(nsIAtom
* aListName
,
90 /** instantiate a new instance of nsTableRowFrame.
91 * @param aPresShell the pres shell for this frame
93 * @return the frame that was created
95 friend nsIFrame
* NS_NewTableRowFrame(nsIPresShell
* aPresShell
, nsStyleContext
* aContext
);
97 virtual nsMargin
GetUsedMargin() const;
98 virtual nsMargin
GetUsedBorder() const;
99 virtual nsMargin
GetUsedPadding() const;
101 NS_IMETHOD
BuildDisplayList(nsDisplayListBuilder
* aBuilder
,
102 const nsRect
& aDirtyRect
,
103 const nsDisplayListSet
& aLists
);
105 nsTableCellFrame
* GetFirstCell() ;
107 /** calls Reflow for all of its child cells.
108 * Cells with rowspan=1 are all set to the same height and stacked horizontally.
109 * <P> Cells are not split unless absolutely necessary.
110 * <P> Cells are resized in nsTableFrame::BalanceColumnWidths
111 * and nsTableFrame::ShrinkWrapChildren
113 * @param aDesiredSize width set to width of the sum of the cells, height set to
114 * height of cells with rowspan=1.
116 * @see nsIFrame::Reflow
117 * @see nsTableFrame::BalanceColumnWidths
118 * @see nsTableFrame::ShrinkWrapChildren
120 NS_IMETHOD
Reflow(nsPresContext
* aPresContext
,
121 nsHTMLReflowMetrics
& aDesiredSize
,
122 const nsHTMLReflowState
& aReflowState
,
123 nsReflowStatus
& aStatus
);
128 * Get the "type" of the frame
130 * @see nsGkAtoms::tableRowFrame
132 virtual nsIAtom
* GetType() const;
135 NS_IMETHOD
GetFrameName(nsAString
& aResult
) const;
138 void UpdateHeight(nscoord aHeight
,
141 nsTableFrame
* aTableFrame
= nsnull
,
142 nsTableCellFrame
* aCellFrame
= nsnull
);
144 void ResetHeight(nscoord aRowStyleHeight
);
146 // calculate the height, considering content height of the
147 // cells and the style height of the row and cells, excluding pct heights
148 nscoord
CalcHeight(const nsHTMLReflowState
& aReflowState
);
150 // Support for cells with 'vertical-align: baseline'.
153 * returns the max-ascent amongst all the cells that have
154 * 'vertical-align: baseline', *including* cells with rowspans.
155 * returns 0 if we don't have any cell with 'vertical-align: baseline'
157 nscoord
GetMaxCellAscent() const;
159 /* return the row ascent
161 nscoord
GetRowBaseline();
163 /** returns the ordinal position of this row in its table */
164 virtual PRInt32
GetRowIndex() const;
166 /** set this row's starting row index */
167 void SetRowIndex (int aRowIndex
);
169 /** used by row group frame code */
170 nscoord
ReflowCellFrame(nsPresContext
* aPresContext
,
171 const nsHTMLReflowState
& aReflowState
,
173 nsTableCellFrame
* aCellFrame
,
174 nscoord aAvailableHeight
,
175 nsReflowStatus
& aStatus
);
177 * Collapse the row if required, apply col and colgroup visibility: collapse
178 * info to the cells in the row.
179 * @return he amount to shift up all following rows
180 * @param aRowOffset - shift the row up by this amount
181 * @param aWidth - new width of the row
182 * @param aCollapseGroup - parent rowgroup is collapsed so this row needs
184 * @param aDidCollapse - the row has been collapsed
186 nscoord
CollapseRowIfNecessary(nscoord aRowOffset
,
188 PRBool aCollapseGroup
,
189 PRBool
& aDidCollapse
);
191 void InsertCellFrame(nsTableCellFrame
* aFrame
,
192 nsTableCellFrame
* aPrevSibling
);
194 void InsertCellFrame(nsTableCellFrame
* aFrame
,
197 void RemoveCellFrame(nsTableCellFrame
* aFrame
);
199 nsresult
CalculateCellActualSize(nsIFrame
* aRowFrame
,
200 nscoord
& aDesiredWidth
,
201 nscoord
& aDesiredHeight
,
202 nscoord aAvailWidth
);
204 PRBool
IsFirstInserted() const;
205 void SetFirstInserted(PRBool aValue
);
207 PRBool
GetContentHeight() const;
208 void SetContentHeight(nscoord aTwipValue
);
210 PRBool
HasStyleHeight() const;
212 PRBool
HasFixedHeight() const;
213 void SetHasFixedHeight(PRBool aValue
);
215 PRBool
HasPctHeight() const;
216 void SetHasPctHeight(PRBool aValue
);
218 nscoord
GetFixedHeight() const;
219 void SetFixedHeight(nscoord aValue
);
221 float GetPctHeight() const;
222 void SetPctHeight(float aPctValue
,
223 PRBool aForce
= PR_FALSE
);
225 nscoord
GetHeight(nscoord aBasis
= 0) const;
227 nsTableRowFrame
* GetNextRow() const;
229 PRBool
HasUnpaginatedHeight();
230 void SetHasUnpaginatedHeight(PRBool aValue
);
231 nscoord
GetUnpaginatedHeight(nsPresContext
* aPresContext
);
232 void SetUnpaginatedHeight(nsPresContext
* aPresContext
, nscoord aValue
);
234 nscoord
GetTopBCBorderWidth();
235 void SetTopBCBorderWidth(BCPixelSize aWidth
);
236 nscoord
GetBottomBCBorderWidth();
237 void SetBottomBCBorderWidth(BCPixelSize aWidth
);
238 nsMargin
* GetBCBorderWidth(nsMargin
& aBorder
);
241 * Gets inner border widths before collapsing with cell borders
242 * Caller must get bottom border from next row or from table
243 * GetContinuousBCBorderWidth will not overwrite aBorder.bottom
244 * see nsTablePainter about continuous borders
246 void GetContinuousBCBorderWidth(nsMargin
& aBorder
);
248 * @returns outer top bc border == prev row's bottom inner
250 nscoord
GetOuterTopContBCBorderWidth();
252 * Sets full border widths before collapsing with cell borders
253 * @param aForSide - side to set; only accepts right, left, and top
255 void SetContinuousBCBorderWidth(PRUint8 aForSide
,
256 BCPixelSize aPixelValue
);
260 /** protected constructor.
263 nsTableRowFrame(nsStyleContext
*aContext
);
265 void InitChildReflowState(nsPresContext
& aPresContext
,
266 const nsSize
& aAvailSize
,
267 PRBool aBorderCollapse
,
268 nsTableCellReflowState
& aReflowState
);
270 /** implement abstract method on nsHTMLContainerFrame */
271 virtual PRIntn
GetSkipSides() const;
273 // row-specific methods
275 nscoord
ComputeCellXOffset(const nsHTMLReflowState
& aState
,
277 const nsMargin
& aKidMargin
) const;
279 * Called for incremental/dirty and resize reflows. If aDirtyOnly is true then
280 * only reflow dirty cells.
282 NS_IMETHOD
ReflowChildren(nsPresContext
* aPresContext
,
283 nsHTMLReflowMetrics
& aDesiredSize
,
284 const nsHTMLReflowState
& aReflowState
,
285 nsTableFrame
& aTableFrame
,
286 nsReflowStatus
& aStatus
);
290 unsigned mRowIndex
:29;
291 unsigned mHasFixedHeight
:1; // set if the dominating style height on the row or any cell is pixel based
292 unsigned mHasPctHeight
:1; // set if the dominating style height on the row or any cell is pct based
293 unsigned mFirstInserted
:1; // if true, then it was the top most newly inserted row
296 // the desired height based on the content of the tallest cell in the row
297 nscoord mContentHeight
;
298 // the height based on a style percentage height on either the row or any cell
299 // if mHasPctHeight is set
300 nscoord mStylePctHeight
;
301 // the height based on a style pixel height on the row or any
302 // cell if mHasFixedHeight is set
303 nscoord mStyleFixedHeight
;
305 // max-ascent and max-descent amongst all cells that have 'vertical-align: baseline'
306 nscoord mMaxCellAscent
; // does include cells with rowspan > 1
307 nscoord mMaxCellDescent
; // does *not* include cells with rowspan > 1
309 // border widths in pixels in the collapsing border model of the *inner*
310 // half of the border only
311 BCPixelSize mTopBorderWidth
;
312 BCPixelSize mBottomBorderWidth
;
313 BCPixelSize mRightContBorderWidth
;
314 BCPixelSize mTopContBorderWidth
;
315 BCPixelSize mLeftContBorderWidth
;
318 * Sets the NS_ROW_HAS_CELL_WITH_STYLE_HEIGHT bit to indicate whether
319 * this row has any cells that have non-auto-height. (Row-spanning
320 * cells are ignored.)
322 void InitHasCellWithStyleHeight(nsTableFrame
* aTableFrame
);
326 inline PRInt32
nsTableRowFrame::GetRowIndex() const
328 return PRInt32(mBits
.mRowIndex
);
331 inline void nsTableRowFrame::SetRowIndex (int aRowIndex
)
333 mBits
.mRowIndex
= aRowIndex
;
336 inline PRBool
nsTableRowFrame::IsFirstInserted() const
338 return PRBool(mBits
.mFirstInserted
);
341 inline void nsTableRowFrame::SetFirstInserted(PRBool aValue
)
343 mBits
.mFirstInserted
= aValue
;
346 inline PRBool
nsTableRowFrame::HasStyleHeight() const
348 return (PRBool
)mBits
.mHasFixedHeight
|| (PRBool
)mBits
.mHasPctHeight
;
351 inline PRBool
nsTableRowFrame::HasFixedHeight() const
353 return (PRBool
)mBits
.mHasFixedHeight
;
356 inline void nsTableRowFrame::SetHasFixedHeight(PRBool aValue
)
358 mBits
.mHasFixedHeight
= aValue
;
361 inline PRBool
nsTableRowFrame::HasPctHeight() const
363 return (PRBool
)mBits
.mHasPctHeight
;
366 inline void nsTableRowFrame::SetHasPctHeight(PRBool aValue
)
368 mBits
.mHasPctHeight
= aValue
;
371 inline nscoord
nsTableRowFrame::GetContentHeight() const
373 return mContentHeight
;
376 inline void nsTableRowFrame::SetContentHeight(nscoord aValue
)
378 mContentHeight
= aValue
;
381 inline nscoord
nsTableRowFrame::GetFixedHeight() const
383 if (mBits
.mHasFixedHeight
)
384 return mStyleFixedHeight
;
389 inline float nsTableRowFrame::GetPctHeight() const
391 if (mBits
.mHasPctHeight
)
392 return (float)mStylePctHeight
/ 100.0f
;
397 inline PRBool
nsTableRowFrame::HasUnpaginatedHeight()
399 return (mState
& NS_TABLE_ROW_HAS_UNPAGINATED_HEIGHT
) ==
400 NS_TABLE_ROW_HAS_UNPAGINATED_HEIGHT
;
403 inline void nsTableRowFrame::SetHasUnpaginatedHeight(PRBool aValue
)
406 mState
|= NS_TABLE_ROW_HAS_UNPAGINATED_HEIGHT
;
408 mState
&= ~NS_TABLE_ROW_HAS_UNPAGINATED_HEIGHT
;
412 inline nscoord
nsTableRowFrame::GetTopBCBorderWidth()
414 return mTopBorderWidth
;
417 inline void nsTableRowFrame::SetTopBCBorderWidth(BCPixelSize aWidth
)
419 mTopBorderWidth
= aWidth
;
422 inline nscoord
nsTableRowFrame::GetBottomBCBorderWidth()
424 return mBottomBorderWidth
;
427 inline void nsTableRowFrame::SetBottomBCBorderWidth(BCPixelSize aWidth
)
429 mBottomBorderWidth
= aWidth
;
432 inline nsMargin
* nsTableRowFrame::GetBCBorderWidth(nsMargin
& aBorder
)
434 aBorder
.left
= aBorder
.right
= 0;
436 aBorder
.top
= nsPresContext::CSSPixelsToAppUnits(mTopBorderWidth
);
437 aBorder
.bottom
= nsPresContext::CSSPixelsToAppUnits(mBottomBorderWidth
);
443 nsTableRowFrame::GetContinuousBCBorderWidth(nsMargin
& aBorder
)
445 PRInt32 aPixelsToTwips
= nsPresContext::AppUnitsPerCSSPixel();
446 aBorder
.right
= BC_BORDER_LEFT_HALF_COORD(aPixelsToTwips
,
447 mLeftContBorderWidth
);
448 aBorder
.top
= BC_BORDER_BOTTOM_HALF_COORD(aPixelsToTwips
,
449 mTopContBorderWidth
);
450 aBorder
.left
= BC_BORDER_RIGHT_HALF_COORD(aPixelsToTwips
,
451 mRightContBorderWidth
);
454 inline nscoord
nsTableRowFrame::GetOuterTopContBCBorderWidth()
456 PRInt32 aPixelsToTwips
= nsPresContext::AppUnitsPerCSSPixel();
457 return BC_BORDER_TOP_HALF_COORD(aPixelsToTwips
, mTopContBorderWidth
);