1 /*************************************************************************
3 * The Contents of this file are made available subject to the terms of
4 * either of the following licenses
6 * - GNU Lesser General Public License Version 2.1
7 * - Sun Industry Standards Source License Version 1.1
9 * Sun Microsystems Inc., October, 2000
11 * GNU Lesser General Public License Version 2.1
12 * =============================================
13 * Copyright 2000 by Sun Microsystems, Inc.
14 * 901 San Antonio Road, Palo Alto, CA 94303, USA
16 * This library is free software; you can redistribute it and/or
17 * modify it under the terms of the GNU Lesser General Public
18 * License version 2.1, as published by the Free Software Foundation.
20 * This library is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23 * Lesser General Public License for more details.
25 * You should have received a copy of the GNU Lesser General Public
26 * License along with this library; if not, write to the Free Software
27 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
31 * Sun Industry Standards Source License Version 1.1
32 * =================================================
33 * The contents of this file are subject to the Sun Industry Standards
34 * Source License Version 1.1 (the "License"); You may not use this file
35 * except in compliance with the License. You may obtain a copy of the
36 * License at http://www.openoffice.org/license.html.
38 * Software provided under this License is provided on an "AS IS" basis,
39 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
40 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
41 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
42 * See the License for the specific provisions governing your rights and
43 * obligations concerning the Software.
45 * The Initial Developer of the Original Code is: IBM Corporation
47 * Copyright: 2008 by IBM Corporation
49 * All Rights Reserved.
51 * Contributor(s): _______________________________________
54 ************************************************************************/
56 #ifndef _LWPMARGINS_HXX
57 #define _LWPMARGINS_HXX
59 #include "lwpobjstrm.hxx"
60 #include "lwptools.hxx"
62 const sal_uInt8 MARGIN_LEFT
= 0;
63 const sal_uInt8 MARGIN_RIGHT
= 1;
64 const sal_uInt8 MARGIN_TOP
= 2;
65 const sal_uInt8 MARGIN_BOTTOM
= 3;
70 LwpMargins():m_nLeft(0),m_nTop(0),m_nRight(0),m_nBottom(0){}
72 void Read(LwpObjectStream
*pStrm
)
74 pStrm
->QuickRead(&m_nLeft
, 4);
75 pStrm
->QuickRead(&m_nTop
, 4);
76 pStrm
->QuickRead(&m_nRight
, 4);
77 pStrm
->QuickRead(&m_nBottom
, 4);
81 inline void operator = (const LwpMargins
& rOther
);
82 inline double GetMarginsValue(const sal_uInt8
& nWhichSide
);
91 inline void LwpMargins::operator = (const LwpMargins
& rOther
)
93 m_nLeft
= rOther
.m_nLeft
;
94 m_nTop
= rOther
.m_nTop
;
95 m_nRight
= rOther
.m_nRight
;
96 m_nBottom
= rOther
.m_nBottom
;
99 inline double LwpMargins::GetMarginsValue(const sal_uInt8
& nWhichSide
)
103 case MARGIN_LEFT
://left
104 return LwpTools::ConvertFromUnitsToMetric(m_nLeft
);
106 case MARGIN_RIGHT
://right
107 return LwpTools::ConvertFromUnitsToMetric(m_nRight
);
109 case MARGIN_TOP
://top
110 return LwpTools::ConvertFromUnitsToMetric(m_nTop
);
112 case MARGIN_BOTTOM
://bottom
113 return LwpTools::ConvertFromUnitsToMetric(m_nBottom
);
116 // FIXME: this is needed to avoid warning: control reaches end of non-void function
117 // a better solution would be to enum value for the parameter side