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 ************************************************************************/
56 /*************************************************************************
58 * Table cell style. Number format, string value, and so on...
59 ************************************************************************/
60 #ifndef INCLUDED_LOTUSWORDPRO_INC_XFILTER_XFCELLSTYLE_HXX
61 #define INCLUDED_LOTUSWORDPRO_INC_XFILTER_XFCELLSTYLE_HXX
63 #include <sal/config.h>
65 #include <rtl/ref.hxx>
67 #include <xfilter/xfstyle.hxx>
68 #include <xfilter/xfcolor.hxx>
69 #include <xfilter/xfmargins.hxx>
70 #include <xfilter/xfpadding.hxx>
71 #include <xfilter/xfshadow.hxx>
82 * @descr Style object for cell.
84 class XFCellStyle
: public XFStyle
89 virtual ~XFCellStyle() override
;
93 * @descr Set cell data format style name.
95 void SetDataStyle(const OUString
& style
);
98 * @descr: Set the padding of the paragraph.This is the distance
99 between the border and the top of the text.
100 * @param: indent value of the padding.
102 void SetPadding(double left
, double right
, double top
, double bottom
);
105 * @descr: Set alignment property of the cell.
106 * @param: eAlign alignment type,left,right,center or justify.
108 void SetAlignType(enumXFAlignType hori
, enumXFAlignType vert
);
111 * @descr: The borders are complex, so you have to create one before use.
112 Very few paragraphs will already have borders property, this way
113 we can save much memory.
114 * @param: pBorders borders of the paragraph, please reference the XFBorders.
116 void SetBorders(XFBorders
* pBorders
);
119 * @descr: Set background color of the cell.
120 * @param: color value of the back color.
122 void SetBackColor(XFColor
const& color
);
125 * descr: set cell background image.
127 void SetBackImage(std::unique_ptr
<XFBGImage
>& rImage
);
129 virtual enumXFStyle
GetStyleFamily() override
;
131 virtual bool Equal(IXFStyle
* pStyle
) override
;
133 virtual void ToXml(IXFStream
* pStrm
) override
;
136 OUString m_strDataStyle
;
137 enumXFAlignType m_eHoriAlign
;
138 enumXFAlignType m_eVertAlign
;
140 XFColor m_aBackColor
;
141 std::unique_ptr
<XFBGImage
> m_xBackImage
;
143 XFPadding m_aPadding
;
144 rtl::Reference
<XFFont
> m_pFont
;
146 std::unique_ptr
<XFBorders
> m_pBorders
;
149 inline void XFCellStyle::SetAlignType(enumXFAlignType hori
, enumXFAlignType vert
)
155 inline void XFCellStyle::SetDataStyle(const OUString
& style
) { m_strDataStyle
= style
; }
159 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */