1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_xmloff.hxx"
26*b1cdbd2cSJim Jagielski #include "ximpcustomshape.hxx"
27*b1cdbd2cSJim Jagielski #include "ximpshap.hxx"
28*b1cdbd2cSJim Jagielski #include "xmlehelp.hxx"
29*b1cdbd2cSJim Jagielski #include <rtl/math.hxx>
30*b1cdbd2cSJim Jagielski #include <rtl/ustrbuf.hxx>
31*b1cdbd2cSJim Jagielski #include <rtl/ustring.hxx>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/uno/Reference.h>
33*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/XPropertySet.hpp>
34*b1cdbd2cSJim Jagielski #include <com/sun/star/xml/sax/XAttributeList.hpp>
35*b1cdbd2cSJim Jagielski #include <com/sun/star/container/XIndexContainer.hpp>
36*b1cdbd2cSJim Jagielski #include <xmloff/xmltoken.hxx>
37*b1cdbd2cSJim Jagielski #include "EnhancedCustomShapeToken.hxx"
38*b1cdbd2cSJim Jagielski #include <xmloff/xmlimp.hxx>
39*b1cdbd2cSJim Jagielski #include <xmloff/xmltkmap.hxx>
40*b1cdbd2cSJim Jagielski #include "xmloff/xmlnmspe.hxx"
41*b1cdbd2cSJim Jagielski #include <xmloff/nmspmap.hxx>
42*b1cdbd2cSJim Jagielski #include <xmloff/xmluconv.hxx>
43*b1cdbd2cSJim Jagielski #include "xexptran.hxx"
44*b1cdbd2cSJim Jagielski #include "xmloff/xmlerror.hxx"
45*b1cdbd2cSJim Jagielski #include <tools/debug.hxx>
46*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/Direction3D.hpp>
47*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeParameterPair.hpp>
48*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeParameterType.hpp>
49*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeTextFrame.hpp>
50*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeAdjustmentValue.hpp>
51*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeSegment.hpp>
52*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeSegmentCommand.hpp>
53*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/EnhancedCustomShapeTextPathMode.hpp>
54*b1cdbd2cSJim Jagielski #include <com/sun/star/drawing/ProjectionMode.hpp>
55*b1cdbd2cSJim Jagielski #include <hash_map>
56*b1cdbd2cSJim Jagielski
57*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
58*b1cdbd2cSJim Jagielski using namespace ::xmloff::token;
59*b1cdbd2cSJim Jagielski using namespace ::xmloff::EnhancedCustomShapeToken;
60*b1cdbd2cSJim Jagielski
61*b1cdbd2cSJim Jagielski TYPEINIT1( XMLEnhancedCustomShapeContext, SvXMLImportContext );
62*b1cdbd2cSJim Jagielski
XMLEnhancedCustomShapeContext(SvXMLImport & rImport,::com::sun::star::uno::Reference<::com::sun::star::drawing::XShape> & rxShape,sal_uInt16 nPrefix,const rtl::OUString & rLocalName,std::vector<com::sun::star::beans::PropertyValue> & rCustomShapeGeometry)63*b1cdbd2cSJim Jagielski XMLEnhancedCustomShapeContext::XMLEnhancedCustomShapeContext( SvXMLImport& rImport,
64*b1cdbd2cSJim Jagielski ::com::sun::star::uno::Reference< ::com::sun::star::drawing::XShape >& rxShape,
65*b1cdbd2cSJim Jagielski sal_uInt16 nPrefix, const rtl::OUString& rLocalName,
66*b1cdbd2cSJim Jagielski std::vector< com::sun::star::beans::PropertyValue >& rCustomShapeGeometry ) :
67*b1cdbd2cSJim Jagielski SvXMLImportContext( rImport, nPrefix, rLocalName ),
68*b1cdbd2cSJim Jagielski mrUnitConverter( rImport.GetMM100UnitConverter() ),
69*b1cdbd2cSJim Jagielski mrxShape( rxShape ),
70*b1cdbd2cSJim Jagielski mrCustomShapeGeometry( rCustomShapeGeometry )
71*b1cdbd2cSJim Jagielski {
72*b1cdbd2cSJim Jagielski }
73*b1cdbd2cSJim Jagielski
74*b1cdbd2cSJim Jagielski const SvXMLEnumMapEntry aXML_GluePointEnumMap[] =
75*b1cdbd2cSJim Jagielski {
76*b1cdbd2cSJim Jagielski { XML_NONE, 0 },
77*b1cdbd2cSJim Jagielski { XML_SEGMENTS, 1 },
78*b1cdbd2cSJim Jagielski { XML_NONE, 2 },
79*b1cdbd2cSJim Jagielski { XML_RECTANGLE, 3 },
80*b1cdbd2cSJim Jagielski { XML_TOKEN_INVALID, 0 }
81*b1cdbd2cSJim Jagielski };
GetBool(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)82*b1cdbd2cSJim Jagielski void GetBool( std::vector< com::sun::star::beans::PropertyValue >& rDest,
83*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
84*b1cdbd2cSJim Jagielski {
85*b1cdbd2cSJim Jagielski sal_Bool bAttrBool;
86*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertBool( bAttrBool, rValue ) )
87*b1cdbd2cSJim Jagielski {
88*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
89*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
90*b1cdbd2cSJim Jagielski aProp.Value <<= bAttrBool;
91*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
92*b1cdbd2cSJim Jagielski }
93*b1cdbd2cSJim Jagielski }
94*b1cdbd2cSJim Jagielski
GetInt32(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)95*b1cdbd2cSJim Jagielski void GetInt32( std::vector< com::sun::star::beans::PropertyValue >& rDest,
96*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
97*b1cdbd2cSJim Jagielski {
98*b1cdbd2cSJim Jagielski sal_Int32 nAttrNumber;
99*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertNumber( nAttrNumber, rValue ) )
100*b1cdbd2cSJim Jagielski {
101*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
102*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
103*b1cdbd2cSJim Jagielski aProp.Value <<= nAttrNumber;
104*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
105*b1cdbd2cSJim Jagielski }
106*b1cdbd2cSJim Jagielski }
107*b1cdbd2cSJim Jagielski
GetDouble(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)108*b1cdbd2cSJim Jagielski void GetDouble( std::vector< com::sun::star::beans::PropertyValue >& rDest,
109*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
110*b1cdbd2cSJim Jagielski {
111*b1cdbd2cSJim Jagielski double fAttrDouble;
112*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertDouble( fAttrDouble, rValue ) )
113*b1cdbd2cSJim Jagielski {
114*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
115*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
116*b1cdbd2cSJim Jagielski aProp.Value <<= fAttrDouble;
117*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
118*b1cdbd2cSJim Jagielski }
119*b1cdbd2cSJim Jagielski }
120*b1cdbd2cSJim Jagielski
GetDistance(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)121*b1cdbd2cSJim Jagielski void GetDistance( std::vector< com::sun::star::beans::PropertyValue >& rDest,
122*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
123*b1cdbd2cSJim Jagielski {
124*b1cdbd2cSJim Jagielski double fAttrDouble;
125*b1cdbd2cSJim Jagielski MapUnit eSrcUnit( SvXMLExportHelper::GetUnitFromString( rValue, MAP_100TH_MM ) );
126*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertDouble( fAttrDouble, rValue, eSrcUnit, MAP_100TH_MM ) )
127*b1cdbd2cSJim Jagielski {
128*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
129*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
130*b1cdbd2cSJim Jagielski aProp.Value <<= fAttrDouble;
131*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
132*b1cdbd2cSJim Jagielski }
133*b1cdbd2cSJim Jagielski }
134*b1cdbd2cSJim Jagielski
GetString(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)135*b1cdbd2cSJim Jagielski void GetString( std::vector< com::sun::star::beans::PropertyValue >& rDest,
136*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
137*b1cdbd2cSJim Jagielski {
138*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
139*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
140*b1cdbd2cSJim Jagielski aProp.Value <<= rValue;
141*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
142*b1cdbd2cSJim Jagielski }
143*b1cdbd2cSJim Jagielski
GetEnum(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp,const SvXMLEnumMapEntry & rMap)144*b1cdbd2cSJim Jagielski void GetEnum( std::vector< com::sun::star::beans::PropertyValue >& rDest,
145*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp,
146*b1cdbd2cSJim Jagielski const SvXMLEnumMapEntry& rMap )
147*b1cdbd2cSJim Jagielski {
148*b1cdbd2cSJim Jagielski sal_uInt16 eKind;
149*b1cdbd2cSJim Jagielski if( SvXMLUnitConverter::convertEnum( eKind, rValue, &rMap ) )
150*b1cdbd2cSJim Jagielski {
151*b1cdbd2cSJim Jagielski sal_Int16 nEnum = (sal_Int16)eKind;
152*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
153*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
154*b1cdbd2cSJim Jagielski aProp.Value <<= nEnum;
155*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
156*b1cdbd2cSJim Jagielski }
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski
GetDoublePercentage(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)159*b1cdbd2cSJim Jagielski void GetDoublePercentage( std::vector< com::sun::star::beans::PropertyValue >& rDest,
160*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
161*b1cdbd2cSJim Jagielski {
162*b1cdbd2cSJim Jagielski MapUnit eSrcUnit = SvXMLExportHelper::GetUnitFromString( rValue, MAP_100TH_MM );
163*b1cdbd2cSJim Jagielski if ( eSrcUnit == MAP_RELATIVE )
164*b1cdbd2cSJim Jagielski {
165*b1cdbd2cSJim Jagielski rtl_math_ConversionStatus eStatus;
166*b1cdbd2cSJim Jagielski double fAttrDouble = ::rtl::math::stringToDouble( rValue,
167*b1cdbd2cSJim Jagielski (sal_Unicode)('.'), (sal_Unicode)(','), &eStatus, NULL );
168*b1cdbd2cSJim Jagielski if ( eStatus == rtl_math_ConversionStatus_Ok )
169*b1cdbd2cSJim Jagielski {
170*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
171*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
172*b1cdbd2cSJim Jagielski aProp.Value <<= fAttrDouble;
173*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
174*b1cdbd2cSJim Jagielski }
175*b1cdbd2cSJim Jagielski }
176*b1cdbd2cSJim Jagielski }
177*b1cdbd2cSJim Jagielski
GetB3DVector(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)178*b1cdbd2cSJim Jagielski void GetB3DVector( std::vector< com::sun::star::beans::PropertyValue >& rDest,
179*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
180*b1cdbd2cSJim Jagielski {
181*b1cdbd2cSJim Jagielski ::basegfx::B3DVector aB3DVector;
182*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertB3DVector( aB3DVector, rValue ) )
183*b1cdbd2cSJim Jagielski {
184*b1cdbd2cSJim Jagielski drawing::Direction3D aDirection3D( aB3DVector.getX(), aB3DVector.getY(), aB3DVector.getZ() );
185*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
186*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
187*b1cdbd2cSJim Jagielski aProp.Value <<= aDirection3D;
188*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
189*b1cdbd2cSJim Jagielski }
190*b1cdbd2cSJim Jagielski }
191*b1cdbd2cSJim Jagielski
GetEquationName(const rtl::OUString & rEquation,const sal_Int32 nStart,rtl::OUString & rEquationName)192*b1cdbd2cSJim Jagielski sal_Bool GetEquationName( const rtl::OUString& rEquation, const sal_Int32 nStart, rtl::OUString& rEquationName )
193*b1cdbd2cSJim Jagielski {
194*b1cdbd2cSJim Jagielski sal_Int32 nIndex = nStart;
195*b1cdbd2cSJim Jagielski while( nIndex < rEquation.getLength() )
196*b1cdbd2cSJim Jagielski {
197*b1cdbd2cSJim Jagielski sal_Unicode nChar = rEquation[ nIndex ];
198*b1cdbd2cSJim Jagielski if (
199*b1cdbd2cSJim Jagielski ( ( nChar >= 'a' ) && ( nChar <= 'z' ) )
200*b1cdbd2cSJim Jagielski || ( ( nChar >= 'A' ) && ( nChar <= 'Z' ) )
201*b1cdbd2cSJim Jagielski || ( ( nChar >= '0' ) && ( nChar <= '9' ) )
202*b1cdbd2cSJim Jagielski )
203*b1cdbd2cSJim Jagielski {
204*b1cdbd2cSJim Jagielski nIndex++;
205*b1cdbd2cSJim Jagielski }
206*b1cdbd2cSJim Jagielski else
207*b1cdbd2cSJim Jagielski break;
208*b1cdbd2cSJim Jagielski }
209*b1cdbd2cSJim Jagielski sal_Bool bValid = ( nIndex - nStart ) != 0;
210*b1cdbd2cSJim Jagielski if ( bValid )
211*b1cdbd2cSJim Jagielski rEquationName = rEquation.copy( nStart, nIndex - nStart );
212*b1cdbd2cSJim Jagielski return bValid;
213*b1cdbd2cSJim Jagielski }
214*b1cdbd2cSJim Jagielski
GetNextParameter(com::sun::star::drawing::EnhancedCustomShapeParameter & rParameter,sal_Int32 & nIndex,const rtl::OUString & rParaString)215*b1cdbd2cSJim Jagielski sal_Bool GetNextParameter( com::sun::star::drawing::EnhancedCustomShapeParameter& rParameter, sal_Int32& nIndex, const rtl::OUString& rParaString )
216*b1cdbd2cSJim Jagielski {
217*b1cdbd2cSJim Jagielski if ( nIndex >= rParaString.getLength() )
218*b1cdbd2cSJim Jagielski return sal_False;
219*b1cdbd2cSJim Jagielski
220*b1cdbd2cSJim Jagielski sal_Bool bValid = sal_True;
221*b1cdbd2cSJim Jagielski sal_Bool bNumberRequired = sal_True;
222*b1cdbd2cSJim Jagielski sal_Bool bMustBePositiveWholeNumbered = sal_False;
223*b1cdbd2cSJim Jagielski
224*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::NORMAL;
225*b1cdbd2cSJim Jagielski if ( rParaString[ nIndex ] == (sal_Unicode)'$' )
226*b1cdbd2cSJim Jagielski {
227*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::ADJUSTMENT;
228*b1cdbd2cSJim Jagielski bMustBePositiveWholeNumbered = sal_True;
229*b1cdbd2cSJim Jagielski nIndex++;
230*b1cdbd2cSJim Jagielski }
231*b1cdbd2cSJim Jagielski else if ( rParaString[ nIndex ] == (sal_Unicode)'?' )
232*b1cdbd2cSJim Jagielski {
233*b1cdbd2cSJim Jagielski nIndex++;
234*b1cdbd2cSJim Jagielski bNumberRequired = sal_False;
235*b1cdbd2cSJim Jagielski rtl::OUString aEquationName;
236*b1cdbd2cSJim Jagielski bValid = GetEquationName( rParaString, nIndex, aEquationName );
237*b1cdbd2cSJim Jagielski if ( bValid )
238*b1cdbd2cSJim Jagielski {
239*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::EQUATION;
240*b1cdbd2cSJim Jagielski rParameter.Value <<= aEquationName;
241*b1cdbd2cSJim Jagielski nIndex += aEquationName.getLength();
242*b1cdbd2cSJim Jagielski }
243*b1cdbd2cSJim Jagielski }
244*b1cdbd2cSJim Jagielski else if ( rParaString[ nIndex ] > (sal_Unicode)'9' )
245*b1cdbd2cSJim Jagielski {
246*b1cdbd2cSJim Jagielski bNumberRequired = sal_False;
247*b1cdbd2cSJim Jagielski if ( rParaString.matchIgnoreAsciiCaseAsciiL( "left", 4, nIndex ) )
248*b1cdbd2cSJim Jagielski {
249*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::LEFT;
250*b1cdbd2cSJim Jagielski nIndex += 4;
251*b1cdbd2cSJim Jagielski }
252*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "top", 3, nIndex ) )
253*b1cdbd2cSJim Jagielski {
254*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::TOP;
255*b1cdbd2cSJim Jagielski nIndex += 3;
256*b1cdbd2cSJim Jagielski }
257*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "right", 5, nIndex ) )
258*b1cdbd2cSJim Jagielski {
259*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::RIGHT;
260*b1cdbd2cSJim Jagielski nIndex += 5;
261*b1cdbd2cSJim Jagielski }
262*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "bottom", 6, nIndex ) )
263*b1cdbd2cSJim Jagielski {
264*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::BOTTOM;
265*b1cdbd2cSJim Jagielski nIndex += 6;
266*b1cdbd2cSJim Jagielski }
267*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "xstretch", 8, nIndex ) )
268*b1cdbd2cSJim Jagielski {
269*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::XSTRETCH;
270*b1cdbd2cSJim Jagielski nIndex += 8;
271*b1cdbd2cSJim Jagielski }
272*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "ystretch", 8, nIndex ) )
273*b1cdbd2cSJim Jagielski {
274*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::YSTRETCH;
275*b1cdbd2cSJim Jagielski nIndex += 8;
276*b1cdbd2cSJim Jagielski }
277*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "hasstroke", 9, nIndex ) )
278*b1cdbd2cSJim Jagielski {
279*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::HASSTROKE;
280*b1cdbd2cSJim Jagielski nIndex += 9;
281*b1cdbd2cSJim Jagielski }
282*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "hasfill", 7, nIndex ) )
283*b1cdbd2cSJim Jagielski {
284*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::HASFILL;
285*b1cdbd2cSJim Jagielski nIndex += 7;
286*b1cdbd2cSJim Jagielski }
287*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "width", 5, nIndex ) )
288*b1cdbd2cSJim Jagielski {
289*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::WIDTH;
290*b1cdbd2cSJim Jagielski nIndex += 5;
291*b1cdbd2cSJim Jagielski }
292*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "height", 6, nIndex ) )
293*b1cdbd2cSJim Jagielski {
294*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::HEIGHT;
295*b1cdbd2cSJim Jagielski nIndex += 6;
296*b1cdbd2cSJim Jagielski }
297*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "logwidth", 8, nIndex ) )
298*b1cdbd2cSJim Jagielski {
299*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::LOGWIDTH;
300*b1cdbd2cSJim Jagielski nIndex += 8;
301*b1cdbd2cSJim Jagielski }
302*b1cdbd2cSJim Jagielski else if ( rParaString.matchIgnoreAsciiCaseAsciiL( "logheight", 9, nIndex ) )
303*b1cdbd2cSJim Jagielski {
304*b1cdbd2cSJim Jagielski rParameter.Type = com::sun::star::drawing::EnhancedCustomShapeParameterType::LOGHEIGHT;
305*b1cdbd2cSJim Jagielski nIndex += 9;
306*b1cdbd2cSJim Jagielski }
307*b1cdbd2cSJim Jagielski else
308*b1cdbd2cSJim Jagielski bValid = sal_False;
309*b1cdbd2cSJim Jagielski }
310*b1cdbd2cSJim Jagielski if ( bValid )
311*b1cdbd2cSJim Jagielski {
312*b1cdbd2cSJim Jagielski if ( bNumberRequired )
313*b1cdbd2cSJim Jagielski {
314*b1cdbd2cSJim Jagielski sal_Int32 nStartIndex = nIndex;
315*b1cdbd2cSJim Jagielski
316*b1cdbd2cSJim Jagielski sal_Bool bM = sal_False; // set if the value is negative
317*b1cdbd2cSJim Jagielski sal_Bool bE = sal_False; // set if a double is including a "E" statement
318*b1cdbd2cSJim Jagielski sal_Bool bEM = sal_False; // set if a double is including a "E-"statement
319*b1cdbd2cSJim Jagielski sal_Bool bDot = sal_False; // set if there is a dot included
320*b1cdbd2cSJim Jagielski sal_Bool bEnd = sal_False; // set for each value that can not be part of a double/integer
321*b1cdbd2cSJim Jagielski
322*b1cdbd2cSJim Jagielski while( ( nIndex < rParaString.getLength() ) && bValid )
323*b1cdbd2cSJim Jagielski {
324*b1cdbd2cSJim Jagielski switch( rParaString[ nIndex ] )
325*b1cdbd2cSJim Jagielski {
326*b1cdbd2cSJim Jagielski case '.' :
327*b1cdbd2cSJim Jagielski {
328*b1cdbd2cSJim Jagielski if ( bMustBePositiveWholeNumbered )
329*b1cdbd2cSJim Jagielski bValid = sal_False;
330*b1cdbd2cSJim Jagielski else
331*b1cdbd2cSJim Jagielski {
332*b1cdbd2cSJim Jagielski if ( bDot )
333*b1cdbd2cSJim Jagielski bValid = sal_False;
334*b1cdbd2cSJim Jagielski else
335*b1cdbd2cSJim Jagielski bDot = sal_True;
336*b1cdbd2cSJim Jagielski }
337*b1cdbd2cSJim Jagielski }
338*b1cdbd2cSJim Jagielski break;
339*b1cdbd2cSJim Jagielski case '-' :
340*b1cdbd2cSJim Jagielski {
341*b1cdbd2cSJim Jagielski if ( bMustBePositiveWholeNumbered )
342*b1cdbd2cSJim Jagielski bValid = sal_False;
343*b1cdbd2cSJim Jagielski else
344*b1cdbd2cSJim Jagielski {
345*b1cdbd2cSJim Jagielski if ( nStartIndex == nIndex )
346*b1cdbd2cSJim Jagielski bM = sal_True;
347*b1cdbd2cSJim Jagielski else if ( bE )
348*b1cdbd2cSJim Jagielski bEM = sal_True;
349*b1cdbd2cSJim Jagielski else
350*b1cdbd2cSJim Jagielski bValid = sal_False;
351*b1cdbd2cSJim Jagielski }
352*b1cdbd2cSJim Jagielski }
353*b1cdbd2cSJim Jagielski break;
354*b1cdbd2cSJim Jagielski
355*b1cdbd2cSJim Jagielski case 'e' :
356*b1cdbd2cSJim Jagielski case 'E' :
357*b1cdbd2cSJim Jagielski {
358*b1cdbd2cSJim Jagielski if ( bMustBePositiveWholeNumbered )
359*b1cdbd2cSJim Jagielski bEnd = sal_True;
360*b1cdbd2cSJim Jagielski else
361*b1cdbd2cSJim Jagielski {
362*b1cdbd2cSJim Jagielski if ( !bE )
363*b1cdbd2cSJim Jagielski bE = sal_True;
364*b1cdbd2cSJim Jagielski else
365*b1cdbd2cSJim Jagielski bEnd = sal_True;
366*b1cdbd2cSJim Jagielski }
367*b1cdbd2cSJim Jagielski }
368*b1cdbd2cSJim Jagielski break;
369*b1cdbd2cSJim Jagielski case '0' :
370*b1cdbd2cSJim Jagielski case '1' :
371*b1cdbd2cSJim Jagielski case '2' :
372*b1cdbd2cSJim Jagielski case '3' :
373*b1cdbd2cSJim Jagielski case '4' :
374*b1cdbd2cSJim Jagielski case '5' :
375*b1cdbd2cSJim Jagielski case '6' :
376*b1cdbd2cSJim Jagielski case '7' :
377*b1cdbd2cSJim Jagielski case '8' :
378*b1cdbd2cSJim Jagielski case '9' :
379*b1cdbd2cSJim Jagielski break;
380*b1cdbd2cSJim Jagielski default:
381*b1cdbd2cSJim Jagielski bEnd = sal_True;
382*b1cdbd2cSJim Jagielski }
383*b1cdbd2cSJim Jagielski if ( !bEnd )
384*b1cdbd2cSJim Jagielski nIndex++;
385*b1cdbd2cSJim Jagielski else
386*b1cdbd2cSJim Jagielski break;
387*b1cdbd2cSJim Jagielski }
388*b1cdbd2cSJim Jagielski if ( nIndex == nStartIndex )
389*b1cdbd2cSJim Jagielski bValid = sal_False;
390*b1cdbd2cSJim Jagielski if ( bValid )
391*b1cdbd2cSJim Jagielski {
392*b1cdbd2cSJim Jagielski rtl::OUString aNumber( rParaString.copy( nStartIndex, nIndex - nStartIndex ) );
393*b1cdbd2cSJim Jagielski if ( bE || bDot )
394*b1cdbd2cSJim Jagielski {
395*b1cdbd2cSJim Jagielski double fAttrDouble;
396*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertDouble( fAttrDouble, aNumber ) )
397*b1cdbd2cSJim Jagielski rParameter.Value <<= fAttrDouble;
398*b1cdbd2cSJim Jagielski else
399*b1cdbd2cSJim Jagielski bValid = sal_False;
400*b1cdbd2cSJim Jagielski }
401*b1cdbd2cSJim Jagielski else
402*b1cdbd2cSJim Jagielski {
403*b1cdbd2cSJim Jagielski sal_Int32 nValue;
404*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertNumber( nValue, aNumber ) )
405*b1cdbd2cSJim Jagielski rParameter.Value <<= nValue;
406*b1cdbd2cSJim Jagielski else
407*b1cdbd2cSJim Jagielski bValid = sal_False;
408*b1cdbd2cSJim Jagielski }
409*b1cdbd2cSJim Jagielski }
410*b1cdbd2cSJim Jagielski }
411*b1cdbd2cSJim Jagielski }
412*b1cdbd2cSJim Jagielski if ( bValid )
413*b1cdbd2cSJim Jagielski {
414*b1cdbd2cSJim Jagielski // skipping white spaces and commatas (#121507#)
415*b1cdbd2cSJim Jagielski const sal_Unicode aSpace(sal_Unicode(' '));
416*b1cdbd2cSJim Jagielski const sal_Unicode aCommata(sal_Unicode(','));
417*b1cdbd2cSJim Jagielski
418*b1cdbd2cSJim Jagielski while(nIndex < rParaString.getLength())
419*b1cdbd2cSJim Jagielski {
420*b1cdbd2cSJim Jagielski const sal_Unicode aCandidate(rParaString[nIndex]);
421*b1cdbd2cSJim Jagielski
422*b1cdbd2cSJim Jagielski if(aSpace == aCandidate || aCommata == aCandidate)
423*b1cdbd2cSJim Jagielski {
424*b1cdbd2cSJim Jagielski nIndex++;
425*b1cdbd2cSJim Jagielski }
426*b1cdbd2cSJim Jagielski else
427*b1cdbd2cSJim Jagielski {
428*b1cdbd2cSJim Jagielski break;
429*b1cdbd2cSJim Jagielski }
430*b1cdbd2cSJim Jagielski }
431*b1cdbd2cSJim Jagielski }
432*b1cdbd2cSJim Jagielski return bValid;
433*b1cdbd2cSJim Jagielski }
434*b1cdbd2cSJim Jagielski
GetPosition3D(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp,SvXMLUnitConverter & rUnitConverter)435*b1cdbd2cSJim Jagielski void GetPosition3D( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:extrusion-viewpoint
436*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp,
437*b1cdbd2cSJim Jagielski SvXMLUnitConverter& rUnitConverter )
438*b1cdbd2cSJim Jagielski {
439*b1cdbd2cSJim Jagielski drawing::Position3D aPosition3D;
440*b1cdbd2cSJim Jagielski if ( rUnitConverter.convertPosition3D( aPosition3D, rValue ) )
441*b1cdbd2cSJim Jagielski {
442*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
443*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
444*b1cdbd2cSJim Jagielski aProp.Value <<= aPosition3D;
445*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
446*b1cdbd2cSJim Jagielski }
447*b1cdbd2cSJim Jagielski }
448*b1cdbd2cSJim Jagielski
GetDoubleSequence(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)449*b1cdbd2cSJim Jagielski void GetDoubleSequence( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:glue-point-leaving-directions
450*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
451*b1cdbd2cSJim Jagielski {
452*b1cdbd2cSJim Jagielski std::vector< double > vDirection;
453*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
454*b1cdbd2cSJim Jagielski do
455*b1cdbd2cSJim Jagielski {
456*b1cdbd2cSJim Jagielski double fAttrDouble;
457*b1cdbd2cSJim Jagielski rtl::OUString aToken( rValue.getToken( 0, ',', nIndex ) );
458*b1cdbd2cSJim Jagielski if ( !SvXMLUnitConverter::convertDouble( fAttrDouble, aToken ) )
459*b1cdbd2cSJim Jagielski break;
460*b1cdbd2cSJim Jagielski else
461*b1cdbd2cSJim Jagielski vDirection.push_back( fAttrDouble );
462*b1cdbd2cSJim Jagielski }
463*b1cdbd2cSJim Jagielski while ( nIndex >= 0 );
464*b1cdbd2cSJim Jagielski
465*b1cdbd2cSJim Jagielski if ( !vDirection.empty() )
466*b1cdbd2cSJim Jagielski {
467*b1cdbd2cSJim Jagielski uno::Sequence< double > aDirectionsSeq( vDirection.size() );
468*b1cdbd2cSJim Jagielski std::vector< double >::const_iterator aIter = vDirection.begin();
469*b1cdbd2cSJim Jagielski std::vector< double >::const_iterator aEnd = vDirection.end();
470*b1cdbd2cSJim Jagielski double* pValues = aDirectionsSeq.getArray();
471*b1cdbd2cSJim Jagielski
472*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
473*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
474*b1cdbd2cSJim Jagielski
475*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
476*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
477*b1cdbd2cSJim Jagielski aProp.Value <<= aDirectionsSeq;
478*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
479*b1cdbd2cSJim Jagielski }
480*b1cdbd2cSJim Jagielski }
481*b1cdbd2cSJim Jagielski
GetEnhancedParameter(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)482*b1cdbd2cSJim Jagielski void GetEnhancedParameter( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:handle-position
483*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
484*b1cdbd2cSJim Jagielski {
485*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
486*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameter aParameter;
487*b1cdbd2cSJim Jagielski if ( GetNextParameter( aParameter, nIndex, rValue ) )
488*b1cdbd2cSJim Jagielski {
489*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
490*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
491*b1cdbd2cSJim Jagielski aProp.Value <<= aParameter;
492*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
493*b1cdbd2cSJim Jagielski }
494*b1cdbd2cSJim Jagielski }
495*b1cdbd2cSJim Jagielski
GetEnhancedParameterPair(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)496*b1cdbd2cSJim Jagielski void GetEnhancedParameterPair( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:handle-position
497*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
498*b1cdbd2cSJim Jagielski {
499*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
500*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair aParameterPair;
501*b1cdbd2cSJim Jagielski if ( GetNextParameter( aParameterPair.First, nIndex, rValue )
502*b1cdbd2cSJim Jagielski && GetNextParameter( aParameterPair.Second, nIndex, rValue ) )
503*b1cdbd2cSJim Jagielski {
504*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
505*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
506*b1cdbd2cSJim Jagielski aProp.Value <<= aParameterPair;
507*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
508*b1cdbd2cSJim Jagielski }
509*b1cdbd2cSJim Jagielski }
510*b1cdbd2cSJim Jagielski
GetEnhancedParameterPairSequence(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)511*b1cdbd2cSJim Jagielski sal_Int32 GetEnhancedParameterPairSequence( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:glue-points
512*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
513*b1cdbd2cSJim Jagielski {
514*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair > vParameter;
515*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair aParameter;
516*b1cdbd2cSJim Jagielski
517*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
518*b1cdbd2cSJim Jagielski while ( GetNextParameter( aParameter.First, nIndex, rValue )
519*b1cdbd2cSJim Jagielski && GetNextParameter( aParameter.Second, nIndex, rValue ) )
520*b1cdbd2cSJim Jagielski {
521*b1cdbd2cSJim Jagielski vParameter.push_back( aParameter );
522*b1cdbd2cSJim Jagielski }
523*b1cdbd2cSJim Jagielski if ( !vParameter.empty() )
524*b1cdbd2cSJim Jagielski {
525*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeParameterPair > aParameterSeq( vParameter.size() );
526*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair >::const_iterator aIter = vParameter.begin();
527*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair >::const_iterator aEnd = vParameter.end();
528*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair* pValues = aParameterSeq.getArray();
529*b1cdbd2cSJim Jagielski
530*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
531*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
532*b1cdbd2cSJim Jagielski
533*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
534*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
535*b1cdbd2cSJim Jagielski aProp.Value <<= aParameterSeq;
536*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
537*b1cdbd2cSJim Jagielski }
538*b1cdbd2cSJim Jagielski return vParameter.size();
539*b1cdbd2cSJim Jagielski }
540*b1cdbd2cSJim Jagielski
GetEnhancedRectangleSequence(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue,const EnhancedCustomShapeTokenEnum eDestProp)541*b1cdbd2cSJim Jagielski void GetEnhancedRectangleSequence( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:text-areas
542*b1cdbd2cSJim Jagielski const rtl::OUString& rValue, const EnhancedCustomShapeTokenEnum eDestProp )
543*b1cdbd2cSJim Jagielski {
544*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeTextFrame > vTextFrame;
545*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeTextFrame aParameter;
546*b1cdbd2cSJim Jagielski
547*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
548*b1cdbd2cSJim Jagielski
549*b1cdbd2cSJim Jagielski while ( GetNextParameter( aParameter.TopLeft.First, nIndex, rValue )
550*b1cdbd2cSJim Jagielski && GetNextParameter( aParameter.TopLeft.Second, nIndex, rValue )
551*b1cdbd2cSJim Jagielski && GetNextParameter( aParameter.BottomRight.First, nIndex, rValue )
552*b1cdbd2cSJim Jagielski && GetNextParameter( aParameter.BottomRight.Second, nIndex, rValue ) )
553*b1cdbd2cSJim Jagielski {
554*b1cdbd2cSJim Jagielski vTextFrame.push_back( aParameter );
555*b1cdbd2cSJim Jagielski }
556*b1cdbd2cSJim Jagielski if ( !vTextFrame.empty() )
557*b1cdbd2cSJim Jagielski {
558*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeTextFrame > aTextFrameSeq( vTextFrame.size() );
559*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeTextFrame >::const_iterator aIter = vTextFrame.begin();
560*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeTextFrame >::const_iterator aEnd = vTextFrame.end();
561*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeTextFrame* pValues = aTextFrameSeq.getArray();
562*b1cdbd2cSJim Jagielski
563*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
564*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
565*b1cdbd2cSJim Jagielski
566*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
567*b1cdbd2cSJim Jagielski aProp.Name = EASGet( eDestProp );
568*b1cdbd2cSJim Jagielski aProp.Value <<= aTextFrameSeq;
569*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
570*b1cdbd2cSJim Jagielski }
571*b1cdbd2cSJim Jagielski }
572*b1cdbd2cSJim Jagielski
GetEnhancedPath(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue)573*b1cdbd2cSJim Jagielski void GetEnhancedPath( std::vector< com::sun::star::beans::PropertyValue >& rDest, // e.g. draw:enhanced-path
574*b1cdbd2cSJim Jagielski const rtl::OUString& rValue )
575*b1cdbd2cSJim Jagielski {
576*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair > vCoordinates;
577*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeSegment > vSegments;
578*b1cdbd2cSJim Jagielski
579*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
580*b1cdbd2cSJim Jagielski sal_Int32 nParameterCount = 0;
581*b1cdbd2cSJim Jagielski
582*b1cdbd2cSJim Jagielski sal_Int32 nParametersNeeded = 1;
583*b1cdbd2cSJim Jagielski sal_Int16 nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::MOVETO;
584*b1cdbd2cSJim Jagielski
585*b1cdbd2cSJim Jagielski sal_Bool bValid = sal_True;
586*b1cdbd2cSJim Jagielski
587*b1cdbd2cSJim Jagielski while( bValid && ( nIndex < rValue.getLength() ) )
588*b1cdbd2cSJim Jagielski {
589*b1cdbd2cSJim Jagielski switch( rValue[ nIndex ] )
590*b1cdbd2cSJim Jagielski {
591*b1cdbd2cSJim Jagielski case 'M' :
592*b1cdbd2cSJim Jagielski {
593*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::MOVETO;
594*b1cdbd2cSJim Jagielski nParametersNeeded = 1;
595*b1cdbd2cSJim Jagielski nIndex++;
596*b1cdbd2cSJim Jagielski }
597*b1cdbd2cSJim Jagielski break;
598*b1cdbd2cSJim Jagielski case 'L' :
599*b1cdbd2cSJim Jagielski {
600*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::LINETO;
601*b1cdbd2cSJim Jagielski nParametersNeeded = 1;
602*b1cdbd2cSJim Jagielski nIndex++;
603*b1cdbd2cSJim Jagielski }
604*b1cdbd2cSJim Jagielski break;
605*b1cdbd2cSJim Jagielski case 'C' :
606*b1cdbd2cSJim Jagielski {
607*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::CURVETO;
608*b1cdbd2cSJim Jagielski nParametersNeeded = 3;
609*b1cdbd2cSJim Jagielski nIndex++;
610*b1cdbd2cSJim Jagielski }
611*b1cdbd2cSJim Jagielski break;
612*b1cdbd2cSJim Jagielski case 'Z' :
613*b1cdbd2cSJim Jagielski {
614*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::CLOSESUBPATH;
615*b1cdbd2cSJim Jagielski nParametersNeeded = 0;
616*b1cdbd2cSJim Jagielski nIndex++;
617*b1cdbd2cSJim Jagielski }
618*b1cdbd2cSJim Jagielski break;
619*b1cdbd2cSJim Jagielski case 'N' :
620*b1cdbd2cSJim Jagielski {
621*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ENDSUBPATH;
622*b1cdbd2cSJim Jagielski nParametersNeeded = 0;
623*b1cdbd2cSJim Jagielski nIndex++;
624*b1cdbd2cSJim Jagielski }
625*b1cdbd2cSJim Jagielski break;
626*b1cdbd2cSJim Jagielski case 'F' :
627*b1cdbd2cSJim Jagielski {
628*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::NOFILL;
629*b1cdbd2cSJim Jagielski nParametersNeeded = 0;
630*b1cdbd2cSJim Jagielski nIndex++;
631*b1cdbd2cSJim Jagielski }
632*b1cdbd2cSJim Jagielski break;
633*b1cdbd2cSJim Jagielski case 'S' :
634*b1cdbd2cSJim Jagielski {
635*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::NOSTROKE;
636*b1cdbd2cSJim Jagielski nParametersNeeded = 0;
637*b1cdbd2cSJim Jagielski nIndex++;
638*b1cdbd2cSJim Jagielski }
639*b1cdbd2cSJim Jagielski break;
640*b1cdbd2cSJim Jagielski case 'T' :
641*b1cdbd2cSJim Jagielski {
642*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ANGLEELLIPSETO;
643*b1cdbd2cSJim Jagielski nParametersNeeded = 3;
644*b1cdbd2cSJim Jagielski nIndex++;
645*b1cdbd2cSJim Jagielski }
646*b1cdbd2cSJim Jagielski break;
647*b1cdbd2cSJim Jagielski case 'U' :
648*b1cdbd2cSJim Jagielski {
649*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ANGLEELLIPSE;
650*b1cdbd2cSJim Jagielski nParametersNeeded = 3;
651*b1cdbd2cSJim Jagielski nIndex++;
652*b1cdbd2cSJim Jagielski }
653*b1cdbd2cSJim Jagielski break;
654*b1cdbd2cSJim Jagielski case 'A' :
655*b1cdbd2cSJim Jagielski {
656*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ARCTO;
657*b1cdbd2cSJim Jagielski nParametersNeeded = 4;
658*b1cdbd2cSJim Jagielski nIndex++;
659*b1cdbd2cSJim Jagielski }
660*b1cdbd2cSJim Jagielski break;
661*b1cdbd2cSJim Jagielski case 'B' :
662*b1cdbd2cSJim Jagielski {
663*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ARC;
664*b1cdbd2cSJim Jagielski nParametersNeeded = 4;
665*b1cdbd2cSJim Jagielski nIndex++;
666*b1cdbd2cSJim Jagielski }
667*b1cdbd2cSJim Jagielski break;
668*b1cdbd2cSJim Jagielski case 'W' :
669*b1cdbd2cSJim Jagielski {
670*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::CLOCKWISEARCTO;
671*b1cdbd2cSJim Jagielski nParametersNeeded = 4;
672*b1cdbd2cSJim Jagielski nIndex++;
673*b1cdbd2cSJim Jagielski }
674*b1cdbd2cSJim Jagielski break;
675*b1cdbd2cSJim Jagielski case 'V' :
676*b1cdbd2cSJim Jagielski {
677*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::CLOCKWISEARC;
678*b1cdbd2cSJim Jagielski nParametersNeeded = 4;
679*b1cdbd2cSJim Jagielski nIndex++;
680*b1cdbd2cSJim Jagielski }
681*b1cdbd2cSJim Jagielski break;
682*b1cdbd2cSJim Jagielski case 'X' :
683*b1cdbd2cSJim Jagielski {
684*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ELLIPTICALQUADRANTX;
685*b1cdbd2cSJim Jagielski nParametersNeeded = 1;
686*b1cdbd2cSJim Jagielski nIndex++;
687*b1cdbd2cSJim Jagielski }
688*b1cdbd2cSJim Jagielski break;
689*b1cdbd2cSJim Jagielski case 'Y' :
690*b1cdbd2cSJim Jagielski {
691*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::ELLIPTICALQUADRANTY;
692*b1cdbd2cSJim Jagielski nParametersNeeded = 1;
693*b1cdbd2cSJim Jagielski nIndex++;
694*b1cdbd2cSJim Jagielski }
695*b1cdbd2cSJim Jagielski break;
696*b1cdbd2cSJim Jagielski case 'Q' :
697*b1cdbd2cSJim Jagielski {
698*b1cdbd2cSJim Jagielski nLatestSegmentCommand = com::sun::star::drawing::EnhancedCustomShapeSegmentCommand::QUADRATICCURVETO;
699*b1cdbd2cSJim Jagielski nParametersNeeded = 2;
700*b1cdbd2cSJim Jagielski nIndex++;
701*b1cdbd2cSJim Jagielski }
702*b1cdbd2cSJim Jagielski break;
703*b1cdbd2cSJim Jagielski case ' ' :
704*b1cdbd2cSJim Jagielski {
705*b1cdbd2cSJim Jagielski nIndex++;
706*b1cdbd2cSJim Jagielski }
707*b1cdbd2cSJim Jagielski break;
708*b1cdbd2cSJim Jagielski
709*b1cdbd2cSJim Jagielski case '$' :
710*b1cdbd2cSJim Jagielski case '?' :
711*b1cdbd2cSJim Jagielski case '0' :
712*b1cdbd2cSJim Jagielski case '1' :
713*b1cdbd2cSJim Jagielski case '2' :
714*b1cdbd2cSJim Jagielski case '3' :
715*b1cdbd2cSJim Jagielski case '4' :
716*b1cdbd2cSJim Jagielski case '5' :
717*b1cdbd2cSJim Jagielski case '6' :
718*b1cdbd2cSJim Jagielski case '7' :
719*b1cdbd2cSJim Jagielski case '8' :
720*b1cdbd2cSJim Jagielski case '9' :
721*b1cdbd2cSJim Jagielski case '.' :
722*b1cdbd2cSJim Jagielski case '-' :
723*b1cdbd2cSJim Jagielski {
724*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair aPair;
725*b1cdbd2cSJim Jagielski if ( GetNextParameter( aPair.First, nIndex, rValue ) &&
726*b1cdbd2cSJim Jagielski GetNextParameter( aPair.Second, nIndex, rValue ) )
727*b1cdbd2cSJim Jagielski {
728*b1cdbd2cSJim Jagielski vCoordinates.push_back( aPair );
729*b1cdbd2cSJim Jagielski nParameterCount++;
730*b1cdbd2cSJim Jagielski }
731*b1cdbd2cSJim Jagielski else
732*b1cdbd2cSJim Jagielski bValid = sal_False;
733*b1cdbd2cSJim Jagielski }
734*b1cdbd2cSJim Jagielski break;
735*b1cdbd2cSJim Jagielski default:
736*b1cdbd2cSJim Jagielski nIndex++;
737*b1cdbd2cSJim Jagielski break;
738*b1cdbd2cSJim Jagielski }
739*b1cdbd2cSJim Jagielski if ( !nParameterCount && !nParametersNeeded )
740*b1cdbd2cSJim Jagielski {
741*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeSegment aSegment;
742*b1cdbd2cSJim Jagielski aSegment.Command = nLatestSegmentCommand;
743*b1cdbd2cSJim Jagielski aSegment.Count = 0;
744*b1cdbd2cSJim Jagielski vSegments.push_back( aSegment );
745*b1cdbd2cSJim Jagielski nParametersNeeded = 0x7fffffff;
746*b1cdbd2cSJim Jagielski }
747*b1cdbd2cSJim Jagielski else if ( nParameterCount >= nParametersNeeded )
748*b1cdbd2cSJim Jagielski {
749*b1cdbd2cSJim Jagielski // check if the last command is identical,
750*b1cdbd2cSJim Jagielski // if so, we just need to increment the count
751*b1cdbd2cSJim Jagielski if ( !vSegments.empty() && ( vSegments[ vSegments.size() - 1 ].Command == nLatestSegmentCommand ) )
752*b1cdbd2cSJim Jagielski vSegments[ vSegments.size() -1 ].Count++;
753*b1cdbd2cSJim Jagielski else
754*b1cdbd2cSJim Jagielski {
755*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeSegment aSegment;
756*b1cdbd2cSJim Jagielski aSegment.Command = nLatestSegmentCommand;
757*b1cdbd2cSJim Jagielski aSegment.Count = 1;
758*b1cdbd2cSJim Jagielski vSegments.push_back( aSegment );
759*b1cdbd2cSJim Jagielski }
760*b1cdbd2cSJim Jagielski nParameterCount = 0;
761*b1cdbd2cSJim Jagielski }
762*b1cdbd2cSJim Jagielski }
763*b1cdbd2cSJim Jagielski // adding the Coordinates property
764*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeParameterPair > seqCoordinates( vCoordinates.size() );
765*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair >::const_iterator aCoordinatesIter = vCoordinates.begin();
766*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeParameterPair >::const_iterator aCoordinatesEnd = vCoordinates.end();
767*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair* pCoordinateValues = seqCoordinates.getArray();
768*b1cdbd2cSJim Jagielski
769*b1cdbd2cSJim Jagielski while ( aCoordinatesIter != aCoordinatesEnd )
770*b1cdbd2cSJim Jagielski *pCoordinateValues++ = *aCoordinatesIter++;
771*b1cdbd2cSJim Jagielski
772*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
773*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_Coordinates );
774*b1cdbd2cSJim Jagielski aProp.Value <<= seqCoordinates;
775*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
776*b1cdbd2cSJim Jagielski
777*b1cdbd2cSJim Jagielski
778*b1cdbd2cSJim Jagielski // adding the Segments property
779*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeSegment > seqSegments( vSegments.size() );
780*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeSegment >::const_iterator aSegmentsIter = vSegments.begin();
781*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeSegment >::const_iterator aSegmentsEnd = vSegments.end();
782*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeSegment* pSegmentValues = seqSegments.getArray();
783*b1cdbd2cSJim Jagielski
784*b1cdbd2cSJim Jagielski while ( aSegmentsIter != aSegmentsEnd )
785*b1cdbd2cSJim Jagielski *pSegmentValues++ = *aSegmentsIter++;
786*b1cdbd2cSJim Jagielski
787*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_Segments );
788*b1cdbd2cSJim Jagielski aProp.Value <<= seqSegments;
789*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
790*b1cdbd2cSJim Jagielski }
791*b1cdbd2cSJim Jagielski
GetAdjustmentValues(std::vector<com::sun::star::beans::PropertyValue> & rDest,const rtl::OUString & rValue)792*b1cdbd2cSJim Jagielski void GetAdjustmentValues( std::vector< com::sun::star::beans::PropertyValue >& rDest, // draw:adjustments
793*b1cdbd2cSJim Jagielski const rtl::OUString& rValue )
794*b1cdbd2cSJim Jagielski {
795*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue > vAdjustmentValue;
796*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameter aParameter;
797*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
798*b1cdbd2cSJim Jagielski while ( GetNextParameter( aParameter, nIndex, rValue ) )
799*b1cdbd2cSJim Jagielski {
800*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue aAdj;
801*b1cdbd2cSJim Jagielski if ( aParameter.Type == com::sun::star::drawing::EnhancedCustomShapeParameterType::NORMAL )
802*b1cdbd2cSJim Jagielski {
803*b1cdbd2cSJim Jagielski aAdj.Value <<= aParameter.Value;
804*b1cdbd2cSJim Jagielski aAdj.State = beans::PropertyState_DIRECT_VALUE;
805*b1cdbd2cSJim Jagielski }
806*b1cdbd2cSJim Jagielski else
807*b1cdbd2cSJim Jagielski aAdj.State = beans::PropertyState_DEFAULT_VALUE; // this should not be, but better than setting nothing
808*b1cdbd2cSJim Jagielski
809*b1cdbd2cSJim Jagielski vAdjustmentValue.push_back( aAdj );
810*b1cdbd2cSJim Jagielski }
811*b1cdbd2cSJim Jagielski
812*b1cdbd2cSJim Jagielski sal_Int32 nAdjustmentValues = vAdjustmentValue.size();
813*b1cdbd2cSJim Jagielski if ( nAdjustmentValues )
814*b1cdbd2cSJim Jagielski {
815*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue > aAdjustmentValues( nAdjustmentValues );
816*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue >::const_iterator aIter = vAdjustmentValue.begin();
817*b1cdbd2cSJim Jagielski std::vector< com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue >::const_iterator aEnd = vAdjustmentValue.end();
818*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeAdjustmentValue* pValues = aAdjustmentValues.getArray();
819*b1cdbd2cSJim Jagielski
820*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
821*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
822*b1cdbd2cSJim Jagielski
823*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
824*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_AdjustmentValues );
825*b1cdbd2cSJim Jagielski aProp.Value <<= aAdjustmentValues;
826*b1cdbd2cSJim Jagielski rDest.push_back( aProp );
827*b1cdbd2cSJim Jagielski }
828*b1cdbd2cSJim Jagielski }
829*b1cdbd2cSJim Jagielski
StartElement(const uno::Reference<xml::sax::XAttributeList> & xAttrList)830*b1cdbd2cSJim Jagielski void XMLEnhancedCustomShapeContext::StartElement( const uno::Reference< xml::sax::XAttributeList >& xAttrList )
831*b1cdbd2cSJim Jagielski {
832*b1cdbd2cSJim Jagielski sal_Int16 nLength = xAttrList->getLength();
833*b1cdbd2cSJim Jagielski if ( nLength )
834*b1cdbd2cSJim Jagielski {
835*b1cdbd2cSJim Jagielski sal_Int32 nAttrNumber;
836*b1cdbd2cSJim Jagielski for( sal_Int16 nAttr = 0; nAttr < nLength; nAttr++ )
837*b1cdbd2cSJim Jagielski {
838*b1cdbd2cSJim Jagielski rtl::OUString aLocalName;
839*b1cdbd2cSJim Jagielski const rtl::OUString& rValue = xAttrList->getValueByIndex( nAttr );
840*b1cdbd2cSJim Jagielski /* sven fixme, this must be checked! sal_uInt16 nPrefix = */ GetImport().GetNamespaceMap().GetKeyByAttrName( xAttrList->getNameByIndex( nAttr ), &aLocalName );
841*b1cdbd2cSJim Jagielski
842*b1cdbd2cSJim Jagielski switch( EASGet( aLocalName ) )
843*b1cdbd2cSJim Jagielski {
844*b1cdbd2cSJim Jagielski case EAS_type :
845*b1cdbd2cSJim Jagielski GetString( mrCustomShapeGeometry, rValue, EAS_Type );
846*b1cdbd2cSJim Jagielski break;
847*b1cdbd2cSJim Jagielski case EAS_mirror_horizontal :
848*b1cdbd2cSJim Jagielski GetBool( mrCustomShapeGeometry, rValue, EAS_MirroredX );
849*b1cdbd2cSJim Jagielski break;
850*b1cdbd2cSJim Jagielski case EAS_mirror_vertical :
851*b1cdbd2cSJim Jagielski GetBool( mrCustomShapeGeometry, rValue, EAS_MirroredY );
852*b1cdbd2cSJim Jagielski break;
853*b1cdbd2cSJim Jagielski case EAS_viewBox :
854*b1cdbd2cSJim Jagielski {
855*b1cdbd2cSJim Jagielski SdXMLImExViewBox aViewBox( rValue, GetImport().GetMM100UnitConverter() );
856*b1cdbd2cSJim Jagielski awt::Rectangle aRect( aViewBox.GetX(), aViewBox.GetY(), aViewBox.GetWidth(), aViewBox.GetHeight() );
857*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
858*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_ViewBox );
859*b1cdbd2cSJim Jagielski aProp.Value <<= aRect;
860*b1cdbd2cSJim Jagielski mrCustomShapeGeometry.push_back( aProp );
861*b1cdbd2cSJim Jagielski }
862*b1cdbd2cSJim Jagielski break;
863*b1cdbd2cSJim Jagielski case EAS_text_rotate_angle :
864*b1cdbd2cSJim Jagielski GetDouble( mrCustomShapeGeometry, rValue, EAS_TextRotateAngle );
865*b1cdbd2cSJim Jagielski break;
866*b1cdbd2cSJim Jagielski case EAS_extrusion_allowed :
867*b1cdbd2cSJim Jagielski GetBool( maPath, rValue, EAS_ExtrusionAllowed );
868*b1cdbd2cSJim Jagielski break;
869*b1cdbd2cSJim Jagielski case EAS_text_path_allowed :
870*b1cdbd2cSJim Jagielski GetBool( maPath, rValue, EAS_TextPathAllowed );
871*b1cdbd2cSJim Jagielski break;
872*b1cdbd2cSJim Jagielski case EAS_concentric_gradient_fill_allowed :
873*b1cdbd2cSJim Jagielski GetBool( maPath, rValue, EAS_ConcentricGradientFillAllowed );
874*b1cdbd2cSJim Jagielski break;
875*b1cdbd2cSJim Jagielski case EAS_extrusion :
876*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_Extrusion );
877*b1cdbd2cSJim Jagielski break;
878*b1cdbd2cSJim Jagielski case EAS_extrusion_brightness :
879*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_Brightness );
880*b1cdbd2cSJim Jagielski break;
881*b1cdbd2cSJim Jagielski case EAS_extrusion_depth :
882*b1cdbd2cSJim Jagielski {
883*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
884*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameterPair aParameterPair;
885*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameter& rDepth = aParameterPair.First;
886*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeParameter& rFraction = aParameterPair.Second;
887*b1cdbd2cSJim Jagielski if ( GetNextParameter( rDepth, nIndex, rValue ) )
888*b1cdbd2cSJim Jagielski {
889*b1cdbd2cSJim Jagielski // try to catch the unit for the depth
890*b1cdbd2cSJim Jagielski MapUnit eSrcUnit( SvXMLExportHelper::GetUnitFromString( rValue, MAP_100TH_MM ) );
891*b1cdbd2cSJim Jagielski
892*b1cdbd2cSJim Jagielski rtl::OUStringBuffer aUnitStr;
893*b1cdbd2cSJim Jagielski double fFactor = SvXMLExportHelper::GetConversionFactor( aUnitStr, MAP_100TH_MM, eSrcUnit );
894*b1cdbd2cSJim Jagielski if ( ( fFactor != 1.0 ) && ( fFactor != 0.0 ) )
895*b1cdbd2cSJim Jagielski {
896*b1cdbd2cSJim Jagielski double fDepth;
897*b1cdbd2cSJim Jagielski if ( rDepth.Value >>= fDepth )
898*b1cdbd2cSJim Jagielski {
899*b1cdbd2cSJim Jagielski fDepth /= fFactor;
900*b1cdbd2cSJim Jagielski rDepth.Value <<= fDepth;
901*b1cdbd2cSJim Jagielski }
902*b1cdbd2cSJim Jagielski }
903*b1cdbd2cSJim Jagielski if ( rValue.matchIgnoreAsciiCase( rtl::OUString( aUnitStr ), nIndex ) )
904*b1cdbd2cSJim Jagielski nIndex += aUnitStr.getLength();
905*b1cdbd2cSJim Jagielski
906*b1cdbd2cSJim Jagielski // skipping white spaces
907*b1cdbd2cSJim Jagielski while( ( nIndex < rValue.getLength() ) && rValue[ nIndex ] == (sal_Unicode)' ' )
908*b1cdbd2cSJim Jagielski nIndex++;
909*b1cdbd2cSJim Jagielski
910*b1cdbd2cSJim Jagielski if ( GetNextParameter( rFraction, nIndex, rValue ) )
911*b1cdbd2cSJim Jagielski {
912*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
913*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_Depth );
914*b1cdbd2cSJim Jagielski aProp.Value <<= aParameterPair;
915*b1cdbd2cSJim Jagielski maExtrusion.push_back( aProp );
916*b1cdbd2cSJim Jagielski }
917*b1cdbd2cSJim Jagielski }
918*b1cdbd2cSJim Jagielski }
919*b1cdbd2cSJim Jagielski break;
920*b1cdbd2cSJim Jagielski case EAS_extrusion_diffusion :
921*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_Diffusion );
922*b1cdbd2cSJim Jagielski break;
923*b1cdbd2cSJim Jagielski case EAS_extrusion_number_of_line_segments :
924*b1cdbd2cSJim Jagielski GetInt32( maExtrusion, rValue, EAS_NumberOfLineSegments );
925*b1cdbd2cSJim Jagielski break;
926*b1cdbd2cSJim Jagielski case EAS_extrusion_light_face :
927*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_LightFace );
928*b1cdbd2cSJim Jagielski break;
929*b1cdbd2cSJim Jagielski case EAS_extrusion_first_light_harsh :
930*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_FirstLightHarsh );
931*b1cdbd2cSJim Jagielski break;
932*b1cdbd2cSJim Jagielski case EAS_extrusion_second_light_harsh :
933*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_SecondLightHarsh );
934*b1cdbd2cSJim Jagielski break;
935*b1cdbd2cSJim Jagielski case EAS_extrusion_first_light_level :
936*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_FirstLightLevel );
937*b1cdbd2cSJim Jagielski break;
938*b1cdbd2cSJim Jagielski case EAS_extrusion_second_light_level :
939*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_SecondLightLevel );
940*b1cdbd2cSJim Jagielski break;
941*b1cdbd2cSJim Jagielski case EAS_extrusion_first_light_direction :
942*b1cdbd2cSJim Jagielski GetB3DVector( maExtrusion, rValue, EAS_FirstLightDirection );
943*b1cdbd2cSJim Jagielski break;
944*b1cdbd2cSJim Jagielski case EAS_extrusion_second_light_direction :
945*b1cdbd2cSJim Jagielski GetB3DVector( maExtrusion, rValue, EAS_SecondLightDirection );
946*b1cdbd2cSJim Jagielski break;
947*b1cdbd2cSJim Jagielski case EAS_extrusion_metal :
948*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_Metal );
949*b1cdbd2cSJim Jagielski break;
950*b1cdbd2cSJim Jagielski case EAS_shade_mode :
951*b1cdbd2cSJim Jagielski {
952*b1cdbd2cSJim Jagielski drawing::ShadeMode eShadeMode( drawing::ShadeMode_FLAT );
953*b1cdbd2cSJim Jagielski if( IsXMLToken( rValue, XML_PHONG ) )
954*b1cdbd2cSJim Jagielski eShadeMode = drawing::ShadeMode_PHONG;
955*b1cdbd2cSJim Jagielski else if ( IsXMLToken( rValue, XML_GOURAUD ) )
956*b1cdbd2cSJim Jagielski eShadeMode = drawing::ShadeMode_SMOOTH;
957*b1cdbd2cSJim Jagielski else if ( IsXMLToken( rValue, XML_DRAFT ) )
958*b1cdbd2cSJim Jagielski eShadeMode = drawing::ShadeMode_DRAFT;
959*b1cdbd2cSJim Jagielski
960*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
961*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_ShadeMode );
962*b1cdbd2cSJim Jagielski aProp.Value <<= eShadeMode;
963*b1cdbd2cSJim Jagielski maExtrusion.push_back( aProp );
964*b1cdbd2cSJim Jagielski }
965*b1cdbd2cSJim Jagielski break;
966*b1cdbd2cSJim Jagielski case EAS_extrusion_rotation_angle :
967*b1cdbd2cSJim Jagielski GetEnhancedParameterPair( maExtrusion, rValue, EAS_RotateAngle );
968*b1cdbd2cSJim Jagielski break;
969*b1cdbd2cSJim Jagielski case EAS_extrusion_rotation_center :
970*b1cdbd2cSJim Jagielski GetB3DVector( maExtrusion, rValue, EAS_RotationCenter );
971*b1cdbd2cSJim Jagielski break;
972*b1cdbd2cSJim Jagielski case EAS_extrusion_shininess :
973*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_Shininess );
974*b1cdbd2cSJim Jagielski break;
975*b1cdbd2cSJim Jagielski case EAS_extrusion_skew :
976*b1cdbd2cSJim Jagielski GetEnhancedParameterPair( maExtrusion, rValue, EAS_Skew );
977*b1cdbd2cSJim Jagielski break;
978*b1cdbd2cSJim Jagielski case EAS_extrusion_specularity :
979*b1cdbd2cSJim Jagielski GetDoublePercentage( maExtrusion, rValue, EAS_Specularity );
980*b1cdbd2cSJim Jagielski break;
981*b1cdbd2cSJim Jagielski case EAS_projection :
982*b1cdbd2cSJim Jagielski {
983*b1cdbd2cSJim Jagielski drawing::ProjectionMode eProjectionMode( drawing::ProjectionMode_PERSPECTIVE );
984*b1cdbd2cSJim Jagielski if( IsXMLToken( rValue, XML_PARALLEL ) )
985*b1cdbd2cSJim Jagielski eProjectionMode = drawing::ProjectionMode_PARALLEL;
986*b1cdbd2cSJim Jagielski
987*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
988*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_ProjectionMode );
989*b1cdbd2cSJim Jagielski aProp.Value <<= eProjectionMode;
990*b1cdbd2cSJim Jagielski maExtrusion.push_back( aProp );
991*b1cdbd2cSJim Jagielski }
992*b1cdbd2cSJim Jagielski break;
993*b1cdbd2cSJim Jagielski case EAS_extrusion_viewpoint :
994*b1cdbd2cSJim Jagielski GetPosition3D( maExtrusion, rValue, EAS_ViewPoint, mrUnitConverter );
995*b1cdbd2cSJim Jagielski break;
996*b1cdbd2cSJim Jagielski case EAS_extrusion_origin :
997*b1cdbd2cSJim Jagielski GetEnhancedParameterPair( maExtrusion, rValue, EAS_Origin );
998*b1cdbd2cSJim Jagielski break;
999*b1cdbd2cSJim Jagielski case EAS_extrusion_color :
1000*b1cdbd2cSJim Jagielski GetBool( maExtrusion, rValue, EAS_Color );
1001*b1cdbd2cSJim Jagielski break;
1002*b1cdbd2cSJim Jagielski case EAS_enhanced_path :
1003*b1cdbd2cSJim Jagielski GetEnhancedPath( maPath, rValue );
1004*b1cdbd2cSJim Jagielski break;
1005*b1cdbd2cSJim Jagielski case EAS_path_stretchpoint_x :
1006*b1cdbd2cSJim Jagielski {
1007*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertNumber( nAttrNumber, rValue ) )
1008*b1cdbd2cSJim Jagielski {
1009*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1010*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_StretchX );
1011*b1cdbd2cSJim Jagielski aProp.Value <<= nAttrNumber;
1012*b1cdbd2cSJim Jagielski maPath.push_back( aProp );
1013*b1cdbd2cSJim Jagielski }
1014*b1cdbd2cSJim Jagielski }
1015*b1cdbd2cSJim Jagielski break;
1016*b1cdbd2cSJim Jagielski case EAS_path_stretchpoint_y :
1017*b1cdbd2cSJim Jagielski {
1018*b1cdbd2cSJim Jagielski if ( SvXMLUnitConverter::convertNumber( nAttrNumber, rValue ) )
1019*b1cdbd2cSJim Jagielski {
1020*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1021*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_StretchY );
1022*b1cdbd2cSJim Jagielski aProp.Value <<= nAttrNumber;
1023*b1cdbd2cSJim Jagielski maPath.push_back( aProp );
1024*b1cdbd2cSJim Jagielski }
1025*b1cdbd2cSJim Jagielski }
1026*b1cdbd2cSJim Jagielski break;
1027*b1cdbd2cSJim Jagielski case EAS_text_areas :
1028*b1cdbd2cSJim Jagielski GetEnhancedRectangleSequence( maPath, rValue, EAS_TextFrames );
1029*b1cdbd2cSJim Jagielski break;
1030*b1cdbd2cSJim Jagielski case EAS_glue_points :
1031*b1cdbd2cSJim Jagielski {
1032*b1cdbd2cSJim Jagielski sal_Int32 i, nPairs = GetEnhancedParameterPairSequence( maPath, rValue, EAS_GluePoints );
1033*b1cdbd2cSJim Jagielski GetImport().GetShapeImport()->moveGluePointMapping( mrxShape, nPairs );
1034*b1cdbd2cSJim Jagielski for ( i = 0; i < nPairs; i++ )
1035*b1cdbd2cSJim Jagielski GetImport().GetShapeImport()->addGluePointMapping( mrxShape, i + 4, i + 4 );
1036*b1cdbd2cSJim Jagielski }
1037*b1cdbd2cSJim Jagielski break;
1038*b1cdbd2cSJim Jagielski case EAS_glue_point_type :
1039*b1cdbd2cSJim Jagielski GetEnum( maPath, rValue, EAS_GluePointType, *aXML_GluePointEnumMap );
1040*b1cdbd2cSJim Jagielski break;
1041*b1cdbd2cSJim Jagielski case EAS_glue_point_leaving_directions :
1042*b1cdbd2cSJim Jagielski GetDoubleSequence( maPath, rValue, EAS_GluePointLeavingDirections );
1043*b1cdbd2cSJim Jagielski break;
1044*b1cdbd2cSJim Jagielski case EAS_text_path :
1045*b1cdbd2cSJim Jagielski GetBool( maTextPath, rValue, EAS_TextPath );
1046*b1cdbd2cSJim Jagielski break;
1047*b1cdbd2cSJim Jagielski case EAS_text_path_mode :
1048*b1cdbd2cSJim Jagielski {
1049*b1cdbd2cSJim Jagielski com::sun::star::drawing::EnhancedCustomShapeTextPathMode eTextPathMode( com::sun::star::drawing::EnhancedCustomShapeTextPathMode_NORMAL );
1050*b1cdbd2cSJim Jagielski if( IsXMLToken( rValue, XML_PATH ) )
1051*b1cdbd2cSJim Jagielski eTextPathMode = com::sun::star::drawing::EnhancedCustomShapeTextPathMode_PATH;
1052*b1cdbd2cSJim Jagielski else if ( IsXMLToken( rValue, XML_SHAPE ) )
1053*b1cdbd2cSJim Jagielski eTextPathMode = com::sun::star::drawing::EnhancedCustomShapeTextPathMode_SHAPE;
1054*b1cdbd2cSJim Jagielski
1055*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1056*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_TextPathMode );
1057*b1cdbd2cSJim Jagielski aProp.Value <<= eTextPathMode;
1058*b1cdbd2cSJim Jagielski maTextPath.push_back( aProp );
1059*b1cdbd2cSJim Jagielski }
1060*b1cdbd2cSJim Jagielski break;
1061*b1cdbd2cSJim Jagielski case EAS_text_path_scale :
1062*b1cdbd2cSJim Jagielski {
1063*b1cdbd2cSJim Jagielski sal_Bool bScaleX = IsXMLToken( rValue, XML_SHAPE );
1064*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1065*b1cdbd2cSJim Jagielski aProp.Name = EASGet( EAS_ScaleX );
1066*b1cdbd2cSJim Jagielski aProp.Value <<= bScaleX;
1067*b1cdbd2cSJim Jagielski maTextPath.push_back( aProp );
1068*b1cdbd2cSJim Jagielski }
1069*b1cdbd2cSJim Jagielski break;
1070*b1cdbd2cSJim Jagielski case EAS_text_path_same_letter_heights :
1071*b1cdbd2cSJim Jagielski GetBool( maTextPath, rValue, EAS_SameLetterHeights );
1072*b1cdbd2cSJim Jagielski break;
1073*b1cdbd2cSJim Jagielski case EAS_modifiers :
1074*b1cdbd2cSJim Jagielski GetAdjustmentValues( mrCustomShapeGeometry, rValue );
1075*b1cdbd2cSJim Jagielski break;
1076*b1cdbd2cSJim Jagielski default:
1077*b1cdbd2cSJim Jagielski break;
1078*b1cdbd2cSJim Jagielski }
1079*b1cdbd2cSJim Jagielski }
1080*b1cdbd2cSJim Jagielski }
1081*b1cdbd2cSJim Jagielski }
1082*b1cdbd2cSJim Jagielski
SdXMLCustomShapePropertyMerge(std::vector<com::sun::star::beans::PropertyValue> & rPropVec,const std::vector<beans::PropertyValues> & rElement,const rtl::OUString & rElementName)1083*b1cdbd2cSJim Jagielski void SdXMLCustomShapePropertyMerge( std::vector< com::sun::star::beans::PropertyValue >& rPropVec,
1084*b1cdbd2cSJim Jagielski const std::vector< beans::PropertyValues >& rElement,
1085*b1cdbd2cSJim Jagielski const rtl::OUString& rElementName )
1086*b1cdbd2cSJim Jagielski {
1087*b1cdbd2cSJim Jagielski if ( !rElement.empty() )
1088*b1cdbd2cSJim Jagielski {
1089*b1cdbd2cSJim Jagielski uno::Sequence< beans::PropertyValues > aPropSeq( rElement.size() );
1090*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValues >::const_iterator aIter = rElement.begin();
1091*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValues >::const_iterator aEnd = rElement.end();
1092*b1cdbd2cSJim Jagielski beans::PropertyValues* pValues = aPropSeq.getArray();
1093*b1cdbd2cSJim Jagielski
1094*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
1095*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
1096*b1cdbd2cSJim Jagielski
1097*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1098*b1cdbd2cSJim Jagielski aProp.Name = rElementName;
1099*b1cdbd2cSJim Jagielski aProp.Value <<= aPropSeq;
1100*b1cdbd2cSJim Jagielski rPropVec.push_back( aProp );
1101*b1cdbd2cSJim Jagielski }
1102*b1cdbd2cSJim Jagielski }
1103*b1cdbd2cSJim Jagielski
SdXMLCustomShapePropertyMerge(std::vector<com::sun::star::beans::PropertyValue> & rPropVec,const std::vector<rtl::OUString> & rElement,const rtl::OUString & rElementName)1104*b1cdbd2cSJim Jagielski void SdXMLCustomShapePropertyMerge( std::vector< com::sun::star::beans::PropertyValue >& rPropVec,
1105*b1cdbd2cSJim Jagielski const std::vector< rtl::OUString >& rElement,
1106*b1cdbd2cSJim Jagielski const rtl::OUString& rElementName )
1107*b1cdbd2cSJim Jagielski {
1108*b1cdbd2cSJim Jagielski if ( !rElement.empty() )
1109*b1cdbd2cSJim Jagielski {
1110*b1cdbd2cSJim Jagielski uno::Sequence< rtl::OUString > aPropSeq( rElement.size() );
1111*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::const_iterator aIter = rElement.begin();
1112*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::const_iterator aEnd = rElement.end();
1113*b1cdbd2cSJim Jagielski rtl::OUString* pValues = aPropSeq.getArray();
1114*b1cdbd2cSJim Jagielski
1115*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
1116*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
1117*b1cdbd2cSJim Jagielski
1118*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1119*b1cdbd2cSJim Jagielski aProp.Name = rElementName;
1120*b1cdbd2cSJim Jagielski aProp.Value <<= aPropSeq;
1121*b1cdbd2cSJim Jagielski rPropVec.push_back( aProp );
1122*b1cdbd2cSJim Jagielski }
1123*b1cdbd2cSJim Jagielski }
1124*b1cdbd2cSJim Jagielski
SdXMLCustomShapePropertyMerge(std::vector<com::sun::star::beans::PropertyValue> & rPropVec,const std::vector<com::sun::star::beans::PropertyValue> & rElement,const rtl::OUString & rElementName)1125*b1cdbd2cSJim Jagielski void SdXMLCustomShapePropertyMerge( std::vector< com::sun::star::beans::PropertyValue >& rPropVec,
1126*b1cdbd2cSJim Jagielski const std::vector< com::sun::star::beans::PropertyValue >& rElement,
1127*b1cdbd2cSJim Jagielski const rtl::OUString& rElementName )
1128*b1cdbd2cSJim Jagielski {
1129*b1cdbd2cSJim Jagielski if ( !rElement.empty() )
1130*b1cdbd2cSJim Jagielski {
1131*b1cdbd2cSJim Jagielski uno::Sequence< beans::PropertyValue > aPropSeq( rElement.size() );
1132*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::const_iterator aIter = rElement.begin();
1133*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::const_iterator aEnd = rElement.end();
1134*b1cdbd2cSJim Jagielski beans::PropertyValue* pValues = aPropSeq.getArray();
1135*b1cdbd2cSJim Jagielski
1136*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
1137*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
1138*b1cdbd2cSJim Jagielski
1139*b1cdbd2cSJim Jagielski beans::PropertyValue aProp;
1140*b1cdbd2cSJim Jagielski aProp.Name = rElementName;
1141*b1cdbd2cSJim Jagielski aProp.Value <<= aPropSeq;
1142*b1cdbd2cSJim Jagielski rPropVec.push_back( aProp );
1143*b1cdbd2cSJim Jagielski }
1144*b1cdbd2cSJim Jagielski }
1145*b1cdbd2cSJim Jagielski
1146*b1cdbd2cSJim Jagielski typedef std::hash_map< rtl::OUString, sal_Int32, rtl::OUStringHash, OUStringEqFunc> EquationHashMap;
1147*b1cdbd2cSJim Jagielski
1148*b1cdbd2cSJim Jagielski /* if rPara.Type is from type EnhancedCustomShapeParameterType::EQUATION, the name of the equation
1149*b1cdbd2cSJim Jagielski will be converted from rtl::OUString to index */
CheckAndResolveEquationParameter(com::sun::star::drawing::EnhancedCustomShapeParameter & rPara,EquationHashMap * pH)1150*b1cdbd2cSJim Jagielski void CheckAndResolveEquationParameter( com::sun::star::drawing::EnhancedCustomShapeParameter& rPara, EquationHashMap* pH )
1151*b1cdbd2cSJim Jagielski {
1152*b1cdbd2cSJim Jagielski if ( rPara.Type == com::sun::star::drawing::EnhancedCustomShapeParameterType::EQUATION )
1153*b1cdbd2cSJim Jagielski {
1154*b1cdbd2cSJim Jagielski rtl::OUString aEquationName;
1155*b1cdbd2cSJim Jagielski if ( rPara.Value >>= aEquationName )
1156*b1cdbd2cSJim Jagielski {
1157*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
1158*b1cdbd2cSJim Jagielski EquationHashMap::iterator aHashIter( pH->find( aEquationName ) );
1159*b1cdbd2cSJim Jagielski if ( aHashIter != pH->end() )
1160*b1cdbd2cSJim Jagielski nIndex = (*aHashIter).second;
1161*b1cdbd2cSJim Jagielski rPara.Value <<= nIndex;
1162*b1cdbd2cSJim Jagielski }
1163*b1cdbd2cSJim Jagielski }
1164*b1cdbd2cSJim Jagielski }
1165*b1cdbd2cSJim Jagielski
EndElement()1166*b1cdbd2cSJim Jagielski void XMLEnhancedCustomShapeContext::EndElement()
1167*b1cdbd2cSJim Jagielski {
1168*b1cdbd2cSJim Jagielski // resolve properties that are indexing a Equation
1169*b1cdbd2cSJim Jagielski if ( !maEquations.empty() )
1170*b1cdbd2cSJim Jagielski {
1171*b1cdbd2cSJim Jagielski // creating hash map containing the name and index of each equation
1172*b1cdbd2cSJim Jagielski EquationHashMap* pH = new EquationHashMap;
1173*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::iterator aEquationNameIter = maEquationNames.begin();
1174*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::iterator aEquationNameEnd = maEquationNames.end();
1175*b1cdbd2cSJim Jagielski while( aEquationNameIter != aEquationNameEnd )
1176*b1cdbd2cSJim Jagielski {
1177*b1cdbd2cSJim Jagielski (*pH)[ *aEquationNameIter ] = (sal_Int32)( aEquationNameIter - maEquationNames.begin() );
1178*b1cdbd2cSJim Jagielski aEquationNameIter++;
1179*b1cdbd2cSJim Jagielski }
1180*b1cdbd2cSJim Jagielski
1181*b1cdbd2cSJim Jagielski // resolve equation
1182*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::iterator aEquationIter = maEquations.begin();
1183*b1cdbd2cSJim Jagielski std::vector< rtl::OUString >::iterator aEquationEnd = maEquations.end();
1184*b1cdbd2cSJim Jagielski while( aEquationIter != aEquationEnd )
1185*b1cdbd2cSJim Jagielski {
1186*b1cdbd2cSJim Jagielski sal_Int32 nIndexOf = 0;
1187*b1cdbd2cSJim Jagielski do
1188*b1cdbd2cSJim Jagielski {
1189*b1cdbd2cSJim Jagielski nIndexOf = aEquationIter->indexOf( '?', nIndexOf );
1190*b1cdbd2cSJim Jagielski if ( nIndexOf != -1 )
1191*b1cdbd2cSJim Jagielski {
1192*b1cdbd2cSJim Jagielski rtl::OUString aEquationName;
1193*b1cdbd2cSJim Jagielski if ( GetEquationName( *aEquationIter, nIndexOf + 1, aEquationName ) )
1194*b1cdbd2cSJim Jagielski {
1195*b1cdbd2cSJim Jagielski // copying first characters inclusive '?'
1196*b1cdbd2cSJim Jagielski rtl::OUString aNew( aEquationIter->copy( 0, nIndexOf + 1 ) );
1197*b1cdbd2cSJim Jagielski sal_Int32 nIndex = 0;
1198*b1cdbd2cSJim Jagielski EquationHashMap::iterator aHashIter( pH->find( aEquationName ) );
1199*b1cdbd2cSJim Jagielski if ( aHashIter != pH->end() )
1200*b1cdbd2cSJim Jagielski nIndex = (*aHashIter).second;
1201*b1cdbd2cSJim Jagielski aNew += rtl::OUString::valueOf( nIndex );
1202*b1cdbd2cSJim Jagielski aNew += aEquationIter->copy( nIndexOf + aEquationName.getLength() + 1 );
1203*b1cdbd2cSJim Jagielski *aEquationIter = aNew;
1204*b1cdbd2cSJim Jagielski }
1205*b1cdbd2cSJim Jagielski nIndexOf++;
1206*b1cdbd2cSJim Jagielski }
1207*b1cdbd2cSJim Jagielski }
1208*b1cdbd2cSJim Jagielski while( nIndexOf != -1 );
1209*b1cdbd2cSJim Jagielski aEquationIter++;
1210*b1cdbd2cSJim Jagielski }
1211*b1cdbd2cSJim Jagielski
1212*b1cdbd2cSJim Jagielski // Path
1213*b1cdbd2cSJim Jagielski sal_Int32 i;
1214*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::iterator aPathIter = maPath.begin();
1215*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::iterator aPathEnd = maPath.end();
1216*b1cdbd2cSJim Jagielski while ( aPathIter != aPathEnd )
1217*b1cdbd2cSJim Jagielski {
1218*b1cdbd2cSJim Jagielski switch( EASGet( aPathIter->Name ) )
1219*b1cdbd2cSJim Jagielski {
1220*b1cdbd2cSJim Jagielski case EAS_Coordinates :
1221*b1cdbd2cSJim Jagielski case EAS_GluePoints :
1222*b1cdbd2cSJim Jagielski {
1223*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeParameterPair >& rSeq =
1224*b1cdbd2cSJim Jagielski *((uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeParameterPair >*)
1225*b1cdbd2cSJim Jagielski aPathIter->Value.getValue());
1226*b1cdbd2cSJim Jagielski for ( i = 0; i < rSeq.getLength(); i++ )
1227*b1cdbd2cSJim Jagielski {
1228*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].First, pH );
1229*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].Second, pH );
1230*b1cdbd2cSJim Jagielski }
1231*b1cdbd2cSJim Jagielski }
1232*b1cdbd2cSJim Jagielski break;
1233*b1cdbd2cSJim Jagielski case EAS_TextFrames :
1234*b1cdbd2cSJim Jagielski {
1235*b1cdbd2cSJim Jagielski uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeTextFrame >& rSeq =
1236*b1cdbd2cSJim Jagielski *((uno::Sequence< com::sun::star::drawing::EnhancedCustomShapeTextFrame >*)
1237*b1cdbd2cSJim Jagielski aPathIter->Value.getValue());
1238*b1cdbd2cSJim Jagielski for ( i = 0; i < rSeq.getLength(); i++ )
1239*b1cdbd2cSJim Jagielski {
1240*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].TopLeft.First, pH );
1241*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].TopLeft.Second, pH );
1242*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].BottomRight.First, pH );
1243*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( rSeq[ i ].BottomRight.Second, pH );
1244*b1cdbd2cSJim Jagielski }
1245*b1cdbd2cSJim Jagielski }
1246*b1cdbd2cSJim Jagielski break;
1247*b1cdbd2cSJim Jagielski default:
1248*b1cdbd2cSJim Jagielski break;
1249*b1cdbd2cSJim Jagielski }
1250*b1cdbd2cSJim Jagielski aPathIter++;
1251*b1cdbd2cSJim Jagielski }
1252*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValues >::iterator aHandleIter = maHandles.begin();
1253*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValues >::iterator aHandleEnd = maHandles.end();
1254*b1cdbd2cSJim Jagielski while ( aHandleIter != aHandleEnd )
1255*b1cdbd2cSJim Jagielski {
1256*b1cdbd2cSJim Jagielski beans::PropertyValue* pValues = aHandleIter->getArray();
1257*b1cdbd2cSJim Jagielski for ( i = 0; i < aHandleIter->getLength(); i++ )
1258*b1cdbd2cSJim Jagielski {
1259*b1cdbd2cSJim Jagielski switch( EASGet( pValues->Name ) )
1260*b1cdbd2cSJim Jagielski {
1261*b1cdbd2cSJim Jagielski case EAS_RangeYMinimum :
1262*b1cdbd2cSJim Jagielski case EAS_RangeYMaximum :
1263*b1cdbd2cSJim Jagielski case EAS_RangeXMinimum :
1264*b1cdbd2cSJim Jagielski case EAS_RangeXMaximum :
1265*b1cdbd2cSJim Jagielski case EAS_RadiusRangeMinimum :
1266*b1cdbd2cSJim Jagielski case EAS_RadiusRangeMaximum :
1267*b1cdbd2cSJim Jagielski {
1268*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( *((com::sun::star::drawing::EnhancedCustomShapeParameter*)
1269*b1cdbd2cSJim Jagielski pValues->Value.getValue()), pH );
1270*b1cdbd2cSJim Jagielski }
1271*b1cdbd2cSJim Jagielski break;
1272*b1cdbd2cSJim Jagielski
1273*b1cdbd2cSJim Jagielski case EAS_Position :
1274*b1cdbd2cSJim Jagielski case EAS_Polar :
1275*b1cdbd2cSJim Jagielski {
1276*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( (*((com::sun::star::drawing::EnhancedCustomShapeParameterPair*)
1277*b1cdbd2cSJim Jagielski pValues->Value.getValue())).First, pH );
1278*b1cdbd2cSJim Jagielski CheckAndResolveEquationParameter( (*((com::sun::star::drawing::EnhancedCustomShapeParameterPair*)
1279*b1cdbd2cSJim Jagielski pValues->Value.getValue())).Second, pH );
1280*b1cdbd2cSJim Jagielski }
1281*b1cdbd2cSJim Jagielski break;
1282*b1cdbd2cSJim Jagielski default:
1283*b1cdbd2cSJim Jagielski break;
1284*b1cdbd2cSJim Jagielski }
1285*b1cdbd2cSJim Jagielski pValues++;
1286*b1cdbd2cSJim Jagielski }
1287*b1cdbd2cSJim Jagielski aHandleIter++;
1288*b1cdbd2cSJim Jagielski }
1289*b1cdbd2cSJim Jagielski delete pH;
1290*b1cdbd2cSJim Jagielski }
1291*b1cdbd2cSJim Jagielski
1292*b1cdbd2cSJim Jagielski SdXMLCustomShapePropertyMerge( mrCustomShapeGeometry, maExtrusion, EASGet( EAS_Extrusion ) );
1293*b1cdbd2cSJim Jagielski SdXMLCustomShapePropertyMerge( mrCustomShapeGeometry, maPath, EASGet( EAS_Path ) );
1294*b1cdbd2cSJim Jagielski SdXMLCustomShapePropertyMerge( mrCustomShapeGeometry, maTextPath, EASGet( EAS_TextPath ) );
1295*b1cdbd2cSJim Jagielski SdXMLCustomShapePropertyMerge( mrCustomShapeGeometry, maEquations, EASGet( EAS_Equations ) );
1296*b1cdbd2cSJim Jagielski if ( !maHandles.empty() )
1297*b1cdbd2cSJim Jagielski SdXMLCustomShapePropertyMerge( mrCustomShapeGeometry, maHandles, EASGet( EAS_Handles ) );
1298*b1cdbd2cSJim Jagielski }
1299*b1cdbd2cSJim Jagielski
CreateChildContext(sal_uInt16 nPrefix,const rtl::OUString & rLocalName,const uno::Reference<xml::sax::XAttributeList> & xAttrList)1300*b1cdbd2cSJim Jagielski SvXMLImportContext* XMLEnhancedCustomShapeContext::CreateChildContext( sal_uInt16 nPrefix,const rtl::OUString& rLocalName,
1301*b1cdbd2cSJim Jagielski const uno::Reference< xml::sax::XAttributeList> & xAttrList )
1302*b1cdbd2cSJim Jagielski {
1303*b1cdbd2cSJim Jagielski EnhancedCustomShapeTokenEnum aTokenEnum = EASGet( rLocalName );
1304*b1cdbd2cSJim Jagielski if ( aTokenEnum == EAS_equation )
1305*b1cdbd2cSJim Jagielski {
1306*b1cdbd2cSJim Jagielski sal_Int16 nLength = xAttrList->getLength();
1307*b1cdbd2cSJim Jagielski if ( nLength )
1308*b1cdbd2cSJim Jagielski {
1309*b1cdbd2cSJim Jagielski rtl::OUString aFormula;
1310*b1cdbd2cSJim Jagielski rtl::OUString aFormulaName;
1311*b1cdbd2cSJim Jagielski for( sal_Int16 nAttr = 0; nAttr < nLength; nAttr++ )
1312*b1cdbd2cSJim Jagielski {
1313*b1cdbd2cSJim Jagielski rtl::OUString aLocalName;
1314*b1cdbd2cSJim Jagielski const rtl::OUString& rValue = xAttrList->getValueByIndex( nAttr );
1315*b1cdbd2cSJim Jagielski /* fixme sven, this needs to be chekced! sal_uInt16 nPrefix = */ GetImport().GetNamespaceMap().GetKeyByAttrName( xAttrList->getNameByIndex( nAttr ), &aLocalName );
1316*b1cdbd2cSJim Jagielski
1317*b1cdbd2cSJim Jagielski switch( EASGet( aLocalName ) )
1318*b1cdbd2cSJim Jagielski {
1319*b1cdbd2cSJim Jagielski case EAS_formula :
1320*b1cdbd2cSJim Jagielski aFormula = rValue;
1321*b1cdbd2cSJim Jagielski break;
1322*b1cdbd2cSJim Jagielski case EAS_name :
1323*b1cdbd2cSJim Jagielski aFormulaName = rValue;
1324*b1cdbd2cSJim Jagielski break;
1325*b1cdbd2cSJim Jagielski default:
1326*b1cdbd2cSJim Jagielski break;
1327*b1cdbd2cSJim Jagielski }
1328*b1cdbd2cSJim Jagielski }
1329*b1cdbd2cSJim Jagielski if ( aFormulaName.getLength() || aFormula.getLength() )
1330*b1cdbd2cSJim Jagielski {
1331*b1cdbd2cSJim Jagielski maEquations.push_back( aFormula );
1332*b1cdbd2cSJim Jagielski maEquationNames.push_back( aFormulaName );
1333*b1cdbd2cSJim Jagielski }
1334*b1cdbd2cSJim Jagielski }
1335*b1cdbd2cSJim Jagielski }
1336*b1cdbd2cSJim Jagielski else if ( aTokenEnum == EAS_handle )
1337*b1cdbd2cSJim Jagielski {
1338*b1cdbd2cSJim Jagielski std::vector< com::sun::star::beans::PropertyValue > aHandle;
1339*b1cdbd2cSJim Jagielski const sal_Int16 nLength = xAttrList->getLength();
1340*b1cdbd2cSJim Jagielski for( sal_Int16 nAttr = 0; nAttr < nLength; nAttr++ )
1341*b1cdbd2cSJim Jagielski {
1342*b1cdbd2cSJim Jagielski rtl::OUString aLocalName;
1343*b1cdbd2cSJim Jagielski const rtl::OUString& rValue = xAttrList->getValueByIndex( nAttr );
1344*b1cdbd2cSJim Jagielski /* fixme sven, this needs to be chekced! sal_uInt16 nPrefix = */ GetImport().GetNamespaceMap().GetKeyByAttrName( xAttrList->getNameByIndex( nAttr ), &aLocalName );
1345*b1cdbd2cSJim Jagielski switch( EASGet( aLocalName ) )
1346*b1cdbd2cSJim Jagielski {
1347*b1cdbd2cSJim Jagielski case EAS_handle_mirror_vertical :
1348*b1cdbd2cSJim Jagielski GetBool( aHandle, rValue, EAS_MirroredY );
1349*b1cdbd2cSJim Jagielski break;
1350*b1cdbd2cSJim Jagielski case EAS_handle_mirror_horizontal :
1351*b1cdbd2cSJim Jagielski GetBool( aHandle, rValue, EAS_MirroredX );
1352*b1cdbd2cSJim Jagielski break;
1353*b1cdbd2cSJim Jagielski case EAS_handle_switched :
1354*b1cdbd2cSJim Jagielski GetBool( aHandle, rValue, EAS_Switched );
1355*b1cdbd2cSJim Jagielski break;
1356*b1cdbd2cSJim Jagielski case EAS_handle_position :
1357*b1cdbd2cSJim Jagielski GetEnhancedParameterPair( aHandle, rValue, EAS_Position );
1358*b1cdbd2cSJim Jagielski break;
1359*b1cdbd2cSJim Jagielski case EAS_handle_range_x_minimum :
1360*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RangeXMinimum );
1361*b1cdbd2cSJim Jagielski break;
1362*b1cdbd2cSJim Jagielski case EAS_handle_range_x_maximum :
1363*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RangeXMaximum );
1364*b1cdbd2cSJim Jagielski break;
1365*b1cdbd2cSJim Jagielski case EAS_handle_range_y_minimum :
1366*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RangeYMinimum );
1367*b1cdbd2cSJim Jagielski break;
1368*b1cdbd2cSJim Jagielski case EAS_handle_range_y_maximum :
1369*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RangeYMaximum );
1370*b1cdbd2cSJim Jagielski break;
1371*b1cdbd2cSJim Jagielski case EAS_handle_polar :
1372*b1cdbd2cSJim Jagielski GetEnhancedParameterPair( aHandle, rValue, EAS_Polar );
1373*b1cdbd2cSJim Jagielski break;
1374*b1cdbd2cSJim Jagielski case EAS_handle_radius_range_minimum :
1375*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RadiusRangeMinimum );
1376*b1cdbd2cSJim Jagielski break;
1377*b1cdbd2cSJim Jagielski case EAS_handle_radius_range_maximum :
1378*b1cdbd2cSJim Jagielski GetEnhancedParameter( aHandle, rValue, EAS_RadiusRangeMaximum );
1379*b1cdbd2cSJim Jagielski break;
1380*b1cdbd2cSJim Jagielski default:
1381*b1cdbd2cSJim Jagielski break;
1382*b1cdbd2cSJim Jagielski }
1383*b1cdbd2cSJim Jagielski }
1384*b1cdbd2cSJim Jagielski beans::PropertyValues aPropSeq( aHandle.size() );
1385*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::const_iterator aIter = aHandle.begin();
1386*b1cdbd2cSJim Jagielski std::vector< beans::PropertyValue >::const_iterator aEnd = aHandle.end();
1387*b1cdbd2cSJim Jagielski beans::PropertyValue* pValues = aPropSeq.getArray();
1388*b1cdbd2cSJim Jagielski
1389*b1cdbd2cSJim Jagielski while ( aIter != aEnd )
1390*b1cdbd2cSJim Jagielski *pValues++ = *aIter++;
1391*b1cdbd2cSJim Jagielski
1392*b1cdbd2cSJim Jagielski maHandles.push_back( aPropSeq );
1393*b1cdbd2cSJim Jagielski }
1394*b1cdbd2cSJim Jagielski return SvXMLImportContext::CreateChildContext( nPrefix, rLocalName, xAttrList );
1395*b1cdbd2cSJim Jagielski }
1396