1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*************************************************************************
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
10 * Sun Microsystems Inc., October, 2000
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
46 * The Initial Developer of the Original Code is: IBM Corporation
48 * Copyright: 2008 by IBM Corporation
50 * All Rights Reserved.
52 * Contributor(s): _______________________________________
55 ************************************************************************/
58 * For LWP filter architecture prototype - cell layouts
60 /*************************************************************************
63 ************************************************************************/
64 #include "lwpcelllayout.hxx"
65 #include "lwpfoundry.hxx"
66 #include "lwpobjfactory.hxx"
67 #include "lwptblcell.hxx"
68 #include "lwptblformula.hxx"
69 #include "lwpholder.hxx"
70 #include "lwpnumericfmt.hxx"
71 #include "lwptable.hxx"
72 #include "lwpglobalmgr.hxx"
74 #include "xfilter/xfstylemanager.hxx"
75 #include "xfilter/xfcell.hxx"
76 #include "xfilter/xfcellstyle.hxx"
77 #include "xfilter/xfcolstyle.hxx"
79 LwpCellLayout::LwpCellLayout(LwpObjectHeader
&objHdr
, LwpSvStream
* pStrm
)
80 : LwpMiddleLayout(objHdr
, pStrm
)
84 LwpCellLayout::~LwpCellLayout()
88 * @short Get table layout pointer, if default cell layout, return NULL
89 * @param LwpTableLayout *
92 LwpTableLayout
* LwpCellLayout::GetTableLayout()
94 LwpRowLayout
* pRow
= dynamic_cast<LwpRowLayout
*>(GetParent()->obj());
99 LwpTableLayout
* pTableLayout
= pRow
->GetParentTableLayout();
103 * @short Get table pointer, if default cell layout, return NULL
107 LwpTable
* LwpCellLayout::GetTable()
109 LwpTableLayout
* pTableLayout
= GetTableLayout();
114 LwpTable
*pTable
= pTableLayout
->GetTable();
118 * @short Set current cell layout to cell layout map
122 void LwpCellLayout::SetCellMap()
124 // this function is called from LwpTableLayout, so it can't be NULL
125 GetTableLayout()->SetWordProCellMap(crowid
, ccolid
, this);
128 * @short Get actual width of this cell layout
132 double LwpCellLayout::GetActualWidth()
135 LwpTableLayout
* pTableLayout
= GetTableLayout();
137 if (pTableLayout
== NULL
)
139 return GetGeometryWidth();
142 OUString strColStyle
= pTableLayout
->GetColumnWidth(ccolid
);
144 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
145 XFColStyle
*pStyle
= static_cast<XFColStyle
*>(pXFStyleManager
->FindStyle(strColStyle
));
148 return pStyle
->GetWidth();
151 return GetGeometryWidth();
155 * @short Apply padding to cell style
156 * @param pCellStyle - pointer of XFCellStyle
159 void LwpCellLayout::ApplyPadding(XFCellStyle
*pCellStyle
)
161 double fLeft
= GetMarginsValue(MARGIN_LEFT
);
162 double fRight
= GetMarginsValue(MARGIN_RIGHT
);
163 double fTop
= GetMarginsValue(MARGIN_TOP
);
164 double fBottom
= GetMarginsValue(MARGIN_BOTTOM
);
165 pCellStyle
->SetPadding((float)fLeft
,(float)fRight
,(float)fTop
,(float)fBottom
);
168 * @short Apply border to cell style according to cell position, default cell layout won't use this function
170 * @return pCellStyle - pointer of XFCellStyle
172 void LwpCellLayout::ApplyBorders(XFCellStyle
*pCellStyle
)
174 // judge cell border type
175 LwpCellBorderType eType
= GetCellBorderType(crowid
, ccolid
, GetTableLayout());
177 // get left cell and judge if neighbour border is different
178 XFBorders
* pBorders
= GetXFBorders();
186 case enumNoBottomBorder
:
187 pBorders
->SetWidth(enumXFBorderBottom
, 0);
189 case enumNoLeftBorder
:
190 pBorders
->SetWidth(enumXFBorderLeft
, 0);
192 case enumNoLeftNoBottomBorder
:
193 pBorders
->SetWidth(enumXFBorderBottom
, 0);
194 pBorders
->SetWidth(enumXFBorderLeft
, 0);
196 case enumWholeBorder
:
201 pCellStyle
->SetBorders(pBorders
);
204 * @short Apply watermark to cell style
205 * @param pCellStyle - pointer of XFCellStyle
208 void LwpCellLayout::ApplyWatermark(XFCellStyle
*pCellStyle
)
210 XFBGImage
* pBGImage
= GetXFBGImage();
213 pCellStyle
->SetBackImage(pBGImage
);
218 * @short Apply pattern fill to cell style
219 * @param pCellStyle - pointer of XFCellStyle
222 void LwpCellLayout::ApplyPatternFill(XFCellStyle
* pCellStyle
)
224 XFBGImage
* pXFBGImage
= this->GetFillPattern();
227 pCellStyle
->SetBackImage(pXFBGImage
);
232 * @short Apply background to cell style
233 * @param pCellStyle - pointer of XFCellStyle
236 void LwpCellLayout::ApplyBackGround(XFCellStyle
* pCellStyle
)
238 if (this->IsPatternFill())
240 ApplyPatternFill(pCellStyle
);
244 ApplyBackColor(pCellStyle
);
248 * @short Apply back color to cell style
249 * @param pCellStyle - pointer of XFCellStyle
252 void LwpCellLayout::ApplyBackColor(XFCellStyle
*pCellStyle
)
254 LwpColor
* pColor
= GetBackColor();
255 if(pColor
&& pColor
->IsValidColor())
257 XFColor
aXFColor(pColor
->To24Color());
258 pCellStyle
->SetBackColor(aXFColor
);
262 * @short register style of cell layout
263 * @param pCellStyle The style of the cell, which would be applied to the cell.
266 void LwpCellLayout::ApplyFmtStyle(XFCellStyle
*pCellStyle
)
268 LwpLayoutNumerics
* pLayoutNumerics
= dynamic_cast<LwpLayoutNumerics
*>(cLayNumerics
.obj());
269 if (!pLayoutNumerics
)
271 // if current layout doesn't have format, go to based on layout
272 LwpCellLayout
* pCellLayout
= dynamic_cast<LwpCellLayout
*>(m_BasedOnStyle
.obj());
275 pLayoutNumerics
= dynamic_cast<LwpLayoutNumerics
*>(pCellLayout
->GetNumericsObject()->obj());
279 // apply format style
282 XFStyle
* pStyle
= pLayoutNumerics
->Convert();
285 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
286 m_NumfmtName
= pXFStyleManager
->AddStyle(pStyle
)->GetStyleName();
287 pCellStyle
->SetDataStyle(m_NumfmtName
);
294 * @short get style name according to cell position, only table default cells use this function
295 * @param nRow - default cell position row number
296 * @param nCol - default cell position col number
297 * @return OUString - registered cell style name
299 OUString
LwpCellLayout::GetCellStyleName(sal_uInt16 nRow
, sal_uInt16 nCol
, LwpTableLayout
* pTableLayout
)
301 // judge cell border type
302 LwpCellBorderType eType
= GetCellBorderType(nRow
, nCol
, pTableLayout
);
303 return m_CellStyleNames
[eType
];
308 * @param aTableID - ID of the table which this cell belongs to
309 * @param bIsTopRow - whether current cell is top row
310 * @param bIsRightCol - whether current cell is the rightest column
313 XFCell
* LwpCellLayout::ConvertCell(LwpObjectID aTableID
, sal_uInt16 nRow
, sal_uInt16 nCol
)
315 // if cell layout is aTableID's default cell layout
316 // it can't have any content, bypass these code
317 LwpTable
* pTable
= dynamic_cast<LwpTable
*>(aTableID
.obj());
323 XFCell
* pXFCell
= new XFCell();
324 OUString aStyleName
= m_StyleName
;
326 // if cell layout is aTableID's default cell layout
327 // we should judt its style by current positon
328 if (*pTable
->GetDefaultCellStyle() == *GetObjectID())
330 aStyleName
= GetCellStyleName(nRow
, nCol
, pTable
->GetTableLayout());
334 LwpStory
* pStory
= dynamic_cast<LwpStory
*>(m_Content
.obj());
337 pStory
->XFConvert(pXFCell
);
340 ApplyProtect(pXFCell
, aTableID
);
341 pXFCell
->SetStyleName(aStyleName
);
345 LwpPara
* LwpCellLayout::GetLastParaOfPreviousStory()
347 LwpObjectID
* pPreStoryID
= this->GetPreviousCellStory();
348 if (pPreStoryID
&& !(pPreStoryID
->IsNull()))
350 LwpStory
* pPreStory
= dynamic_cast<LwpStory
*>(pPreStoryID
->obj(VO_STORY
));
351 return dynamic_cast<LwpPara
*>(pPreStory
->GetLastPara()->obj(VO_PARA
));
360 * @short Get previous cell which used for bullet inside cell
362 * @return LwpObjectID * - object ID of cell content story
364 LwpObjectID
* LwpCellLayout::GetPreviousCellStory()
366 LwpTable
*pTable
= GetTable();
372 sal_uInt16 nRow
= crowid
;
373 sal_uInt16 nCol
= ccolid
;
375 // if table is reset paragraph in columns, get cell on the top side of current cell
376 if (pTable
->IsNumberDown())
386 // if not, get cell on the left side of current cell
396 nCol
= pTable
->GetColumn() - 1;
405 // get the object id pointer of previous cell story
406 LwpTableLayout
* pTableLayout
= GetTableLayout();
412 return pTableLayout
->SearchCellStoryMap(nRow
, nCol
);
416 * @short judge border type by cell neighbour
419 * @param pTableLayout
420 * @return LwpCellBorderType
422 LwpCellBorderType
LwpCellLayout::GetCellBorderType(sal_uInt16 nRow
, sal_uInt16 nCol
, LwpTableLayout
* pTableLayout
)
427 return enumWholeBorder
;
430 // get left cell and judge if neighbour border is different
431 XFBorders
* pBorders
= GetXFBorders();
434 return enumWholeBorder
;
436 XFBorder
*pLeftBorder
= pBorders
->GetLeft();
437 XFBorder
*pBottomBorder
= pBorders
->GetBottom();
438 sal_Bool bNoLeftBorder
= sal_False
;
439 sal_Bool bNoBottomBorder
= sal_False
;
441 LwpCellLayout
* pLeftNeighbour
= GetCellByRowCol(nRow
, GetLeftColID(nCol
), pTableLayout
);
444 XFBorders
* pNeighbourBorders
= pLeftNeighbour
->GetXFBorders();
445 if (pNeighbourBorders
)
447 XFBorder
* pRightBorder
= pNeighbourBorders
->GetRight();
448 if (*pLeftBorder
== *pRightBorder
)
450 // for these 2 types cell, left border should be ignored for sake of avoiding duplication border
451 // but if left border is different with right border of left cell
452 // we should not ignored it
453 bNoLeftBorder
= sal_True
;
455 delete pNeighbourBorders
;
460 LwpCellLayout
* pBelowNeighbour
= GetCellByRowCol(GetBelowRowID(nRow
), nCol
, pTableLayout
);
461 if (pBelowNeighbour
) //&& (eType == enumRightNotLastCellBorder || eType == enumLeftNotLastCellBorder) )
463 XFBorders
* pBelowBorders
= pBelowNeighbour
->GetXFBorders();
466 XFBorder
* pTopBorder
= pBelowBorders
->GetTop();
467 if (*pTopBorder
== *pBottomBorder
)
469 // for these 2 types cell, bottom border should be ignored for sake of avoiding duplication border
470 // but if bottom border is different with right border of left cell
471 // we should not ignored it
472 bNoBottomBorder
= sal_True
;
474 delete pBelowBorders
;
484 return enumNoLeftNoBottomBorder
;
486 return enumNoBottomBorder
;
490 return enumNoLeftBorder
;
492 return enumWholeBorder
;
496 * @short Get neighbour cell by specifying ROW+COL
499 * @return LwpCellLayout *
501 LwpCellLayout
* LwpCellLayout::GetCellByRowCol(sal_uInt16 nRow
, sal_uInt16 nCol
, LwpTableLayout
* pTableLayout
)
503 return pTableLayout
->GetCellByRowCol(nRow
, nCol
);
506 * @short Register table's default cell layout
510 void LwpCellLayout::RegisterDefaultCell()
512 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
513 for (sal_uInt16 eLoop
= enumWholeBorder
; eLoop
< enumCellBorderTopLimit
; eLoop
++)
515 // register cell style
516 XFCellStyle
*pCellStyle
= new XFCellStyle();
518 ApplyPadding(pCellStyle
);
519 ApplyBackColor(pCellStyle
);
520 ApplyWatermark(pCellStyle
);
521 ApplyFmtStyle(pCellStyle
);
522 pCellStyle
->SetAlignType(enumXFAlignNone
, GetVerticalAlignmentType());
524 XFBorders
* pBorders
= GetXFBorders();
529 case enumNoBottomBorder
:
533 // remove bottom line
534 pBorders
->SetWidth(enumXFBorderBottom
, 0);
536 case enumNoLeftNoBottomBorder
:
540 // remove left and bottom
541 pBorders
->SetWidth(enumXFBorderLeft
, 0);
542 pBorders
->SetWidth(enumXFBorderBottom
, 0);
544 case enumWholeBorder
:
550 case enumNoLeftBorder
:
555 pBorders
->SetWidth(enumXFBorderLeft
, 0);
560 pCellStyle
->SetBorders(pBorders
);
562 m_CellStyleNames
[eLoop
] = pXFStyleManager
->AddStyle(pCellStyle
)->GetStyleName();
566 * @short Register 4 types of cell style and register content styles
572 void LwpCellLayout::RegisterStyle()
574 LwpVirtualLayout
* pParent
= dynamic_cast<LwpVirtualLayout
*>(GetParent()->obj());
575 if (!pParent
|| pParent
->GetLayoutType() != LWP_ROW_LAYOUT
)
577 // default cell layout, we must register 4 styles for it
578 RegisterDefaultCell();
582 // register cell style
583 XFCellStyle
*pCellStyle
= new XFCellStyle();
585 ApplyPadding(pCellStyle
);
586 // ApplyBackColor(pCellStyle);
587 ApplyBackGround(pCellStyle
);
588 ApplyWatermark(pCellStyle
);
589 ApplyFmtStyle(pCellStyle
);
590 ApplyBorders(pCellStyle
);
592 pCellStyle
->SetAlignType(enumXFAlignNone
, GetVerticalAlignmentType());
594 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
595 m_StyleName
= pXFStyleManager
->AddStyle(pCellStyle
)->GetStyleName();
597 // content object register styles
598 LwpObject
* pObj
= m_Content
.obj();
601 pObj
->SetFoundry(m_pFoundry
);
602 pObj
->RegisterStyle();
605 //register child layout style
606 RegisterChildStyle();
609 * @short Read cell layout
613 void LwpCellLayout::Read()
615 LwpObjectStream
* pStrm
= m_pObjStrm
;
617 LwpMiddleLayout::Read();
619 // before the layout hierarchy rework
620 if (LwpFileHeader::m_nFileRevision
< 0x000b)
626 crowid
= pStrm
->QuickReaduInt16();
627 ccolid
= (sal_uInt8
) pStrm
->QuickReaduInt16(); // written as a lushort
631 type
= pStrm
->QuickReaduInt16();
633 cType
= (LeaderDotType
)type
;
635 cLayNumerics
.ReadIndexed(pStrm
);
636 cLayDiagonalLine
.ReadIndexed(pStrm
);
643 * Apply protect attribute to cell of table
645 * @param aTableID - ID of the table which the cell belongs to
649 void LwpCellLayout::ApplyProtect(XFCell
* pCell
, LwpObjectID aTableID
)
651 sal_Bool bProtected
= sal_False
;
652 // judge current cell
655 bProtected
= sal_True
;
660 LwpCellLayout
* pBase
= dynamic_cast<LwpCellLayout
*>(m_BasedOnStyle
.obj());
661 if (pBase
&& pBase
->IsProtected())
663 bProtected
= sal_True
;
668 LwpTable
* pTable
= dynamic_cast<LwpTable
*>(aTableID
.obj());
669 LwpTableLayout
* pTableLayout
= static_cast<LwpTableLayout
*>(pTable
->GetTableLayout());
670 LwpSuperTableLayout
* pSuper
= pTableLayout
->GetSuperTableLayout();
671 if (pSuper
&& pSuper
->IsProtected())
673 bProtected
= sal_True
;
678 pCell
->SetProtect(bProtected
);
682 LwpConnectedCellLayout::LwpConnectedCellLayout(LwpObjectHeader
&objHdr
, LwpSvStream
* pStrm
)
683 : LwpCellLayout(objHdr
, pStrm
)
686 LwpConnectedCellLayout::~LwpConnectedCellLayout()
689 * @short Set current connected cell layout to cell layout map
690 * @param pCellLayoutMap - cell layout map reference
693 void LwpConnectedCellLayout::SetCellMap()
695 // this function is called from LwpTableLayout, so it can't be NULL
696 LwpTableLayout
* pTableLayout
= GetTableLayout();
697 sal_uInt16 nRowSpan
= m_nRealrowspan
;
699 for (sal_uInt16 iLoop
= 0; iLoop
< nRowSpan
; iLoop
++)
701 for (sal_uInt16 jLoop
= 0; jLoop
< cnumcols
; jLoop
++)
702 pTableLayout
->SetWordProCellMap(iLoop
+ crowid
, jLoop
+ ccolid
, this);
707 * @short judge border type by cell neighbour
710 * @param pTableLayout
711 * @return LwpCellBorderType
713 LwpCellBorderType
LwpConnectedCellLayout::GetCellBorderType(sal_uInt16 nRow
, sal_uInt16 nCol
, LwpTableLayout
* pTableLayout
)
718 return enumWholeBorder
;
721 sal_uInt16 nRowSpan
= m_nRealrowspan
;
723 // get left cell and judge if neighbour border is different
724 XFBorders
* pBorders
= GetXFBorders();
727 return enumWholeBorder
;
729 XFBorder
*pLeftBorder
= pBorders
->GetLeft();
730 XFBorder
*pBottomBorder
= pBorders
->GetBottom();
731 sal_Bool bNoLeftBorder
= sal_True
;
732 sal_Bool bNoBottomBorder
= sal_True
;
736 bNoLeftBorder
= sal_False
;
740 for (sal_uInt16 iLoop
=0; iLoop
< nRowSpan
; iLoop
++)
742 LwpCellLayout
* pLeftNeighbour
= GetCellByRowCol(nRow
+iLoop
, GetLeftColID(nCol
), pTableLayout
);
745 boost::scoped_ptr
<XFBorders
> pNeighbourBorders(pLeftNeighbour
->GetXFBorders());
746 if (pNeighbourBorders
)
748 XFBorder
* pRightBorder
= pNeighbourBorders
->GetRight();
749 if (*pLeftBorder
!= *pRightBorder
)
751 // if left border is different with right border of left cell
752 // we should not ignored it
753 bNoLeftBorder
= sal_False
;
761 if ( (nRow
+ nRowSpan
) == pTableLayout
->GetTable()->GetRow() )
763 bNoBottomBorder
= sal_False
;
767 for (sal_uInt16 iLoop
= 0; iLoop
< cnumcols
; iLoop
++)
769 LwpCellLayout
* pBelowNeighbour
= GetCellByRowCol(nRow
+ nRowSpan
, nCol
+iLoop
, pTableLayout
);
772 boost::scoped_ptr
<XFBorders
> pBelowBorders(pBelowNeighbour
->GetXFBorders());
775 XFBorder
* pTopBorder
= pBelowBorders
->GetTop();
776 if (*pTopBorder
!= *pBottomBorder
)
778 // if bottom border is different with right border of left cell
779 // we should not ignored it
780 bNoBottomBorder
= sal_False
;
793 return enumNoLeftNoBottomBorder
;
795 return enumNoBottomBorder
;
799 return enumNoLeftBorder
;
801 return enumWholeBorder
;
804 * @short Read connected cell layout
808 void LwpConnectedCellLayout::Read()
810 LwpCellLayout::Read();
813 cnumrows
= m_pObjStrm
->QuickReaduInt16();
814 numcols
= m_pObjStrm
->QuickReaduInt16(); // written as a lushort
815 cnumcols
= (sal_uInt8
)numcols
;
817 m_nRealrowspan
= cnumrows
;
818 m_nRealcolspan
= cnumcols
;
820 m_pObjStrm
->SkipExtra();
822 XFCell
* LwpConnectedCellLayout::ConvertCell(LwpObjectID aTableID
, sal_uInt16 nRow
, sal_uInt16 nCol
)
824 XFCell
* pXFCell
= LwpCellLayout::ConvertCell(aTableID
, nRow
, nCol
);
825 pXFCell
->SetColumnSpaned(cnumcols
);
832 * @short parse connected cell layout
833 * @param pOutputStream - output stream
836 void LwpConnectedCellLayout::Parse(IXFStream
* /*pOutputStream*/)
840 LwpHiddenCellLayout::LwpHiddenCellLayout(LwpObjectHeader
&objHdr
, LwpSvStream
* pStrm
)
841 : LwpCellLayout(objHdr
, pStrm
)
844 LwpHiddenCellLayout::~LwpHiddenCellLayout()
847 * @short Set current hidden cell layout to cell layout map
851 void LwpHiddenCellLayout::SetCellMap()
856 * @short Read hidden cell layout
860 void LwpHiddenCellLayout::Read()
862 LwpCellLayout::Read();
864 cconnectedlayout
.ReadIndexed(m_pObjStrm
);
865 m_pObjStrm
->SkipExtra();
869 * @short Convert hidden cell layout
870 * @param aTableID - Object ID of table
871 * @return XFCell * - pointer to converted cell
874 XFCell
* LwpHiddenCellLayout::ConvertCell(LwpObjectID aTableID
, sal_uInt16 nRow
, sal_uInt16 nCol
)
876 if (!cconnectedlayout
.obj())
878 LwpConnectedCellLayout
* pConnCell
= dynamic_cast<LwpConnectedCellLayout
* >(cconnectedlayout
.obj());
880 if (nRow
< (pConnCell
->GetNumrows()+pConnCell
->GetRowID()))
882 // if the hidden cell should be displayed for limit of SODC
883 // use the default cell layout
884 XFCell
* pXFCell
= NULL
;
885 LwpTable
*pTable
= dynamic_cast<LwpTable
*>(aTableID
.obj());
888 LwpCellLayout
*pDefault
= dynamic_cast<LwpCellLayout
*>(pTable
->GetDefaultCellStyle()->obj());
891 pXFCell
= pDefault
->ConvertCell(aTableID
, nRow
, nCol
);
895 pXFCell
= pConnCell
->ConvertCell(aTableID
, nRow
, nCol
);
897 pXFCell
->SetColumnSpaned(pConnCell
->GetNumcols());
906 * @short parse hidden cell layout
907 * @param pOutputStream - output stream
910 void LwpHiddenCellLayout::Parse(IXFStream
* /*pOutputStream*/)
915 LwpParallelColumnsBlock::LwpParallelColumnsBlock(LwpObjectHeader
&objHdr
, LwpSvStream
* pStrm
):LwpCellLayout(objHdr
, pStrm
)
918 LwpParallelColumnsBlock::~LwpParallelColumnsBlock()
921 void LwpParallelColumnsBlock::Read()
923 LwpCellLayout::Read();
924 m_pObjStrm
->SkipExtra();
927 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */