Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include "oox/drawingml/drawingmltypes.hxx"
21 : #include <com/sun/star/awt/FontUnderline.hpp>
22 : #include <com/sun/star/awt/FontStrikeout.hpp>
23 : #include <com/sun/star/style/CaseMap.hpp>
24 : #include <com/sun/star/style/ParagraphAdjust.hpp>
25 : #include <sax/tools/converter.hxx>
26 : #include "oox/token/tokens.hxx"
27 :
28 : using ::com::sun::star::uno::Reference;
29 : using ::com::sun::star::xml::sax::XFastAttributeList;
30 : using namespace ::com::sun::star;
31 : using namespace ::com::sun::star::drawing;
32 : using namespace ::com::sun::star::geometry;
33 : using namespace ::com::sun::star::style;
34 :
35 : namespace oox {
36 : namespace drawingml {
37 :
38 :
39 :
40 : /** converts EMUs into 1/100th mmm */
41 0 : sal_Int32 GetCoordinate( sal_Int32 nValue )
42 : {
43 0 : return (nValue + 180) / 360;
44 : }
45 :
46 : /** converts an emu string into 1/100th mmm */
47 0 : sal_Int32 GetCoordinate( const OUString& sValue )
48 : {
49 0 : sal_Int32 nRet = 0;
50 0 : if( !::sax::Converter::convertNumber( nRet, sValue ) )
51 0 : nRet = 0;
52 0 : return GetCoordinate( nRet );
53 : }
54 :
55 : /** converts a ST_Percentage % string into 1/1000th of % */
56 0 : sal_Int32 GetPercent( const OUString& sValue )
57 : {
58 0 : sal_Int32 nRet = 0;
59 0 : if( !::sax::Converter::convertNumber( nRet, sValue ) )
60 0 : nRet = 0;
61 :
62 0 : return nRet;
63 : }
64 :
65 0 : double GetPositiveFixedPercentage( const OUString& sValue )
66 : {
67 0 : double fPercent = sValue.toFloat() / 100000.;
68 0 : return fPercent;
69 : }
70 :
71 :
72 :
73 : /** converts the attributes from an CT_TLPoint into an awt Point with 1/1000% */
74 0 : awt::Point GetPointPercent( const Reference< XFastAttributeList >& xAttribs )
75 : {
76 0 : return awt::Point( GetPercent( xAttribs->getOptionalValue( XML_x ) ), GetCoordinate( xAttribs->getOptionalValue( XML_y ) ) );
77 : }
78 :
79 :
80 :
81 : /** converts the ST_TextFontSize to point */
82 0 : float GetTextSize( const OUString& sValue )
83 : {
84 0 : float fRet = 0;
85 : sal_Int32 nRet;
86 0 : if( ::sax::Converter::convertNumber( nRet, sValue ) )
87 0 : fRet = static_cast< float >( static_cast< double >( nRet ) / 100.0 );
88 0 : return fRet;
89 : }
90 :
91 :
92 : /** converts the ST_TextSpacingPoint to 1/100mm */
93 0 : sal_Int32 GetTextSpacingPoint( const OUString& sValue )
94 : {
95 : sal_Int32 nRet;
96 0 : if( ::sax::Converter::convertNumber( nRet, sValue ) )
97 0 : nRet = GetTextSpacingPoint( nRet );
98 0 : return nRet;
99 : }
100 :
101 0 : sal_Int32 GetTextSpacingPoint( const sal_Int32 nValue )
102 : {
103 0 : return ( nValue * 254 + 360 ) / 720;
104 : }
105 :
106 0 : float GetFontHeight( sal_Int32 nHeight )
107 : {
108 : // convert 1/100 points to points
109 0 : return static_cast< float >( nHeight / 100.0 );
110 : }
111 :
112 0 : sal_Int16 GetFontUnderline( sal_Int32 nToken )
113 : {
114 : OSL_ASSERT((nToken & sal_Int32(0xFFFF0000))==0);
115 0 : switch( nToken )
116 : {
117 0 : case XML_none: return awt::FontUnderline::NONE;
118 0 : case XML_dash: return awt::FontUnderline::DASH;
119 0 : case XML_dashHeavy: return awt::FontUnderline::BOLDDASH;
120 0 : case XML_dashLong: return awt::FontUnderline::LONGDASH;
121 0 : case XML_dashLongHeavy: return awt::FontUnderline::BOLDLONGDASH;
122 0 : case XML_dbl: return awt::FontUnderline::DOUBLE;
123 0 : case XML_dotDash: return awt::FontUnderline::DASHDOT;
124 0 : case XML_dotDashHeavy: return awt::FontUnderline::BOLDDASHDOT;
125 0 : case XML_dotDotDash: return awt::FontUnderline::DASHDOTDOT;
126 0 : case XML_dotDotDashHeavy: return awt::FontUnderline::BOLDDASHDOTDOT;
127 0 : case XML_dotted: return awt::FontUnderline::DOTTED;
128 0 : case XML_dottedHeavy: return awt::FontUnderline::BOLDDOTTED;
129 0 : case XML_heavy: return awt::FontUnderline::BOLD;
130 0 : case XML_sng: return awt::FontUnderline::SINGLE;
131 0 : case XML_wavy: return awt::FontUnderline::WAVE;
132 0 : case XML_wavyDbl: return awt::FontUnderline::DOUBLEWAVE;
133 0 : case XML_wavyHeavy: return awt::FontUnderline::BOLDWAVE;
134 : // case XML_words: // TODO
135 : }
136 0 : return awt::FontUnderline::DONTKNOW;
137 : }
138 :
139 0 : sal_Int16 GetFontStrikeout( sal_Int32 nToken )
140 : {
141 : OSL_ASSERT((nToken & sal_Int32(0xFFFF0000))==0);
142 0 : switch( nToken )
143 : {
144 0 : case XML_dblStrike: return awt::FontStrikeout::DOUBLE;
145 0 : case XML_noStrike: return awt::FontStrikeout::NONE;
146 0 : case XML_sngStrike: return awt::FontStrikeout::SINGLE;
147 : }
148 0 : return awt::FontStrikeout::DONTKNOW;
149 : }
150 :
151 0 : sal_Int16 GetCaseMap( sal_Int32 nToken )
152 : {
153 0 : switch( nToken )
154 : {
155 0 : case XML_all: return CaseMap::UPPERCASE;
156 0 : case XML_small: return CaseMap::SMALLCAPS;
157 : }
158 0 : return CaseMap::NONE;
159 : }
160 :
161 : /** converts a paragraph align to a ParaAdjust */
162 0 : sal_Int16 GetParaAdjust( sal_Int32 nAlign )
163 : {
164 : OSL_ASSERT((nAlign & sal_Int32(0xFFFF0000))==0);
165 : sal_Int16 nEnum;
166 0 : switch( nAlign )
167 : {
168 : case XML_ctr:
169 0 : nEnum = ParagraphAdjust_CENTER;
170 0 : break;
171 : case XML_just:
172 : case XML_justLow:
173 0 : nEnum = ParagraphAdjust_BLOCK;
174 0 : break;
175 : case XML_r:
176 0 : nEnum = ParagraphAdjust_RIGHT;
177 0 : break;
178 : case XML_thaiDist:
179 : case XML_dist:
180 0 : nEnum = ParagraphAdjust_STRETCH;
181 0 : break;
182 : case XML_l:
183 : default:
184 0 : nEnum = ParagraphAdjust_LEFT;
185 0 : break;
186 : }
187 0 : return nEnum;
188 : }
189 :
190 0 : TextVerticalAdjust GetTextVerticalAdjust( sal_Int32 nToken )
191 : {
192 : TextVerticalAdjust aVertAdjust;
193 0 : switch( nToken )
194 : {
195 : case XML_b:
196 0 : aVertAdjust = TextVerticalAdjust_BOTTOM;
197 0 : break;
198 : case XML_dist:
199 : case XML_just:
200 : case XML_ctr:
201 0 : aVertAdjust = TextVerticalAdjust_CENTER;
202 0 : break;
203 : case XML_t:
204 : default:
205 0 : aVertAdjust = TextVerticalAdjust_TOP;
206 0 : break;
207 : }
208 0 : return aVertAdjust;
209 : }
210 :
211 0 : const char* GetTextVerticalAdjust( TextVerticalAdjust eAdjust )
212 : {
213 0 : const char* sVerticalAdjust = 0;
214 0 : switch( eAdjust )
215 : {
216 : case TextVerticalAdjust_BOTTOM:
217 0 : sVerticalAdjust = "b";
218 0 : break;
219 : case TextVerticalAdjust_CENTER:
220 0 : sVerticalAdjust = "ctr";
221 0 : break;
222 : case TextVerticalAdjust_TOP:
223 : default:
224 0 : sVerticalAdjust = "t";
225 0 : break;
226 : }
227 0 : return sVerticalAdjust;
228 : }
229 :
230 0 : TabAlign GetTabAlign( sal_Int32 aToken )
231 : {
232 : OSL_ASSERT((aToken & sal_Int32(0xFFFF0000))==0);
233 : TabAlign nEnum;
234 0 : switch( aToken )
235 : {
236 : case XML_ctr:
237 0 : nEnum = TabAlign_CENTER;
238 0 : break;
239 : case XML_dec:
240 0 : nEnum = TabAlign_DECIMAL;
241 0 : break;
242 : case XML_l:
243 0 : nEnum = TabAlign_LEFT;
244 0 : break;
245 : case XML_r:
246 0 : nEnum = TabAlign_RIGHT;
247 0 : break;
248 : default:
249 0 : nEnum = TabAlign_DEFAULT;
250 0 : break;
251 : }
252 0 : return nEnum;
253 : }
254 :
255 0 : const char* GetHatchPattern( const drawing::Hatch& rHatch )
256 : {
257 0 : const char* sPattern = 0;
258 0 : const sal_Int32 nAngle = rHatch.Angle > 1800 ? rHatch.Angle - 1800 : rHatch.Angle;
259 : // Angle ~ 0° (horizontal)
260 0 : if( (nAngle >= 0 && nAngle < 225) || nAngle >= 1575 )
261 : {
262 0 : switch( rHatch.Style )
263 : {
264 : case drawing::HatchStyle_SINGLE:
265 : {
266 0 : if( rHatch.Distance < 75 )
267 0 : sPattern = "ltHorz";
268 : else
269 0 : sPattern = "horz";
270 :
271 0 : break;
272 : }
273 : case drawing::HatchStyle_DOUBLE:
274 : case drawing::HatchStyle_TRIPLE:
275 : {
276 0 : if( rHatch.Distance < 75 )
277 0 : sPattern = "smGrid";
278 : else
279 0 : sPattern = "lgGrid";
280 :
281 0 : break;
282 : }
283 0 : default: break;
284 : }
285 : }
286 : // Angle ~ 45° (upward diagonal)
287 0 : else if( nAngle < 675 )
288 : {
289 0 : switch( rHatch.Style )
290 : {
291 : case drawing::HatchStyle_SINGLE:
292 : {
293 0 : if( rHatch.Distance < 75 )
294 0 : sPattern = "ltUpDiag";
295 : else
296 0 : sPattern = "wdUpDiag";
297 :
298 0 : break;
299 : }
300 : case drawing::HatchStyle_DOUBLE:
301 : case drawing::HatchStyle_TRIPLE:
302 : {
303 0 : if( rHatch.Distance < 75 )
304 0 : sPattern = "smCheck";
305 : else
306 0 : sPattern = "openDmnd";
307 :
308 0 : break;
309 : }
310 0 : default: break;
311 : }
312 : }
313 : // Angle ~ 90° (vertical)
314 0 : else if( nAngle < 1125 )
315 : {
316 0 : switch( rHatch.Style )
317 : {
318 : case drawing::HatchStyle_SINGLE:
319 : {
320 : // dkVert is imported as Distance = 25, ltVert as Distance = 50, export them accordingly.
321 0 : if( rHatch.Distance < 50 )
322 0 : sPattern = "dkVert";
323 0 : else if( rHatch.Distance < 75 )
324 0 : sPattern = "ltVert";
325 : else
326 0 : sPattern = "vert";
327 :
328 0 : break;
329 : }
330 : case drawing::HatchStyle_DOUBLE:
331 : case drawing::HatchStyle_TRIPLE:
332 : {
333 0 : if( rHatch.Distance < 75 )
334 0 : sPattern = "smGrid";
335 : else
336 0 : sPattern = "lgGrid";
337 :
338 0 : break;
339 : }
340 0 : default: break;
341 : }
342 : }
343 : // Angle ~ 135° (downward diagonal)
344 0 : else if( nAngle < 1575 )
345 : {
346 0 : switch( rHatch.Style )
347 : {
348 : case drawing::HatchStyle_SINGLE:
349 : {
350 0 : if( rHatch.Distance < 75 )
351 0 : sPattern = "ltDnDiag";
352 : else
353 0 : sPattern = "wdDnDiag";
354 :
355 0 : break;
356 : }
357 : case drawing::HatchStyle_DOUBLE:
358 : case drawing::HatchStyle_TRIPLE:
359 : {
360 0 : if( rHatch.Distance < 75 )
361 0 : sPattern = "smCheck";
362 : else
363 0 : sPattern = "openDmnd";
364 :
365 0 : break;
366 : }
367 0 : default: break;
368 : }
369 : }
370 0 : return sPattern;
371 : }
372 :
373 : /** converts the attributes from a CT_RelativeRect to an IntegerRectangle2D */
374 0 : IntegerRectangle2D GetRelativeRect( const Reference< XFastAttributeList >& xAttribs )
375 : {
376 0 : IntegerRectangle2D r;
377 :
378 0 : r.X1 = xAttribs->getOptionalValue( XML_l ).toInt32();
379 0 : r.Y1 = xAttribs->getOptionalValue( XML_t ).toInt32();
380 0 : r.X2 = xAttribs->getOptionalValue( XML_r ).toInt32();
381 0 : r.Y2 = xAttribs->getOptionalValue( XML_b ).toInt32();
382 :
383 0 : return r;
384 : }
385 :
386 :
387 :
388 : /** converts the attributes from an CT_Size2D into an awt Size with 1/100thmm */
389 0 : awt::Size GetSize2D( const Reference< XFastAttributeList >& xAttribs )
390 : {
391 0 : return awt::Size( GetCoordinate( xAttribs->getOptionalValue( XML_cx ) ), GetCoordinate( xAttribs->getOptionalValue( XML_cy ) ) );
392 : }
393 :
394 0 : IndexRange GetIndexRange( const Reference< XFastAttributeList >& xAttributes )
395 : {
396 : IndexRange range;
397 0 : range.start = xAttributes->getOptionalValue( XML_st ).toInt32();
398 0 : range.end = xAttributes->getOptionalValue( XML_end ).toInt32();
399 0 : return range;
400 : }
401 :
402 :
403 :
404 : } // namespace drawingml
405 : } // namespace oox
406 :
407 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|