mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-07 11:56:51 +00:00
261 lines
12 KiB
C++
261 lines
12 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: NPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Netscape Public License
|
|
* Version 1.1 (the "License"); you may not use this file except in
|
|
* compliance with the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/NPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is mozilla.org code.
|
|
*
|
|
* The Initial Developer of the Original Code is
|
|
* Netscape Communications Corporation.
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
* buster@netscape.com
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the NPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the NPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
#ifndef BasicTableLayoutStrategy_h__
|
|
#define BasicTableLayoutStrategy_h__
|
|
|
|
#include "nscore.h"
|
|
#include "nsITableLayoutStrategy.h"
|
|
#include "nsCoord.h"
|
|
|
|
class nsVoidArray;
|
|
class nsTableFrame;
|
|
struct nsStylePosition;
|
|
struct nsStyleTable;
|
|
|
|
static const PRInt32 kUninitialized=-1;
|
|
|
|
/* ---------- BasicTableLayoutStrategy ---------- */
|
|
|
|
/** Implementation of Nav4 compatible HTML browser table layout.
|
|
* The input to this class is the results from pass1 table layout.
|
|
* The output from this class is to set the column widths in
|
|
* mTableFrame.
|
|
*/
|
|
class BasicTableLayoutStrategy : public nsITableLayoutStrategy
|
|
{
|
|
public:
|
|
|
|
/** Public constructor.
|
|
* @paran aFrame - the table frame for which this delegate will do layout
|
|
* @param aIsNavQuirksMode - honor NN4x table quirks
|
|
*/
|
|
BasicTableLayoutStrategy(nsTableFrame *aFrame,
|
|
PRBool aIsNavQuirksMode = PR_TRUE);
|
|
|
|
/** destructor */
|
|
virtual ~BasicTableLayoutStrategy();
|
|
|
|
/** call every time any table thing changes that might effect the width of any column
|
|
* in the table (content, structure, or style)
|
|
* @param aPresContext - the presentation context
|
|
* @param aReflowState - the reflow state for mTableFrame
|
|
*/
|
|
virtual PRBool Initialize(nsIPresContext* aPresContext,
|
|
const nsHTMLReflowState& aReflowState);
|
|
|
|
/** Called during resize reflow to determine the new column widths
|
|
* @param aPresContext - the presentation context
|
|
* @param aReflowState - the reflow state for mTableFrame
|
|
*/
|
|
virtual PRBool BalanceColumnWidths(nsIPresContext* aPresContext,
|
|
const nsHTMLReflowState& aReflowState);
|
|
|
|
/**
|
|
* Calculate the basis for percent width calculations of the table elements
|
|
* @param aReflowState - the reflow state of the table
|
|
* @param aAvailWidth - the available width for the table
|
|
* @param aPixelToTwips - the number of twips in a pixel.
|
|
* @return - the basis for percent calculations
|
|
*/
|
|
virtual nscoord CalcPctAdjTableWidth(const nsHTMLReflowState& aReflowState,
|
|
nscoord aAvailWidth,
|
|
float aPixelToTwips);
|
|
void Dump(PRInt32 aIndent);
|
|
|
|
protected:
|
|
|
|
/** assign widths for each column.
|
|
* if the column has a fixed coord width, use it.
|
|
* if the column includes col spanning cells,
|
|
* then distribute the fixed space between cells proportionately.
|
|
* Computes the minimum and maximum table widths.
|
|
* Set column width information in each column frame and in the table frame.
|
|
*
|
|
* @param aMaxWidth - the computed width of the table or
|
|
* UNCONSTRAINED_SIZE if an auto width table
|
|
* @return PR_TRUE has a pct cell or col, PR_FALSE otherwise
|
|
*/
|
|
virtual PRBool AssignNonPctColumnWidths(nsIPresContext* aPresContext,
|
|
nscoord aComputedWidth,
|
|
const nsHTMLReflowState& aReflowState,
|
|
float aPixelToTwips);
|
|
|
|
/**
|
|
* Calculate the adjusted widths (min, desired, fixed, or pct) for a cell
|
|
* spanning multiple columns.
|
|
* @param aReflowState - the reflow state of the table
|
|
* @param aConsiderPct - if true, consider columns that have pct widths and are spanned by the cell
|
|
* @param aPixelToTwips- the number of twips in a pixel.
|
|
* @param aHasPctCol - if not null, then set *aHasPctCol to true if there is a pct cell or col
|
|
*/
|
|
void ComputeNonPctColspanWidths(const nsHTMLReflowState& aReflowState,
|
|
PRBool aConsiderPct,
|
|
float aPixelToTwips,
|
|
PRBool* aHasPctCol);
|
|
|
|
/**
|
|
* main helper for above. For min width calculations, it can get called up to
|
|
* 3 times, 1st to let constrained pct cols reach their limit, 2nd
|
|
* to let fix cols reach their limit and 3rd to spread any remainder among
|
|
* auto cols. If there are no auto cols then only constrained cols are considered.
|
|
* @param aWidthIndex - the width to calculate (see nsTableColFrame.h for enums)
|
|
* @param aCellFrame - the frame of the cell with a colspan
|
|
* @param aCellWidth - the width of the cell with a colspan
|
|
* @param aColIndex - the column index of the cell in the table
|
|
* @param aColSpan - the colspan of the cell
|
|
* @param aLimitType - the type of limit (ie. pct, fix, none).
|
|
* @param aPixelToTwips- the number of twips in a pixel.
|
|
* @return - true if all of aCellWidth was allocated, false otherwise
|
|
*/
|
|
PRBool ComputeNonPctColspanWidths(PRInt32 aWidthIndex,
|
|
nsTableCellFrame* aCellFrame,
|
|
PRInt32 aCellWidth,
|
|
PRInt32 aColIndex,
|
|
PRInt32 aColSpan,
|
|
PRInt32& aLimitType,
|
|
float aPixelToTwips);
|
|
|
|
/**
|
|
* Determine percentage col widths for each col frame
|
|
* @param aReflowState - the reflow state of the table
|
|
* @param aBasis - the basis for percent width as computed by CalcPctAdjTableWidth
|
|
* @param aTableIsAutoWidth - true if no width specification for the table is available
|
|
* @param aPixelToTwips - the number of twips in a pixel.
|
|
* @return - the adjusted basis including table border, padding and cell spacing
|
|
*/
|
|
nscoord AssignPctColumnWidths(const nsHTMLReflowState& aReflowState,
|
|
nscoord aBasis,
|
|
PRBool aTableIsAutoWidth,
|
|
float aPixelToTwips);
|
|
|
|
/**
|
|
* Reduce the percent columns by the amount specified in aExcess as the percent width's
|
|
* can accumulate to be over 100%
|
|
* @param aExcess - reduction amount
|
|
*/
|
|
void ReduceOverSpecifiedPctCols(nscoord aExcess);
|
|
|
|
/**
|
|
* Sort rows by rising colspans, in order to treat the inner colspans first
|
|
* the result will be returned in the aRowIndices array.
|
|
* @param aRowIndices - array with indices of those rows which have colspans starting in the corresponding column
|
|
* @param aColSpans - array with the correspong colspan values
|
|
* @param aIndex - number of valid entries in the arrays
|
|
*/
|
|
void RowSort(PRInt32* aRowIndices,
|
|
PRInt32* aColSpans,
|
|
PRInt32 aIndex);
|
|
|
|
/**
|
|
* calculate totals by width type. The logic here is kept in synch with
|
|
* that in CanAllocate
|
|
* @param aTotalCounts - array with counts for each width type that has determined the aTotalWidths sum
|
|
* @param aTotalWidths - array with accumulated widths for each width type
|
|
* @param aDupedWidths - (duplicatd) are widths that will be allocated in BalanceColumnWidths before aTotalsWidths
|
|
* @param a0ProportionalCount - number of columns with col="0*" constraint
|
|
*/
|
|
void CalculateTotals(PRInt32* aTotalCounts,
|
|
PRInt32* aTotalWidths,
|
|
PRInt32* aDupedWidths,
|
|
PRInt32& a0ProportionalCount);
|
|
|
|
/**
|
|
* Allocate aWidthType values to the corresponding columns
|
|
* @param aTotalAllocated - width that has been allocated in this routine
|
|
* @param aAllocTypes - width type that has determined col width
|
|
* @param aWidthType - width type selecting the columns for full width allocation
|
|
*/
|
|
void AllocateFully(nscoord& aTotalAllocated,
|
|
PRInt32* aAllocTypes,
|
|
PRInt32 aWidthType);
|
|
|
|
/**
|
|
* Allocate aWidthType values to the corresponding columns up to the aAvailWidth
|
|
* @param aAvailWidth - width that can distributed to the selected columns
|
|
* @param aWidthType - width type selecting the columns for width allocation
|
|
* @param aStartAtMin - allocation should start at min. content width
|
|
* @param aAllocTypes - width type that has determined col width
|
|
* @param aPixelToTwips - the number of twips in a pixel.
|
|
*/
|
|
void AllocateConstrained(PRInt32 aAvailWidth,
|
|
PRInt32 aWidthType,
|
|
PRBool aStartAtMin,
|
|
PRInt32* aAllocTypes,
|
|
float aPixelToTwips);
|
|
|
|
/**
|
|
* Give the remaining space and exclude the selected columns
|
|
* @param aAllocAmount - space that can be distributed
|
|
* @param aAllocTypes - width type that has determined col width
|
|
* @param aExcludePct - dont give space to percent columns
|
|
* @param aExcludeFix - dont give space to fixed width columns
|
|
* @param aExcludePro - dont give space to proportional columns
|
|
* @param aExclude0Pro - dont give space to proportional columns with 0*
|
|
* @param aPixelToTwips - the number of twips in a pixel.
|
|
*/
|
|
void AllocateUnconstrained(PRInt32 aAllocAmount,
|
|
PRInt32* aAllocTypes,
|
|
PRBool aExcludePct,
|
|
PRBool aExcludeFix,
|
|
PRBool aExcludePro,
|
|
PRBool aExclude0Pro,
|
|
float aPixelToTwips);
|
|
|
|
/**
|
|
* Check in debug mode whether the routine is called on a continuing frame
|
|
*/
|
|
void ContinuingFrameCheck();
|
|
|
|
#ifdef DEBUG
|
|
void SizeOf(nsISizeOfHandler* aSizer, PRUint32* aResult) const {
|
|
*aResult = sizeof(*this);
|
|
}
|
|
#endif
|
|
|
|
protected:
|
|
nsTableFrame * mTableFrame;
|
|
PRInt32 mCols;
|
|
// cached data
|
|
nscoord mCellSpacingTotal; // all of the cellspacing for all of the cols
|
|
float mMinToDesProportionRatio;
|
|
PRPackedBool mIsNavQuirksMode;
|
|
};
|
|
#endif
|
|
|