xref: /trunk/main/sc/source/filter/excel/xlpage.cxx (revision c059a6bf)
1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_scfilt.hxx"
26 #include "xlpage.hxx"
27 #include <sfx2/printer.hxx>
28 #include <editeng/svxenum.hxx>
29 #include <editeng/paperinf.hxx>
30 #include <vcl/svapp.hxx>
31 #include "scitems.hxx"
32 #include <editeng/brshitem.hxx>
33 #include "global.hxx"
34 #include "xlconst.hxx"
35 
36 // Paper size =================================================================
37 
38 struct XclPaperSize
39 {
40     Paper            	mePaper;            /// SVX paper size identifier.
41     long                mnWidth;            /// Paper width in twips.
42     long                mnHeight;           /// Paper height in twips.
43 };
44 
45 #define IN2TWIPS( v )      ((long)((v) * EXC_TWIPS_PER_INCH + 0.5))
46 #define MM2TWIPS( v )      ((long)((v) * EXC_TWIPS_PER_INCH / CM_PER_INCH / 10.0 + 0.5))
47 
48 static const XclPaperSize pPaperSizeTable[] =
49 {
50 /*  0*/ { PAPER_USER,       0,                  0                   },  // undefined
51         { PAPER_LETTER,     IN2TWIPS( 8.5 ),    IN2TWIPS( 11 )      },  // Letter
52         { PAPER_USER,       IN2TWIPS( 8.5 ),    IN2TWIPS( 11 )      },  // Letter Small
53         { PAPER_TABLOID,    IN2TWIPS( 11 ),     IN2TWIPS( 17 )      },  // Tabloid
54         { PAPER_LEDGER,     IN2TWIPS( 17 ),     IN2TWIPS( 11 )      },  // Ledger
55 /*  5*/ { PAPER_LEGAL,      IN2TWIPS( 8.5 ),    IN2TWIPS( 14 )      },  // Legal
56         { PAPER_STATEMENT,  IN2TWIPS( 5.5 ),    IN2TWIPS( 8.5 )     },  // Statement
57         { PAPER_EXECUTIVE,  IN2TWIPS( 7.25 ),   IN2TWIPS( 10.5 )    },  // Executive
58         { PAPER_A3,         MM2TWIPS( 297 ),    MM2TWIPS( 420 )     },  // A3
59         { PAPER_A4,         MM2TWIPS( 210 ),    MM2TWIPS( 297 )     },  // A4
60 /* 10*/ { PAPER_USER,       MM2TWIPS( 210 ),    MM2TWIPS( 297 )     },  // A4 Small
61         { PAPER_A5,         MM2TWIPS( 148 ),    MM2TWIPS( 210 )     },  // A5
62         //See: https://wiki.openoffice.org/wiki/DefaultPaperSize comments
63         //near DMPAPER_B4 in vcl
64         //i.e.
65         //http://msdn.microsoft.com/en-us/library/bb241398.aspx makes the claim:
66         //xlPaperB4	12	B4 (250 mm x 354 mm)
67         //xlPaperB5	13	A5 (148 mm x 210 mm)
68         //but, a paper enum called B5 is surely not actually "A5", and furthermore
69         //the XlPaperSize enumeration otherwise follows the DMPAPER values
70         //http://msdn.microsoft.com/en-us/library/ms776398(VS.85).aspx
71         //which has
72         //DMPAPER_B4 	12 	B4 (JIS) 250 x 354
73         //DMPAPER_B5 	13 	B5 (JIS) 182 x 257 mm
74 	//which claim them to be the JIS sizes. Though that document then gives
75 	//"B4 (JIS)" an *ISO* B4 size in the text, but
76         //http://partners.adobe.com/public/developer/en/ps/5003.PPD_Spec_v4.3.pdf
77         //claims that the MS DMPAPER_B4 and DMPAPER_B5 truly are the JIS sizes
78         //which at least makes some sort of sense. (cmc)
79         { PAPER_B4_JIS,     MM2TWIPS( 257 ),    MM2TWIPS( 364 )     },  // B4 (JIS)
80         { PAPER_B5_JIS,     MM2TWIPS( 182 ),    MM2TWIPS( 257 )     },  // B5 (JIS)
81         { PAPER_USER,       IN2TWIPS( 8.5 ),    IN2TWIPS( 13 )      },  // Folio
82 /* 15*/ { PAPER_QUARTO,     MM2TWIPS( 215 ),    MM2TWIPS( 275 )     },  // Quarto
83         { PAPER_10x14,      IN2TWIPS( 10 ),     IN2TWIPS( 14 )      },  // 10x14
84         { PAPER_USER,       IN2TWIPS( 11 ),     IN2TWIPS( 17 )      },  // 11x17
85         { PAPER_USER,       IN2TWIPS( 8.5 ),    IN2TWIPS( 11 )      },  // Note
86         { PAPER_ENV_9,       IN2TWIPS( 3.875 ),  IN2TWIPS( 8.875 )   },  // Envelope #9
87 /* 20*/ { PAPER_ENV_10,      IN2TWIPS( 4.125 ),  IN2TWIPS( 9.5 )     },  // Envelope #10
88         { PAPER_ENV_11,      IN2TWIPS( 4.5 ),    IN2TWIPS( 10.375 )  },  // Envelope #11
89         { PAPER_ENV_12,      IN2TWIPS( 4.75 ),   IN2TWIPS( 11 )      },  // Envelope #12
90         { PAPER_ENV_14,      IN2TWIPS( 5 ),      IN2TWIPS( 11.5 )    },  // Envelope #14
91         { PAPER_C,          IN2TWIPS( 17 ),     IN2TWIPS( 22 )      },  // ANSI-C
92 /* 25*/ { PAPER_D,          IN2TWIPS( 22 ),     IN2TWIPS( 34 )      },  // ANSI-D
93         { PAPER_E,          IN2TWIPS( 34 ),     IN2TWIPS( 44 )      },  // ANSI-E
94         { PAPER_ENV_DL,         MM2TWIPS( 110 ),    MM2TWIPS( 220 )     },  // Envelope DL
95         { PAPER_ENV_C5,         MM2TWIPS( 162 ),    MM2TWIPS( 229 )     },  // Envelope C5
96         { PAPER_ENV_C3,         MM2TWIPS( 324 ),    MM2TWIPS( 458 )     },  // Envelope C3
97 /* 30*/ { PAPER_ENV_C4,         MM2TWIPS( 229 ),    MM2TWIPS( 324 )     },  // Envelope C4
98         { PAPER_ENV_C6,         MM2TWIPS( 114 ),    MM2TWIPS( 162 )     },  // Envelope C6
99         { PAPER_ENV_C65,        MM2TWIPS( 114 ),    MM2TWIPS( 229 )     },  // Envelope C65
100         { PAPER_B4_ISO,     MM2TWIPS( 250 ),    MM2TWIPS( 353 )     },  // B4 (ISO)
101         { PAPER_B5_ISO,     MM2TWIPS( 176 ),    MM2TWIPS( 250 )     },  // B5 (ISO)
102 /* 35*/ { PAPER_B6_ISO,     MM2TWIPS( 125 ),    MM2TWIPS( 176 )     },  // B6 (ISO)
103         { PAPER_ENV_ITALY,    MM2TWIPS( 110 ),    MM2TWIPS( 230 )     },  // Envelope Italy
104         { PAPER_ENV_MONARCH,    IN2TWIPS( 3.875 ),  IN2TWIPS( 7.5 )     },  // Envelope Monarch
105         { PAPER_ENV_PERSONAL,     IN2TWIPS( 3.625 ),  IN2TWIPS( 6.5 )     },  // 6 3/4 Envelope
106         { PAPER_FANFOLD_US, IN2TWIPS( 14.875 ), IN2TWIPS( 11 )      },  // US Std Fanfold
107 /* 40*/ { PAPER_FANFOLD_DE, IN2TWIPS( 8.5 ),    IN2TWIPS( 12 )      },  // German Std Fanfold
108         { PAPER_FANFOLD_LEGAL_DE,     IN2TWIPS( 8.5 ),    IN2TWIPS( 13 )      },  // German Legal Fanfold
109         { PAPER_B4_ISO,     MM2TWIPS( 250 ),    MM2TWIPS( 353 )     },  // B4 (ISO)
110         { PAPER_POSTCARD_JP,MM2TWIPS( 100 ),    MM2TWIPS( 148 )     },  // Japanese Postcard
111         { PAPER_9x11,       IN2TWIPS( 9 ),      IN2TWIPS( 11 )      },  // 9x11
112 /* 45*/ { PAPER_10x11,      IN2TWIPS( 10 ),     IN2TWIPS( 11 )      },  // 10x11
113         { PAPER_15x11,      IN2TWIPS( 15 ),     IN2TWIPS( 11 )      },  // 15x11
114         { PAPER_ENV_INVITE,     MM2TWIPS( 220 ),    MM2TWIPS( 220 )     },  // Envelope Invite
115         { PAPER_USER,       0,                  0                   },  // undefined
116         { PAPER_USER,       0,                  0                   },  // undefined
117 /* 50*/ { PAPER_USER,       IN2TWIPS( 9.5 ),    IN2TWIPS( 12 )      },  // Letter Extra
118         { PAPER_USER,       IN2TWIPS( 9.5 ),    IN2TWIPS( 15 )      },  // Legal Extra
119         { PAPER_USER,       IN2TWIPS( 11.69 ),  IN2TWIPS( 18 )      },  // Tabloid Extra
120         { PAPER_USER,       MM2TWIPS( 235 ),    MM2TWIPS( 322 )     },  // A4 Extra
121         { PAPER_USER,       IN2TWIPS( 8.5 ),    IN2TWIPS( 11 )      },  // Letter Transverse
122 /* 55*/ { PAPER_USER,       MM2TWIPS( 210 ),    MM2TWIPS( 297 )     },  // A4 Transverse
123         { PAPER_USER,       IN2TWIPS( 9.5 ),    IN2TWIPS( 12 )      },  // Letter Extra Transverse
124         { PAPER_A_PLUS,     MM2TWIPS( 227 ),    MM2TWIPS( 356 )     },  // Super A/A4
125         { PAPER_B_PLUS,     MM2TWIPS( 305 ),    MM2TWIPS( 487 )     },  // Super B/A3
126         { PAPER_LETTER_PLUS,IN2TWIPS( 8.5 ),    IN2TWIPS( 12.69 )   },  // Letter Plus
127 /* 60*/ { PAPER_A4_PLUS,    MM2TWIPS( 210 ),    MM2TWIPS( 330 )     },  // A4 Plus
128         { PAPER_USER,       MM2TWIPS( 148 ),    MM2TWIPS( 210 )     },  // A5 Transverse
129         { PAPER_USER,       MM2TWIPS( 182 ),    MM2TWIPS( 257 )     },  // B5 (JIS) Transverse
130         { PAPER_USER,       MM2TWIPS( 322 ),    MM2TWIPS( 445 )     },  // A3 Extra
131         { PAPER_USER,       MM2TWIPS( 174 ),    MM2TWIPS( 235 )     },  // A5 Extra
132 /* 65*/ { PAPER_USER,       MM2TWIPS( 201 ),    MM2TWIPS( 276 )     },  // B5 (ISO) Extra
133         { PAPER_A2,         MM2TWIPS( 420 ),    MM2TWIPS( 594 )     },  // A2
134         { PAPER_USER,       MM2TWIPS( 297 ),    MM2TWIPS( 420 )     },  // A3 Transverse
135         { PAPER_USER,       MM2TWIPS( 322 ),    MM2TWIPS( 445 )     },  // A3 Extra Transverse
136         { PAPER_DOUBLEPOSTCARD_JP,       MM2TWIPS( 200 ),    MM2TWIPS( 148 )     },  // Double Japanese Postcard
137 /* 70*/ { PAPER_A6,         MM2TWIPS( 105 ),    MM2TWIPS( 148 )     },  // A6
138         { PAPER_USER,       0,                  0                   },  // undefined
139         { PAPER_USER,       0,                  0                   },  // undefined
140         { PAPER_USER,       0,                  0                   },  // undefined
141         { PAPER_USER,       0,                  0                   },  // undefined
142 /* 75*/ { PAPER_USER,       IN2TWIPS( 11 ),     IN2TWIPS( 8.5 )     },  // Letter Rotated
143         { PAPER_USER,       MM2TWIPS( 420 ),    MM2TWIPS( 297 )     },  // A3 Rotated
144         { PAPER_USER,       MM2TWIPS( 297 ),    MM2TWIPS( 210 )     },  // A4 Rotated
145         { PAPER_USER,       MM2TWIPS( 210 ),    MM2TWIPS( 148 )     },  // A5 Rotated
146         { PAPER_USER,       MM2TWIPS( 364 ),    MM2TWIPS( 257 )     },  // B4 (JIS) Rotated
147 /* 80*/ { PAPER_USER,       MM2TWIPS( 257 ),    MM2TWIPS( 182 )     },  // B5 (JIS) Rotated
148         { PAPER_USER,       MM2TWIPS( 148 ),    MM2TWIPS( 100 )     },  // Japanese Postcard Rotated
149         { PAPER_USER,       MM2TWIPS( 148 ),    MM2TWIPS( 200 )     },  // Double Japanese Postcard Rotated
150         { PAPER_USER,       MM2TWIPS( 148 ),    MM2TWIPS( 105 )     },  // A6 Rotated
151         { PAPER_USER,       0,                  0                   },  // undefined
152 /* 85*/ { PAPER_USER,       0,                  0                   },  // undefined
153         { PAPER_USER,       0,                  0                   },  // undefined
154         { PAPER_USER,       0,                  0                   },  // undefined
155         { PAPER_B6_JIS,     MM2TWIPS( 128 ),    MM2TWIPS( 182 )     },  // B6 (JIS)
156         { PAPER_USER,       MM2TWIPS( 182 ),    MM2TWIPS( 128 )     },  // B6 (JIS) Rotated
157 /* 90*/ { PAPER_12x11,      IN2TWIPS( 12 ),     IN2TWIPS( 11 )      }   // 12x11
158 };
159 
160 #undef IN2TWIPS
161 #undef MM2TWIPS
162 
163 // Page settings ==============================================================
164 
XclPageData()165 XclPageData::XclPageData()
166 {
167     SetDefaults();
168 }
169 
~XclPageData()170 XclPageData::~XclPageData()
171 {
172     // SvxBrushItem incomplete in header
173 }
174 
SetDefaults()175 void XclPageData::SetDefaults()
176 {
177     maHorPageBreaks.clear();
178     maVerPageBreaks.clear();
179     mxBrushItem.reset();
180     maHeader.Erase();
181     maFooter.Erase();
182     mfLeftMargin    = mfRightMargin    = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_LR );
183     mfTopMargin     = mfBottomMargin   = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_TB );
184     mfHeaderMargin  = mfFooterMargin   = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_HF );
185     mfHdrLeftMargin = mfHdrRightMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_HLR );
186     mfFtrLeftMargin = mfFtrRightMargin = XclTools::GetInchFromHmm( EXC_MARGIN_DEFAULT_FLR );
187     mnPaperSize = EXC_PAPERSIZE_DEFAULT;
188     mnCopies = 1;
189     mnStartPage = 0;
190     mnScaling = 100;
191     mnFitToWidth = mnFitToHeight = 1;
192     mnHorPrintRes = mnVerPrintRes = 300;
193     mbValid = false;
194     mbPortrait = true;
195     mbPrintInRows = mbBlackWhite = mbDraftQuality = mbPrintNotes = mbManualStart = mbFitToPages = false;
196     mbHorCenter = mbVerCenter = mbPrintHeadings = mbPrintGrid = false;
197 }
198 
GetScPaperSize() const199 Size XclPageData::GetScPaperSize() const
200 {
201     const XclPaperSize* pEntry = pPaperSizeTable;
202     if( mnPaperSize < STATIC_ARRAY_SIZE( pPaperSizeTable ) )
203         pEntry += mnPaperSize;
204 
205     Size aSize;
206     if( pEntry->mePaper == PAPER_USER )
207         aSize = Size( pEntry->mnWidth, pEntry->mnHeight );
208     else
209         aSize = SvxPaperInfo::GetPaperSize( pEntry->mePaper );
210 
211     // invalid size -> back to default
212     if( !aSize.Width() || !aSize.Height() )
213         aSize = SvxPaperInfo::GetDefaultPaperSize();
214 
215     if( !mbPortrait )
216         ::std::swap( aSize.Width(), aSize.Height() );
217 
218     return aSize;
219 }
220 
SetScPaperSize(const Size & rSize,bool bPortrait)221 void XclPageData::SetScPaperSize( const Size& rSize, bool bPortrait )
222 {
223     mbPortrait = bPortrait;
224     mnPaperSize = 0;
225     long nWidth = bPortrait ? rSize.Width() : rSize.Height();
226     long nHeight = bPortrait ? rSize.Height() : rSize.Width();
227     long nMaxWDiff = 80;
228     long nMaxHDiff = 50;
229     for( const XclPaperSize* pEntry = pPaperSizeTable; pEntry != STATIC_ARRAY_END( pPaperSizeTable ); ++pEntry )
230     {
231         long nWDiff = Abs( pEntry->mnWidth - nWidth );
232         long nHDiff = Abs( pEntry->mnHeight - nHeight );
233         if( ((nWDiff <= nMaxWDiff) && (nHDiff < nMaxHDiff)) ||
234             ((nWDiff < nMaxWDiff) && (nHDiff <= nMaxHDiff)) )
235         {
236             mnPaperSize = static_cast< sal_uInt16 >( pEntry - pPaperSizeTable );
237             nMaxWDiff = nWDiff;
238             nMaxHDiff = nHDiff;
239         }
240     }
241 }
242 
243 // ============================================================================
244 
245