merge the formfield patch from ooo-build
[ooovba.git] / sc / source / filter / excel / xlpage.cxx
blob7dc4a5e721062ad90d4b2e6cbb447b71c52c64d8
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: xlpage.cxx,v $
10 * $Revision: 1.9 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_sc.hxx"
33 #include "xlpage.hxx"
34 #include <sfx2/printer.hxx>
35 #include <svx/svxenum.hxx>
36 #include <svx/paperinf.hxx>
37 #include <vcl/svapp.hxx>
38 #include "scitems.hxx"
39 #include <svx/brshitem.hxx>
40 #include "global.hxx"
41 #include "xlconst.hxx"
43 // Paper size =================================================================
45 struct XclPaperSize
47 Paper mePaper; /// SVX paper size identifier.
48 long mnWidth; /// Paper width in twips.
49 long mnHeight; /// Paper height in twips.
52 #define IN2TWIPS( v ) ((long)((v) * EXC_TWIPS_PER_INCH + 0.5))
53 #define MM2TWIPS( v ) ((long)((v) * EXC_TWIPS_PER_INCH / CM_PER_INCH / 10.0 + 0.5))
55 static const XclPaperSize pPaperSizeTable[] =
57 /* 0*/ { PAPER_USER, 0, 0 }, // undefined
58 { PAPER_LETTER, IN2TWIPS( 8.5 ), IN2TWIPS( 11 ) }, // Letter
59 { PAPER_USER, IN2TWIPS( 8.5 ), IN2TWIPS( 11 ) }, // Letter Small
60 { PAPER_TABLOID, IN2TWIPS( 11 ), IN2TWIPS( 17 ) }, // Tabloid
61 { PAPER_LEDGER, IN2TWIPS( 17 ), IN2TWIPS( 11 ) }, // Ledger
62 /* 5*/ { PAPER_LEGAL, IN2TWIPS( 8.5 ), IN2TWIPS( 14 ) }, // Legal
63 { PAPER_STATEMENT, IN2TWIPS( 5.5 ), IN2TWIPS( 8.5 ) }, // Statement
64 { PAPER_EXECUTIVE, IN2TWIPS( 7.25 ), IN2TWIPS( 10.5 ) }, // Executive
65 { PAPER_A3, MM2TWIPS( 297 ), MM2TWIPS( 420 ) }, // A3
66 { PAPER_A4, MM2TWIPS( 210 ), MM2TWIPS( 297 ) }, // A4
67 /* 10*/ { PAPER_USER, MM2TWIPS( 210 ), MM2TWIPS( 297 ) }, // A4 Small
68 { PAPER_A5, MM2TWIPS( 148 ), MM2TWIPS( 210 ) }, // A5
69 //See: http://wiki.services.openoffice.org/wiki/DefaultPaperSize comments
70 //near DMPAPER_B4 in vcl
71 //i.e.
72 //http://msdn.microsoft.com/en-us/library/bb241398.aspx makes the claim:
73 //xlPaperB4 12 B4 (250 mm x 354 mm)
74 //xlPaperB5 13 A5 (148 mm x 210 mm)
75 //but, a paper enum called B5 is surely not actually "A5", and furthermore
76 //the XlPaperSize enumeration otherwise follows the DMPAPER values
77 //http://msdn.microsoft.com/en-us/library/ms776398(VS.85).aspx
78 //which has
79 //DMPAPER_B4 12 B4 (JIS) 250 x 354
80 //DMPAPER_B5 13 B5 (JIS) 182 x 257 mm
81 //which claim them to be the JIS sizes. Though that document then gives
82 //"B4 (JIS)" an *ISO* B4 size in the text, but
83 //http://partners.adobe.com/public/developer/en/ps/5003.PPD_Spec_v4.3.pdf
84 //claims that the MS DMPAPER_B4 and DMPAPER_B5 truly are the JIS sizes
85 //which at least makes some sort of sense. (cmc)
86 { PAPER_B4_JIS, MM2TWIPS( 257 ), MM2TWIPS( 364 ) }, // B4 (JIS)
87 { PAPER_B5_JIS, MM2TWIPS( 182 ), MM2TWIPS( 257 ) }, // B5 (JIS)
88 { PAPER_USER, IN2TWIPS( 8.5 ), IN2TWIPS( 13 ) }, // Folio
89 /* 15*/ { PAPER_QUARTO, MM2TWIPS( 215 ), MM2TWIPS( 275 ) }, // Quarto
90 { PAPER_10x14, IN2TWIPS( 10 ), IN2TWIPS( 14 ) }, // 10x14
91 { PAPER_USER, IN2TWIPS( 11 ), IN2TWIPS( 17 ) }, // 11x17
92 { PAPER_USER, IN2TWIPS( 8.5 ), IN2TWIPS( 11 ) }, // Note
93 { PAPER_ENV_9, IN2TWIPS( 3.875 ), IN2TWIPS( 8.875 ) }, // Envelope #9
94 /* 20*/ { PAPER_ENV_10, IN2TWIPS( 4.125 ), IN2TWIPS( 9.5 ) }, // Envelope #10
95 { PAPER_ENV_11, IN2TWIPS( 4.5 ), IN2TWIPS( 10.375 ) }, // Envelope #11
96 { PAPER_ENV_12, IN2TWIPS( 4.75 ), IN2TWIPS( 11 ) }, // Envelope #12
97 { PAPER_ENV_14, IN2TWIPS( 5 ), IN2TWIPS( 11.5 ) }, // Envelope #14
98 { PAPER_C, IN2TWIPS( 17 ), IN2TWIPS( 22 ) }, // ANSI-C
99 /* 25*/ { PAPER_D, IN2TWIPS( 22 ), IN2TWIPS( 34 ) }, // ANSI-D
100 { PAPER_E, IN2TWIPS( 34 ), IN2TWIPS( 44 ) }, // ANSI-E
101 { PAPER_ENV_DL, MM2TWIPS( 110 ), MM2TWIPS( 220 ) }, // Envelope DL
102 { PAPER_ENV_C5, MM2TWIPS( 162 ), MM2TWIPS( 229 ) }, // Envelope C5
103 { PAPER_ENV_C3, MM2TWIPS( 324 ), MM2TWIPS( 458 ) }, // Envelope C3
104 /* 30*/ { PAPER_ENV_C4, MM2TWIPS( 229 ), MM2TWIPS( 324 ) }, // Envelope C4
105 { PAPER_ENV_C6, MM2TWIPS( 114 ), MM2TWIPS( 162 ) }, // Envelope C6
106 { PAPER_ENV_C65, MM2TWIPS( 114 ), MM2TWIPS( 229 ) }, // Envelope C65
107 { PAPER_B4_ISO, MM2TWIPS( 250 ), MM2TWIPS( 353 ) }, // B4 (ISO)
108 { PAPER_B5_ISO, MM2TWIPS( 176 ), MM2TWIPS( 250 ) }, // B5 (ISO)
109 /* 35*/ { PAPER_B6_ISO, MM2TWIPS( 125 ), MM2TWIPS( 176 ) }, // B6 (ISO)
110 { PAPER_ENV_ITALY, MM2TWIPS( 110 ), MM2TWIPS( 230 ) }, // Envelope Italy
111 { PAPER_ENV_MONARCH, IN2TWIPS( 3.875 ), IN2TWIPS( 7.5 ) }, // Envelope Monarch
112 { PAPER_ENV_PERSONAL, IN2TWIPS( 3.625 ), IN2TWIPS( 6.5 ) }, // 6 3/4 Envelope
113 { PAPER_FANFOLD_US, IN2TWIPS( 14.875 ), IN2TWIPS( 11 ) }, // US Std Fanfold
114 /* 40*/ { PAPER_FANFOLD_DE, IN2TWIPS( 8.5 ), IN2TWIPS( 12 ) }, // German Std Fanfold
115 { PAPER_FANFOLD_LEGAL_DE, IN2TWIPS( 8.5 ), IN2TWIPS( 13 ) }, // German Legal Fanfold
116 { PAPER_B4_ISO, MM2TWIPS( 250 ), MM2TWIPS( 353 ) }, // B4 (ISO)
117 { PAPER_POSTCARD_JP,MM2TWIPS( 100 ), MM2TWIPS( 148 ) }, // Japanese Postcard
118 { PAPER_9x11, IN2TWIPS( 9 ), IN2TWIPS( 11 ) }, // 9x11
119 /* 45*/ { PAPER_10x11, IN2TWIPS( 10 ), IN2TWIPS( 11 ) }, // 10x11
120 { PAPER_15x11, IN2TWIPS( 15 ), IN2TWIPS( 11 ) }, // 15x11
121 { PAPER_ENV_INVITE, MM2TWIPS( 220 ), MM2TWIPS( 220 ) }, // Envelope Invite
122 { PAPER_USER, 0, 0 }, // undefined
123 { PAPER_USER, 0, 0 }, // undefined
124 /* 50*/ { PAPER_USER, IN2TWIPS( 9.5 ), IN2TWIPS( 12 ) }, // Letter Extra
125 { PAPER_USER, IN2TWIPS( 9.5 ), IN2TWIPS( 15 ) }, // Legal Extra
126 { PAPER_USER, IN2TWIPS( 11.69 ), IN2TWIPS( 18 ) }, // Tabloid Extra
127 { PAPER_USER, MM2TWIPS( 235 ), MM2TWIPS( 322 ) }, // A4 Extra
128 { PAPER_USER, IN2TWIPS( 8.5 ), IN2TWIPS( 11 ) }, // Letter Transverse
129 /* 55*/ { PAPER_USER, MM2TWIPS( 210 ), MM2TWIPS( 297 ) }, // A4 Transverse
130 { PAPER_USER, IN2TWIPS( 9.5 ), IN2TWIPS( 12 ) }, // Letter Extra Transverse
131 { PAPER_A_PLUS, MM2TWIPS( 227 ), MM2TWIPS( 356 ) }, // Super A/A4
132 { PAPER_B_PLUS, MM2TWIPS( 305 ), MM2TWIPS( 487 ) }, // Super B/A3
133 { PAPER_LETTER_PLUS,IN2TWIPS( 8.5 ), IN2TWIPS( 12.69 ) }, // Letter Plus
134 /* 60*/ { PAPER_A4_PLUS, MM2TWIPS( 210 ), MM2TWIPS( 330 ) }, // A4 Plus
135 { PAPER_USER, MM2TWIPS( 148 ), MM2TWIPS( 210 ) }, // A5 Transverse
136 { PAPER_USER, MM2TWIPS( 182 ), MM2TWIPS( 257 ) }, // B5 (JIS) Transverse
137 { PAPER_USER, MM2TWIPS( 322 ), MM2TWIPS( 445 ) }, // A3 Extra
138 { PAPER_USER, MM2TWIPS( 174 ), MM2TWIPS( 235 ) }, // A5 Extra
139 /* 65*/ { PAPER_USER, MM2TWIPS( 201 ), MM2TWIPS( 276 ) }, // B5 (ISO) Extra
140 { PAPER_A2, MM2TWIPS( 420 ), MM2TWIPS( 594 ) }, // A2
141 { PAPER_USER, MM2TWIPS( 297 ), MM2TWIPS( 420 ) }, // A3 Transverse
142 { PAPER_USER, MM2TWIPS( 322 ), MM2TWIPS( 445 ) }, // A3 Extra Transverse
143 { PAPER_DOUBLEPOSTCARD_JP, MM2TWIPS( 200 ), MM2TWIPS( 148 ) }, // Double Japanese Postcard
144 /* 70*/ { PAPER_A6, MM2TWIPS( 105 ), MM2TWIPS( 148 ) }, // A6
145 { PAPER_USER, 0, 0 }, // undefined
146 { PAPER_USER, 0, 0 }, // undefined
147 { PAPER_USER, 0, 0 }, // undefined
148 { PAPER_USER, 0, 0 }, // undefined
149 /* 75*/ { PAPER_USER, IN2TWIPS( 11 ), IN2TWIPS( 8.5 ) }, // Letter Rotated
150 { PAPER_USER, MM2TWIPS( 420 ), MM2TWIPS( 297 ) }, // A3 Rotated
151 { PAPER_USER, MM2TWIPS( 297 ), MM2TWIPS( 210 ) }, // A4 Rotated
152 { PAPER_USER, MM2TWIPS( 210 ), MM2TWIPS( 148 ) }, // A5 Rotated
153 { PAPER_USER, MM2TWIPS( 364 ), MM2TWIPS( 257 ) }, // B4 (JIS) Rotated
154 /* 80*/ { PAPER_USER, MM2TWIPS( 257 ), MM2TWIPS( 182 ) }, // B5 (JIS) Rotated
155 { PAPER_USER, MM2TWIPS( 148 ), MM2TWIPS( 100 ) }, // Japanese Postcard Rotated
156 { PAPER_USER, MM2TWIPS( 148 ), MM2TWIPS( 200 ) }, // Double Japanese Postcard Rotated
157 { PAPER_USER, MM2TWIPS( 148 ), MM2TWIPS( 105 ) }, // A6 Rotated
158 { PAPER_USER, 0, 0 }, // undefined
159 /* 85*/ { PAPER_USER, 0, 0 }, // undefined
160 { PAPER_USER, 0, 0 }, // undefined
161 { PAPER_USER, 0, 0 }, // undefined
162 { PAPER_B6_JIS, MM2TWIPS( 128 ), MM2TWIPS( 182 ) }, // B6 (JIS)
163 { PAPER_USER, MM2TWIPS( 182 ), MM2TWIPS( 128 ) }, // B6 (JIS) Rotated
164 /* 90*/ { PAPER_12x11, IN2TWIPS( 12 ), IN2TWIPS( 11 ) } // 12x11
167 #undef IN2TWIPS
168 #undef MM2TWIPS
170 // Page settings ==============================================================
172 XclPageData::XclPageData()
174 SetDefaults();
177 XclPageData::~XclPageData()
179 // SvxBrushItem incomplete in header
182 void XclPageData::SetDefaults()
184 maHorPageBreaks.clear();
185 maVerPageBreaks.clear();
186 mxBrushItem.reset();
187 maHeader.Erase();
188 maFooter.Erase();
189 mfLeftMargin = mfRightMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_LR );
190 mfTopMargin = mfBottomMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_TB );
191 mfHeaderMargin = mfFooterMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_HF );
192 mfHdrLeftMargin = mfHdrRightMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_HLR );
193 mfFtrLeftMargin = mfFtrRightMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_FLR );
194 mnPaperSize = EXC_PAPERSIZE_DEFAULT;
195 mnCopies = 1;
196 mnStartPage = 0;
197 mnScaling = 100;
198 mnFitToWidth = mnFitToHeight = 1;
199 mnHorPrintRes = mnVerPrintRes = 300;
200 mbValid = false;
201 mbPortrait = true;
202 mbPrintInRows = mbBlackWhite = mbDraftQuality = mbPrintNotes = mbManualStart = mbFitToPages = false;
203 mbHorCenter = mbVerCenter = mbPrintHeadings = mbPrintGrid = false;
206 Size XclPageData::GetScPaperSize() const
208 const XclPaperSize* pEntry = pPaperSizeTable;
209 if( mnPaperSize < STATIC_TABLE_SIZE( pPaperSizeTable ) )
210 pEntry += mnPaperSize;
212 Size aSize;
213 if( pEntry->mePaper == PAPER_USER )
214 aSize = Size( pEntry->mnWidth, pEntry->mnHeight );
215 else
216 aSize = SvxPaperInfo::GetPaperSize( pEntry->mePaper );
218 // invalid size -> back to default
219 if( !aSize.Width() || !aSize.Height() )
220 aSize = SvxPaperInfo::GetDefaultPaperSize();
222 if( !mbPortrait )
223 ::std::swap( aSize.Width(), aSize.Height() );
225 return aSize;
228 void XclPageData::SetScPaperSize( const Size& rSize, bool bPortrait )
230 mbPortrait = bPortrait;
231 mnPaperSize = 0;
232 long nWidth = bPortrait ? rSize.Width() : rSize.Height();
233 long nHeight = bPortrait ? rSize.Height() : rSize.Width();
234 long nMaxWDiff = 80;
235 long nMaxHDiff = 50;
236 for( const XclPaperSize* pEntry = pPaperSizeTable; pEntry != STATIC_TABLE_END( pPaperSizeTable ); ++pEntry )
238 long nWDiff = Abs( pEntry->mnWidth - nWidth );
239 long nHDiff = Abs( pEntry->mnHeight - nHeight );
240 if( ((nWDiff <= nMaxWDiff) && (nHDiff < nMaxHDiff)) ||
241 ((nWDiff < nMaxWDiff) && (nHDiff <= nMaxHDiff)) )
243 mnPaperSize = static_cast< sal_uInt16 >( pEntry - pPaperSizeTable );
244 nMaxWDiff = nWDiff;
245 nMaxHDiff = nHDiff;
250 // ============================================================================