summaryrefslogtreecommitdiff
path: root/svx/source/table/tablelayouter.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'svx/source/table/tablelayouter.hxx')
-rw-r--r--svx/source/table/tablelayouter.hxx178
1 files changed, 178 insertions, 0 deletions
diff --git a/svx/source/table/tablelayouter.hxx b/svx/source/table/tablelayouter.hxx
new file mode 100644
index 000000000000..9c56aafb556f
--- /dev/null
+++ b/svx/source/table/tablelayouter.hxx
@@ -0,0 +1,178 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+#ifndef _SVX_TABLE_TABLELAYOUTER_HXX_
+#define _SVX_TABLE_TABLELAYOUTER_HXX_
+
+#include <com/sun/star/container/XIndexAccess.hpp>
+#include <com/sun/star/text/WritingMode.hpp>
+#include <com/sun/star/table/XTable.hpp>
+#include <basegfx/range/b2irectangle.hxx>
+#include <basegfx/tuple/b2ituple.hxx>
+#include <tools/gen.hxx>
+#include <boost/shared_ptr.hpp>
+#include <vector>
+#include <map>
+
+#include "svx/svdotable.hxx"
+
+// -----------------------------------------------------------------------------
+
+class SvxBorderLine;
+
+namespace sdr { namespace table {
+
+/** returns true if the cell(nMergedCol,nMergedRow) is merged with other cells.
+ the returned cell( rOriginCol, rOriginRow ) is the origin( top left cell ) of the merge.
+*/
+bool findMergeOrigin( const TableModelRef& xTable, sal_Int32 nMergedCol, sal_Int32 nMergedRow, sal_Int32& rOriginCol, sal_Int32& rOriginRow );
+
+typedef std::vector< SvxBorderLine* > BorderLineVector;
+typedef std::vector< BorderLineVector > BorderLineMap;
+
+// -----------------------------------------------------------------------------
+// TableModel
+// -----------------------------------------------------------------------------
+
+class TableLayouter
+{
+public:
+ TableLayouter( const TableModelRef& xTableModel );
+ virtual ~TableLayouter();
+
+ /** this checks if new rows are inserted or old rows where removed.
+ This can be used to grow or shrink the table shape in this case.
+ @returns
+ the height difference
+ sal_Int32 detectInsertedOrRemovedRows();
+ */
+
+ /** try to fit the table into the given rectangle.
+ If the rectangle is to small, it will be grown to fit the table.
+
+ if bFitWidth or bFitHeight is set, the layouter tries to scale
+ the rows and/or columns to the given area. The result my be bigger
+ to fullfill constrains.
+
+ if bFitWidth or bFitHeight is set, the model is changed.
+ */
+ void LayoutTable( ::Rectangle& rRectangle, bool bFitWidth, bool bFitHeight );
+
+ /** after a call to LayoutTable, this method can be used to set the new
+ column and row sizes back to the model. */
+// void SetLayoutToModel();
+
+ void UpdateBorderLayout();
+
+ basegfx::B2ITuple getCellSize( const CellPos& rPos ) const;
+ bool getCellArea( const CellRef& xCell, basegfx::B2IRectangle& rArea ) const;
+ bool getCellArea( const CellPos& rPos, basegfx::B2IRectangle& rArea ) const;
+
+ ::sal_Int32 getRowCount() const { return static_cast< ::sal_Int32 >( maRows.size() ); }
+ ::sal_Int32 getColumnCount() const { return static_cast< ::sal_Int32 >( maColumns.size() ); }
+
+ sal_Int32 getRowHeight( sal_Int32 nRow );
+
+ // sets the layout height of the given row hard, LayoutTable must be called directly after calling this method! */
+ void setRowHeight( sal_Int32 nRow, sal_Int32 nHeight );
+
+ sal_Int32 getColumnWidth( sal_Int32 nColumn );
+
+ // sets the layout width of the given column hard, LayoutTable must be called directly after calling this method! */
+ void setColumnWidth( sal_Int32 nColumn, sal_Int32 nWidth );
+
+ sal_Int32 getMinimumColumnWidth( sal_Int32 nColumn );
+
+ sal_Int32 getColumnStart( sal_Int32 nColumn ) const;
+ sal_Int32 getRowStart( sal_Int32 nRow ) const;
+
+ /** checks if the given edge is visible.
+ Edges between merged cells are not visible.
+ */
+ bool isEdgeVisible( sal_Int32 nEdgeX, sal_Int32 nEdgeY, bool bHorizontal ) const;
+
+ /** returns the requested borderline in rpBorderLine or a null pointer if there is no border at this edge */
+ SvxBorderLine* getBorderLine( sal_Int32 nEdgeX, sal_Int32 nEdgeY, bool bHorizontal )const;
+
+ void updateCells( ::Rectangle& rRectangle );
+
+ sal_Int32 getHorizontalEdge( int nEdgeY, sal_Int32* pnMin = 0, sal_Int32* pnMax = 0 );
+ sal_Int32 getVerticalEdge( int nEdgeX , sal_Int32* pnMin = 0, sal_Int32* pnMax = 0);
+
+ void DistributeColumns( ::Rectangle& rArea, sal_Int32 nFirstCol, sal_Int32 nLastCol );
+ void DistributeRows( ::Rectangle& rArea, sal_Int32 nFirstRow, sal_Int32 nLastRow );
+
+ com::sun::star::text::WritingMode GetWritingMode() const { return meWritingMode; }
+ void SetWritingMode( com::sun::star::text::WritingMode eWritingMode );
+
+private:
+ CellRef getCell( const CellPos& rPos ) const;
+
+ void LayoutTableWidth( ::Rectangle& rArea, bool bFit );
+ void LayoutTableHeight( ::Rectangle& rArea, bool bFit );
+
+ inline bool isValidColumn( sal_Int32 nColumn ) const { return (nColumn >= 0) && (nColumn < static_cast<sal_Int32>( maColumns.size())); }
+ inline bool isValidRow( sal_Int32 nRow ) const { return (nRow >= 0) && (nRow < static_cast<sal_Int32>( maRows.size())); }
+ inline bool isValid( const CellPos& rPos ) const { return isValidColumn( rPos.mnCol ) && isValidRow( rPos.mnRow ); }
+
+ void ClearBorderLayout();
+ void ClearBorderLayout(BorderLineMap& rMap);
+ void ResizeBorderLayout();
+ void ResizeBorderLayout( BorderLineMap& rMap );
+
+ void SetBorder( sal_Int32 nCol, sal_Int32 nRow, bool bHorizontal, const SvxBorderLine* pLine );
+
+ static bool HasPriority( const SvxBorderLine* pThis, const SvxBorderLine* pOther );
+
+ struct Layout
+ {
+ sal_Int32 mnPos;
+ sal_Int32 mnSize;
+ sal_Int32 mnMinSize;
+
+ Layout() : mnPos( 0 ), mnSize( 0 ), mnMinSize( 0 ) {}
+ void clear() { mnPos = 0; mnSize = 0; mnMinSize = 0; }
+ };
+ typedef std::vector< Layout > LayoutVector;
+
+ sal_Int32 distribute( LayoutVector& rLayouts, sal_Int32 nDistribute );
+
+ TableModelRef mxTable;
+ LayoutVector maRows;
+ LayoutVector maColumns;
+
+ BorderLineMap maHorizontalBorders;
+ BorderLineMap maVerticalBorders;
+
+ com::sun::star::text::WritingMode meWritingMode;
+
+ const rtl::OUString msSize;
+};
+
+} }
+
+#endif