summaryrefslogtreecommitdiff
path: root/oox
diff options
context:
space:
mode:
Diffstat (limited to 'oox')
-rw-r--r--oox/source/export/drawingml.cxx290
1 files changed, 210 insertions, 80 deletions
diff --git a/oox/source/export/drawingml.cxx b/oox/source/export/drawingml.cxx
index 02bfedd59d90..a9377f3d689d 100644
--- a/oox/source/export/drawingml.cxx
+++ b/oox/source/export/drawingml.cxx
@@ -154,11 +154,13 @@ bool DrawingML::GetPropertyAndState( Reference< XPropertySet > rXPropertySet, Re
void DrawingML::WriteColor( sal_uInt32 nColor, sal_Int32 nAlpha )
{
OString sColor = OString::number( nColor, 16 );
- if( sColor.getLength() < 6 ) {
+ if( sColor.getLength() < 6 )
+ {
OStringBuffer sBuf( "0" );
int remains = 5 - sColor.getLength();
- while( remains > 0 ) {
+ while( remains > 0 )
+ {
sBuf.append( "0" );
remains--;
}
@@ -195,9 +197,11 @@ void DrawingML::WriteColor( const OUString& sColorSchemeName, const Sequence< Pr
mpFS->endElementNS( XML_a, XML_schemeClr );
}
else
+ {
mpFS->singleElementNS( XML_a, XML_schemeClr,
XML_val, USS( sColorSchemeName ),
FSEND );
+ }
}
void DrawingML::WriteColorTransformations( const Sequence< PropertyValue >& aTransformations )
@@ -243,6 +247,7 @@ void DrawingML::WriteSolidFill( Reference< XPropertySet > rXPropSet )
Sequence< PropertyValue > aGrabBag;
mAny >>= aGrabBag;
for( sal_Int32 i=0; i < aGrabBag.getLength(); ++i )
+ {
if( aGrabBag[i].Name == "SpPrSolidFillSchemeClr" )
aGrabBag[i].Value >>= sColorFillScheme;
else if( aGrabBag[i].Name == "OriginalSolidFillClr" )
@@ -251,6 +256,7 @@ void DrawingML::WriteSolidFill( Reference< XPropertySet > rXPropSet )
aGrabBag[i].Value >>= aStyleProperties;
else if( aGrabBag[i].Name == "SpPrSolidFillSchemeClrTransformations" )
aGrabBag[i].Value >>= aTransformations;
+ }
}
sal_Int32 nAlpha = MAX_PERCENT;
@@ -264,20 +270,26 @@ void DrawingML::WriteSolidFill( Reference< XPropertySet > rXPropSet )
// write XML
if ( nFillColor != nOriginalColor )
+ {
// the user has set a different color for the shape
WriteSolidFill( nFillColor & 0xffffff, nAlpha );
+ }
else if ( !sColorFillScheme.isEmpty() )
+ {
// the shape had a scheme color and the user didn't change it
WriteSolidFill( sColorFillScheme, aTransformations );
+ }
else if ( aStyleProperties.hasElements() )
{
sal_uInt32 nThemeColor = 0;
for( sal_Int32 i=0; i < aStyleProperties.getLength(); ++i )
+ {
if( aStyleProperties[i].Name == "Color" )
{
aStyleProperties[i].Value >>= nThemeColor;
break;
}
+ }
if ( nFillColor != nThemeColor )
// the shape contains a theme but it wasn't being used
WriteSolidFill( nFillColor & 0xffffff, nAlpha );
@@ -285,8 +297,10 @@ void DrawingML::WriteSolidFill( Reference< XPropertySet > rXPropSet )
// we must not write a <a: solidFill> tag.
}
else
+ {
// the shape had a custom color and the user didn't change it
WriteSolidFill( nFillColor & 0xffffff, nAlpha );
+ }
}
void DrawingML::WriteGradientStop( sal_uInt16 nStop, sal_uInt32 nColor )
@@ -322,7 +336,8 @@ bool DrawingML::EqualGradients( awt::Gradient aGradient1, awt::Gradient aGradien
void DrawingML::WriteGradientFill( Reference< XPropertySet > rXPropSet )
{
awt::Gradient aGradient;
- if( GETA( FillGradient ) ) {
+ if( GETA( FillGradient ) )
+ {
aGradient = *static_cast< const awt::Gradient* >( mAny.getValue() );
// get InteropGrabBag and search the relevant attributes
@@ -377,6 +392,7 @@ void DrawingML::WriteGrabBagGradientFill( const Sequence< PropertyValue >& aGrad
sal_Int32 nRgbClr = 0;
Sequence< PropertyValue > aTransformations;
for( sal_Int32 j=0; j < aGradientStop.getLength(); ++j )
+ {
if( aGradientStop[j].Name == "SchemeClr" )
aGradientStop[j].Value >>= sSchemeClr;
else if( aGradientStop[j].Name == "RgbClr" )
@@ -387,7 +403,7 @@ void DrawingML::WriteGrabBagGradientFill( const Sequence< PropertyValue >& aGrad
aGradientStop[j].Value >>= nTransparency;
else if( aGradientStop[j].Name == "Transformations" )
aGradientStop[j].Value >>= aTransformations;
-
+ }
// write stop
mpFS->startElementNS( XML_a, XML_gs,
XML_pos, OString::number( nPos * 100000.0 ).getStr(),
@@ -399,7 +415,9 @@ void DrawingML::WriteGrabBagGradientFill( const Sequence< PropertyValue >& aGrad
WriteColor( nRgbClr, nAlpha );
}
else
+ {
WriteColor( sSchemeClr, aTransformations );
+ }
mpFS->endElementNS( XML_a, XML_gs );
}
mpFS->endElementNS( XML_a, XML_gsLst );
@@ -411,7 +429,8 @@ void DrawingML::WriteGrabBagGradientFill( const Sequence< PropertyValue >& aGrad
void DrawingML::WriteGradientFill( awt::Gradient rGradient )
{
- switch( rGradient.Style ) {
+ switch( rGradient.Style )
+ {
default:
case GradientStyle_LINEAR:
mpFS->startElementNS( XML_a, XML_gsLst, FSEND );
@@ -458,12 +477,14 @@ void DrawingML::WriteLineArrow( Reference< XPropertySet > rXPropSet, bool bLineS
sal_Int32 nArrowLength;
sal_Int32 nArrowWidth;
- if ( EscherPropertyContainer::GetLineArrow( bLineStart, rXPropSet, eLineEnd, nArrowLength, nArrowWidth ) ) {
+ if ( EscherPropertyContainer::GetLineArrow( bLineStart, rXPropSet, eLineEnd, nArrowLength, nArrowWidth ) )
+ {
const char* len;
const char* type;
const char* width;
- switch( nArrowLength ) {
+ switch( nArrowLength )
+ {
case ESCHER_LineShortArrow:
len = "sm";
break;
@@ -476,7 +497,8 @@ void DrawingML::WriteLineArrow( Reference< XPropertySet > rXPropSet, bool bLineS
break;
}
- switch( eLineEnd ) {
+ switch( eLineEnd )
+ {
default:
case ESCHER_LineNoEnd:
type = "none";
@@ -498,7 +520,8 @@ void DrawingML::WriteLineArrow( Reference< XPropertySet > rXPropSet, bool bLineS
break;
}
- switch( nArrowWidth ) {
+ switch( nArrowWidth )
+ {
case ESCHER_LineNarrowArrow:
width = "sm";
break;
@@ -544,6 +567,7 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
Sequence< PropertyValue > aGrabBag;
mAny >>= aGrabBag;
for( sal_Int32 i=0; i < aGrabBag.getLength(); ++i )
+ {
if( aGrabBag[i].Name == "SpPrLnSolidFillSchemeClr" )
aGrabBag[i].Value >>= sColorFillScheme;
else if( aGrabBag[i].Name == "OriginalLnSolidFillClr" )
@@ -552,9 +576,11 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
aGrabBag[i].Value >>= aStyleProperties;
else if( aGrabBag[i].Name == "SpPrLnSolidFillSchemeClrTransformations" )
aGrabBag[i].Value >>= aTransformations;
+ }
if( aStyleProperties.hasElements() )
{
for( sal_Int32 i=0; i < aStyleProperties.getLength(); ++i )
+ {
if( aStyleProperties[i].Name == "Color" )
aStyleProperties[i].Value >>= nStyleColor;
else if( aStyleProperties[i].Name == "LineStyle" )
@@ -563,17 +589,20 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
aStyleProperties[i].Value >>= aStyleLineJoint;
else if( aStyleProperties[i].Name == "LineWidth" )
aStyleProperties[i].Value >>= nStyleLineWidth;
+ }
}
}
GET( nLineWidth, LineWidth );
- switch( aLineStyle ) {
+ switch( aLineStyle )
+ {
case drawing::LineStyle_NONE:
bNoFill = true;
break;
case drawing::LineStyle_DASH:
- if( GETA( LineDash ) ) {
+ if( GETA( LineDash ) )
+ {
aLineDash = *(drawing::LineDash*) mAny.getValue();
bDashSet = true;
if( aLineDash.Style == DashStyle_ROUND || aLineDash.Style == DashStyle_ROUNDRELATIVE )
@@ -585,7 +614,8 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
/* fallthru intended */
case drawing::LineStyle_SOLID:
default:
- if ( GETA( LineColor ) ) {
+ if ( GETA( LineColor ) )
+ {
nColor = *((sal_uInt32*) mAny.getValue()) & 0xffffff;
bColorSet = true;
}
@@ -601,11 +631,15 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
if( bColorSet )
{
if( nColor != nOriginalColor )
+ {
// the user has set a different color for the line
WriteSolidFill( nColor );
+ }
else if( !sColorFillScheme.isEmpty() )
+ {
// the line had a scheme color and the user didn't change it
WriteSolidFill( sColorFillScheme, aTransformations );
+ }
else if( aStyleProperties.hasElements() )
{
if( nColor != nStyleColor )
@@ -615,17 +649,22 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
// we must not write a <a: solidFill> tag.
}
else
+ {
WriteSolidFill( nColor );
+ }
}
- if( bDashSet && aStyleLineStyle != drawing::LineStyle_DASH ) {
+ if( bDashSet && aStyleLineStyle != drawing::LineStyle_DASH )
+ {
// line style is a dash and it was not set by the shape style
if (aLineDash.Dashes == 1 && aLineDash.DashLen == 564 && aLineDash.Distance == 423)
+ {
// That's exactly the predefined "dash" value.
mpFS->singleElementNS(XML_a, XML_prstDash,
XML_val, "dash",
FSEND);
+ }
else
{
mpFS->startElementNS( XML_a, XML_custDash, FSEND );
@@ -638,18 +677,22 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
if ( aLineDash.Dashes > 0 )
{
for( i = 0; i < aLineDash.Dashes; i ++ )
+ {
mpFS->singleElementNS( XML_a , XML_ds,
XML_d , write1000thOfAPercent( aLineDash.DashLen > 0 ? aLineDash.DashLen / nLineWidth * 100 : 100 ),
XML_sp, write1000thOfAPercent( aLineDash.Distance > 0 ? aLineDash.Distance / nLineWidth * 100 : 100 ),
FSEND );
+ }
}
if ( aLineDash.Dots > 0 )
{
for( i = 0; i < aLineDash.Dots; i ++ )
+ {
mpFS->singleElementNS( XML_a, XML_ds,
XML_d , write1000thOfAPercent( aLineDash.DotLen > 0 ? aLineDash.DotLen / nLineWidth * 100 : 100 ),
XML_sp, write1000thOfAPercent( aLineDash.Distance > 0 ? aLineDash.Distance / nLineWidth * 100 : 100 ),
FSEND );
+ }
}
}
@@ -670,13 +713,16 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
}
}
- if( !bNoFill && nLineWidth > 1 && GETA( LineJoint ) ) {
+ if( !bNoFill && nLineWidth > 1 && GETA( LineJoint ) )
+ {
LineJoint eLineJoint;
mAny >>= eLineJoint;
if( aStyleLineJoint == LineJoint_NONE || aStyleLineJoint != eLineJoint )
+ {
// style-defined line joint does not exist, or is different from the shape's joint
- switch( eLineJoint ) {
+ switch( eLineJoint )
+ {
case LineJoint_NONE:
case LineJoint_MIDDLE:
case LineJoint_BEVEL:
@@ -690,6 +736,7 @@ void DrawingML::WriteOutline( Reference< XPropertySet > rXPropSet )
mpFS->singleElementNS( XML_a, XML_round, FSEND );
break;
}
+ }
}
if( !bNoFill )
@@ -718,7 +765,9 @@ OUString DrawingML::WriteImage( const OUString& rURL, bool bRelPathToMedia )
Graphic aGraphic = GraphicObject( aURLBS.copy(RTL_CONSTASCII_LENGTH(aURLBegin)) ).GetTransformedGraphic ();
return WriteImage( aGraphic , bRelPathToMedia );
- } else {
+ }
+ else
+ {
// add link to relations
}
@@ -760,7 +809,8 @@ OUString DrawingML::WriteImage( const Graphic& rGraphic , bool bRelPathToMedia )
const void* aData = aLink.GetData();
sal_Size nDataSize = aLink.GetDataSize();
- switch ( aLink.GetType() ) {
+ switch ( aLink.GetType() )
+ {
case GFX_LINK_TYPE_NATIVE_GIF:
sMediaType = "image/gif";
pExtension = ".gif";
@@ -801,9 +851,11 @@ OUString DrawingML::WriteImage( const Graphic& rGraphic , bool bRelPathToMedia )
sMediaType = "application/movie";
pExtension = ".MOV";
break;
- default: {
+ default:
+ {
GraphicType aType = rGraphic.GetType();
- if ( aType == GRAPHIC_BITMAP || aType == GRAPHIC_GDIMETAFILE) {
+ if ( aType == GRAPHIC_BITMAP || aType == GRAPHIC_GDIMETAFILE)
+ {
bool bSwapped = rGraphic.IsSwapOut();
//Warn rather than just happily swap in because of the comments
@@ -817,11 +869,14 @@ OUString DrawingML::WriteImage( const Graphic& rGraphic , bool bRelPathToMedia )
if (bSwapped)
const_cast<Graphic&>(rGraphic).SwapIn();
- if ( aType == GRAPHIC_BITMAP ) {
+ if ( aType == GRAPHIC_BITMAP )
+ {
GraphicConverter::Export( aStream, rGraphic, CVT_PNG );
sMediaType = "image/png";
pExtension = ".png";
- } else {
+ }
+ else
+ {
GraphicConverter::Export( aStream, rGraphic, CVT_EMF );
sMediaType = "image/x-emf";
pExtension = ".emf";
@@ -829,7 +884,9 @@ OUString DrawingML::WriteImage( const Graphic& rGraphic , bool bRelPathToMedia )
if (bSwapped)
const_cast<Graphic&>(rGraphic).SwapOut();
- } else {
+ }
+ else
+ {
OSL_TRACE( "unhandled graphic type" );
/*Earlier, even in case of unhandled graphic types we were
proceeding to write the image, which would eventually
@@ -842,7 +899,7 @@ OUString DrawingML::WriteImage( const Graphic& rGraphic , bool bRelPathToMedia )
aData = aStream.GetData();
nDataSize = aStream.GetEndOfData();
break;
- }
+ }
}
Reference< XOutputStream > xOutStream = mpFB->openFragmentStream( OUStringBuffer()
@@ -881,12 +938,14 @@ OUString DrawingML::WriteBlip( Reference< XPropertySet > rXPropSet, const OUStri
mpFS->startElementNS( XML_a, XML_blip,
FSNS( XML_r, XML_embed), OUStringToOString( sRelId, RTL_TEXTENCODING_UTF8 ).getStr(),
- FSEND );
+ FSEND );
if( nBright || nContrast )
+ {
mpFS->singleElementNS( XML_a, XML_lum,
XML_bright, nBright ? I32S( nBright*1000 ) : NULL,
XML_contrast, nContrast ? I32S( nContrast*1000 ) : NULL,
FSEND );
+ }
WriteArtisticEffect( rXPropSet );
mpFS->endElementNS( XML_a, XML_blip );
@@ -902,7 +961,8 @@ void DrawingML::WriteBlipMode( Reference< XPropertySet > rXPropSet, const OUStri
DBG(fprintf(stderr, "fill bitmap mode: %d\n", eBitmapMode));
- switch (eBitmapMode) {
+ switch (eBitmapMode)
+ {
case BitmapMode_REPEAT:
mpFS->singleElementNS( XML_a, XML_tile, FSEND );
break;
@@ -910,7 +970,7 @@ void DrawingML::WriteBlipMode( Reference< XPropertySet > rXPropSet, const OUStri
WriteStretch( rXPropSet, rURL );
break;
default:
- ;
+ break;
}
}
@@ -932,7 +992,8 @@ void DrawingML::WriteBlipFill( Reference< XPropertySet > rXPropSet, const OUStri
void DrawingML::WriteBlipFill( Reference< XPropertySet > rXPropSet, const OUString& sURLPropName, sal_Int32 nXmlNamespace )
{
- if ( GetProperty( rXPropSet, sURLPropName ) ) {
+ if ( GetProperty( rXPropSet, sURLPropName ) )
+ {
OUString aURL;
mAny >>= aURL;
bool bWriteMode = false;
@@ -944,7 +1005,8 @@ void DrawingML::WriteBlipFill( Reference< XPropertySet > rXPropSet, const OUStri
void DrawingML::WriteBlipFill( Reference< XPropertySet > rXPropSet, const OUString& sBitmapURL, sal_Int32 nXmlNamespace, bool bWriteMode, bool bRelPathToMedia )
{
- if ( !sBitmapURL.isEmpty() ) {
+ if ( !sBitmapURL.isEmpty() )
+ {
DBG(fprintf (stderr, "URL: %s\n", OUStringToOString( sBitmapURL, RTL_TEXTENCODING_UTF8 ).getStr() ));
mpFS->startElementNS( nXmlNamespace , XML_blipFill, FSEND );
@@ -952,8 +1014,11 @@ void DrawingML::WriteBlipFill( Reference< XPropertySet > rXPropSet, const OUStri
WriteBlip( rXPropSet, sBitmapURL, bRelPathToMedia );
if( bWriteMode )
+ {
WriteBlipMode( rXPropSet, sBitmapURL );
- else if( GetProperty( rXPropSet, "FillBitmapStretch" ) ) {
+ }
+ else if( GetProperty( rXPropSet, "FillBitmapStretch" ) )
+ {
bool bStretch = false;
mAny >>= bStretch;
@@ -998,10 +1063,10 @@ void DrawingML::WriteSrcRect( Reference< XPropertySet > rXPropSet, const OUStrin
if ( (0 != aGraphicCropStruct.Left) || (0 != aGraphicCropStruct.Top) || (0 != aGraphicCropStruct.Right) || (0 != aGraphicCropStruct.Bottom) )
{
mpFS->singleElementNS( XML_a, XML_srcRect,
- XML_l, I32S(((aGraphicCropStruct.Left) * 100000)/aOriginalSize.Width()),
- XML_t, I32S(((aGraphicCropStruct.Top) * 100000)/aOriginalSize.Height()),
- XML_r, I32S(((aGraphicCropStruct.Right) * 100000)/aOriginalSize.Width()),
- XML_b, I32S(((aGraphicCropStruct.Bottom) * 100000)/aOriginalSize.Height()),
+ XML_l, I32S(((aGraphicCropStruct.Left) * 100000) / aOriginalSize.Width()),
+ XML_t, I32S(((aGraphicCropStruct.Top) * 100000) / aOriginalSize.Height()),
+ XML_r, I32S(((aGraphicCropStruct.Right) * 100000) / aOriginalSize.Width()),
+ XML_b, I32S(((aGraphicCropStruct.Bottom) * 100000) / aOriginalSize.Height()),
FSEND );
}
}
@@ -1094,7 +1159,10 @@ void DrawingML::WriteShapeTransformation( Reference< XShape > rXShape, sal_Int32
}
if (!bSuppressRotation)
{
- if (bFlipV) {nRotation=(nRotation+18000)%36000;}
+ if (bFlipV)
+ {
+ nRotation=(nRotation+18000)%36000;
+ }
}
WriteTransformation( Rectangle( Point( aPos.X, aPos.Y ), Size( aSize.Width, aSize.Height ) ), nXmlNamespace, bFlipH, bFlipV, OOX_DRAWINGML_EXPORT_ROTATE_CLOCKWISIFY(nRotation) );
}
@@ -1118,8 +1186,10 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
nSize = (sal_Int32) (100*(*((float*) mAny.getValue())));
if ( ( bComplex && GETA( CharWeightComplex ) ) || GETA( CharWeight ) )
+ {
if ( *((float*) mAny.getValue()) >= awt::FontWeight::SEMIBOLD )
bold = "1";
+ }
if ( ( bComplex && GETA( CharPostureComplex ) ) || GETA( CharPosture ) )
switch ( *((awt::FontSlant*) mAny.getValue()) )
@@ -1133,6 +1203,7 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
}
if ( GETAD( CharUnderline ) )
+ {
switch ( *((sal_Int16*) mAny.getValue()) )
{
case awt::FontUnderline::SINGLE :
@@ -1184,6 +1255,7 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
underline = "wavyHeavy";
break;
}
+ }
if ( GETAD( CharStrikeout ) )
{
@@ -1211,7 +1283,8 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
}
}
- if( GETA( CharLocale ) ) {
+ if( GETA( CharLocale ) )
+ {
com::sun::star::lang::Locale aLocale;
mAny >>= aLocale;
LanguageTag aLanguageTag( aLocale);
@@ -1222,7 +1295,8 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
if( GETAD( CharEscapement ) )
mAny >>= nCharEscapement;
- if( nCharEscapement && GETAD( CharEscapementHeight ) ) {
+ if( nCharEscapement && GETAD( CharEscapementHeight ) )
+ {
sal_uInt32 nCharEscapementHeight = 0;
mAny >>= nCharEscapementHeight;
nSize = (nSize * nCharEscapementHeight) / 100;
@@ -1241,11 +1315,13 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
FSEND );
// mso doesn't like text color to be placed after typeface
- if( GETAD( CharColor ) ) {
+ if( GETAD( CharColor ) )
+ {
sal_uInt32 color = *((sal_uInt32*) mAny.getValue());
DBG(fprintf(stderr, "run color: %x auto: %x\n", static_cast<unsigned int>( color ), static_cast<unsigned int>( COL_AUTO )));
- if( color == COL_AUTO ) { // nCharColor depends to the background color
+ if( color == COL_AUTO ) // nCharColor depends to the background color
+ {
bool bIsDark = false;
GET( bIsDark, IsBackgroundDark );
color = bIsDark ? 0xffffff : 0x000000;
@@ -1257,7 +1333,8 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
WriteSolidFill( color );
}
- if( GETA( CharFontName ) ) {
+ if( GETA( CharFontName ) )
+ {
const char* pitch = NULL;
const char* charset = NULL;
OUString usTypeface;
@@ -1272,7 +1349,8 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
FSEND );
}
- if( ( bComplex && GETAD( CharFontNameComplex ) ) || ( !bComplex && GETAD( CharFontNameAsian ) ) ) {
+ if( ( bComplex && GETAD( CharFontNameComplex ) ) || ( !bComplex && GETAD( CharFontNameAsian ) ) )
+ {
const char* pitch = NULL;
const char* charset = NULL;
OUString usTypeface;
@@ -1287,7 +1365,8 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
FSEND );
}
- if( bIsField ) {
+ if( bIsField )
+ {
Reference< XTextField > rXTextField;
GET( rXTextField, TextField );
if( rXTextField.is() )
@@ -1295,19 +1374,20 @@ void DrawingML::WriteRunProperties( Reference< XPropertySet > rRun, bool bIsFiel
}
// field properties starts here
- if( GETA( URL ) ) {
- OUString sURL;
+ if( GETA( URL ) )
+ {
+ OUString sURL;
- mAny >>= sURL;
- if( !sURL.isEmpty() ) {
- OUString sRelId = mpFB->addRelation( mpFS->getOutputStream(),
- "http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",
- sURL, true );
+ mAny >>= sURL;
+ if( !sURL.isEmpty() ) {
+ OUString sRelId = mpFB->addRelation( mpFS->getOutputStream(),
+ "http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",
+ sURL, true );
- mpFS->singleElementNS( XML_a, XML_hlinkClick,
- FSNS( XML_r,XML_id ), USS( sRelId ),
- FSEND );
- }
+ mpFS->singleElementNS( XML_a, XML_hlinkClick,
+ FSNS( XML_r,XML_id ), USS( sRelId ),
+ FSEND );
+ }
}
mpFS->endElementNS( XML_a, XML_rPr );
@@ -1319,21 +1399,26 @@ const char* DrawingML::GetFieldType( ::com::sun::star::uno::Reference< ::com::su
Reference< XPropertySet > rXPropSet( rRun, UNO_QUERY );
OUString aFieldType;
- if( GETA( TextPortionType ) ) {
+ if( GETA( TextPortionType ) )
+ {
aFieldType = OUString( *(OUString*)mAny.getValue() );
DBG(fprintf (stderr, "field type: %s\n", USS(aFieldType) ));
}
- if( aFieldType == "TextField" ) {
+ if( aFieldType == "TextField" )
+ {
Reference< XTextField > rXTextField;
GET( rXTextField, TextField );
- if( rXTextField.is() ) {
- bIsField = true;
+ if( rXTextField.is() )
+ {
+ bIsField = true;
rXPropSet.set( rXTextField, UNO_QUERY );
- if( rXPropSet.is() ) {
+ if( rXPropSet.is() )
+ {
OUString aFieldKind( rXTextField->getPresentation( true ) );
DBG(fprintf (stderr, "field kind: %s\n", USS(aFieldKind) ));
- if( aFieldKind == "Page" ) {
+ if( aFieldKind == "Page" )
+ {
return "slidenum";
}
// else if( aFieldKind == "URL" ) {
@@ -1355,27 +1440,32 @@ void DrawingML::GetUUID( OStringBuffer& rBuffer )
int i;
rBuffer.append( '{' );
- for( i = 0; i < 4; i++ ) {
+ for( i = 0; i < 4; i++ )
+ {
rBuffer.append( cDigits[ aSeq[i] >> 4 ] );
rBuffer.append( cDigits[ aSeq[i] & 0xf ] );
}
rBuffer.append( '-' );
- for( ; i < 6; i++ ) {
+ for( ; i < 6; i++ )
+ {
rBuffer.append( cDigits[ aSeq[i] >> 4 ] );
rBuffer.append( cDigits[ aSeq[i] & 0xf ] );
}
rBuffer.append( '-' );
- for( ; i < 8; i++ ) {
+ for( ; i < 8; i++ )
+ {
rBuffer.append( cDigits[ aSeq[i] >> 4 ] );
rBuffer.append( cDigits[ aSeq[i] & 0xf ] );
}
rBuffer.append( '-' );
- for( ; i < 10; i++ ) {
+ for( ; i < 10; i++ )
+ {
rBuffer.append( cDigits[ aSeq[i] >> 4 ] );
rBuffer.append( cDigits[ aSeq[i] & 0xf ] );
}
rBuffer.append( '-' );
- for( ; i < 16; i++ ) {
+ for( ; i < 16; i++ )
+ {
rBuffer.append( cDigits[ aSeq[i] >> 4 ] );
rBuffer.append( cDigits[ aSeq[i] & 0xf ] );
}
@@ -1388,7 +1478,8 @@ void DrawingML::WriteRun( Reference< XTextRange > rRun )
bool bIsField = false;
OUString sText = rRun->getString();
- if( sText.isEmpty()) {
+ if( sText.isEmpty())
+ {
Reference< XPropertySet > xPropSet( rRun, UNO_QUERY );
try
@@ -1398,13 +1489,15 @@ void DrawingML::WriteRun( Reference< XTextRange > rRun )
if( sText.isEmpty() )
return;
}
- catch (const Exception &) {
+ catch (const Exception &)
+ {
return;
}
}
sFieldType = GetFieldType( rRun, bIsField );
- if( ( sFieldType != NULL ) ) {
+ if( ( sFieldType != NULL ) )
+ {
OStringBuffer sUUID(39);
GetUUID( sUUID );
@@ -1412,8 +1505,11 @@ void DrawingML::WriteRun( Reference< XTextRange > rRun )
XML_id, sUUID.getStr(),
XML_type, sFieldType,
FSEND );
- } else
+ }
+ else
+ {
mpFS->startElementNS( XML_a, XML_r, FSEND );
+ }
Reference< XPropertySet > xPropSet( rRun, uno::UNO_QUERY );
WriteRunProperties( xPropSet, bIsField );
@@ -1607,7 +1703,8 @@ const char* DrawingML::GetAlignment( sal_Int32 nAlignment )
{
const char* sAlignment = NULL;
- switch( nAlignment ) {
+ switch( nAlignment )
+ {
case style::ParagraphAdjust_CENTER:
sAlignment = "ctr";
break;
@@ -1627,13 +1724,17 @@ const char* DrawingML::GetAlignment( sal_Int32 nAlignment )
void DrawingML::WriteLinespacing( LineSpacing& rSpacing )
{
if( rSpacing.Mode == LineSpacingMode::PROP )
+ {
mpFS->singleElementNS( XML_a, XML_spcPct,
XML_val, I32S( ((sal_Int32)rSpacing.Height)*1000 ),
FSEND );
+ }
else
+ {
mpFS->singleElementNS( XML_a, XML_spcPts,
XML_val, I32S( rSpacing.Height ),
FSEND );
+ }
}
void DrawingML::WriteParagraphProperties( Reference< XTextContent > rParagraph )
@@ -1658,14 +1759,16 @@ void DrawingML::WriteParagraphProperties( Reference< XTextContent > rParagraph )
if( nLevel != -1
|| nAlignment != style::ParagraphAdjust_LEFT
- || bHasLinespacing ) {
+ || bHasLinespacing )
+ {
mpFS->startElementNS( XML_a, XML_pPr,
XML_lvl, nLevel > 0 ? I32S( nLevel ) : NULL,
XML_marL, NULL,
XML_algn, GetAlignment( nAlignment ),
FSEND );
- if( bHasLinespacing ) {
+ if( bHasLinespacing )
+ {
mpFS->startElementNS( XML_a, XML_lnSpc, FSEND );
WriteLinespacing( aLineSpacing );
mpFS->endElementNS( XML_a, XML_lnSpc );
@@ -1690,12 +1793,15 @@ void DrawingML::WriteParagraph( Reference< XTextContent > rParagraph )
mpFS->startElementNS( XML_a, XML_p, FSEND );
bool bPropertiesWritten = false;
- while( enumeration->hasMoreElements() ) {
+ while( enumeration->hasMoreElements() )
+ {
Reference< XTextRange > run;
Any any ( enumeration->nextElement() );
- if (any >>= run) {
- if( !bPropertiesWritten ) {
+ if (any >>= run)
+ {
+ if( !bPropertiesWritten )
+ {
WriteParagraphProperties( rParagraph );
bPropertiesWritten = true;
}
@@ -1736,10 +1842,12 @@ void DrawingML::WriteText( Reference< XInterface > rXIface, const OUString& pres
const char* sWritingMode = NULL;
bool bVertical = false;
- if( GETA( TextWritingMode ) ) {
+ if( GETA( TextWritingMode ) )
+ {
WritingMode eMode;
- if( ( mAny >>= eMode ) && eMode == WritingMode_TB_RL ) {
+ if( ( mAny >>= eMode ) && eMode == WritingMode_TB_RL )
+ {
sWritingMode = "vert";
bVertical = true;
}
@@ -1782,7 +1890,8 @@ void DrawingML::WriteText( Reference< XInterface > rXIface, const OUString& pres
bool bHasWrap = false;
bool bWrap = false;
// Only custom shapes obey the TextWordWrap option, normal text always wraps.
- if( dynamic_cast<SvxCustomShape*>(rXIface.get()) && GETA( TextWordWrap ) ) {
+ if( dynamic_cast<SvxCustomShape*>(rXIface.get()) && GETA( TextWordWrap ) )
+ {
mAny >>= bWrap;
bHasWrap = true;
}
@@ -1861,7 +1970,8 @@ void DrawingML::WriteText( Reference< XInterface > rXIface, const OUString& pres
return;
}
- while( enumeration->hasMoreElements() ) {
+ while( enumeration->hasMoreElements() )
+ {
Reference< XTextContent > paragraph;
Any any ( enumeration->nextElement() );
@@ -1921,7 +2031,8 @@ void DrawingML::WritePresetShape( const char* pShape, MSO_SPT eShapeType, bool b
&& eShapeType != mso_sptActionButtonForwardNext // we have adjustments values for these type of shape, but MSO doesn't like them
&& eShapeType != mso_sptActionButtonBackPrevious // so they are now disabled
&& OString(pShape) != "rect" //some shape types are commented out in pCustomShapeTypeTranslationTable[] & are being defaulted to rect & rect does not have adjustment values/name.
- ) {
+ )
+ {
DBG(fprintf(stderr, "adj seq len: %d\n", int( aAdjustmentSeq.getLength() )));
if ( bPredefinedHandlesUsed )
EscherPropertyContainer::LookForPolarHandles( eShapeType, nAdjustmentsWhichNeedsToBeConverted );
@@ -1931,6 +2042,7 @@ void DrawingML::WritePresetShape( const char* pShape, MSO_SPT eShapeType, bool b
if(aAdjustments.size() == static_cast<sal_uInt32>(nLength))// In case there is a mismatch do not write the XML_gd tag.
{
for( sal_Int32 i=0; i < nLength; i++ )
+ {
if( EscherPropertyContainer::GetAdjustmentValue( aAdjustmentSeq[ i ], i, nAdjustmentsWhichNeedsToBeConverted, nValue ) )
{
// If the document model doesn't have an adjustment name (e.g. shape was created from VML), then take it from the predefined list.
@@ -1942,6 +2054,7 @@ void DrawingML::WritePresetShape( const char* pShape, MSO_SPT eShapeType, bool b
XML_name, aAdjustmentSeq[ i ].Name.getLength() > 0 ? USS(aAdjustmentSeq[ i ].Name) : aAdjName.getStr(),
XML_fmla, OString("val " + OString::number( nValue )).getStr(),
FSEND );
+ }
}
}
}
@@ -1968,7 +2081,8 @@ void DrawingML::WritePolyPolygon( const PolyPolygon& rPolyPolygon )
mpFS->startElementNS( XML_a, XML_pathLst, FSEND );
- for( sal_uInt16 i = 0; i < rPolyPolygon.Count(); i ++ ) {
+ for( sal_uInt16 i = 0; i < rPolyPolygon.Count(); i ++ )
+ {
const Polygon& rPoly = rPolyPolygon[ i ];
Rectangle aRect( rPoly.GetBoundRect() );
@@ -2028,21 +2142,25 @@ void DrawingML::WritePolyPolygon( const PolyPolygon& rPolyPolygon )
mpFS->endElementNS( XML_a, XML_pathLst );
- mpFS->endElementNS( XML_a, XML_custGeom );
+ mpFS->endElementNS( XML_a, XML_custGeom );
}
void DrawingML::WriteConnectorConnections( EscherConnectorListEntry& rConnectorEntry, sal_Int32 nStartID, sal_Int32 nEndID )
{
if( nStartID != -1 )
+ {
mpFS->singleElementNS( XML_a, XML_stCxn,
XML_id, I32S( nStartID ),
XML_idx, I64S( rConnectorEntry.GetConnectorRule( true ) ),
FSEND );
+ }
if( nEndID != -1 )
+ {
mpFS->singleElementNS( XML_a, XML_endCxn,
XML_id, I32S( nEndID ),
XML_idx, I64S( rConnectorEntry.GetConnectorRule( false ) ),
FSEND );
+ }
}
sal_Unicode DrawingML::SubstituteBullet( sal_Unicode cBulletId, ::com::sun::star::awt::FontDescriptor& rFontDesc )
@@ -2127,19 +2245,23 @@ void DrawingML::WriteStyleProperties( sal_Int32 nTokenId, const Sequence< Proper
sal_uInt32 nIdx = 0;
Sequence< PropertyValue > aTransformations;
for( sal_Int32 i=0; i < aProperties.getLength(); ++i)
+ {
if( aProperties[i].Name == "SchemeClr" )
aProperties[i].Value >>= sSchemeClr;
else if( aProperties[i].Name == "Idx" )
aProperties[i].Value >>= nIdx;
else if( aProperties[i].Name == "Transformations" )
aProperties[i].Value >>= aTransformations;
+ }
mpFS->startElementNS( XML_a, nTokenId, XML_idx, I32S( nIdx ), FSEND );
WriteColor( sSchemeClr, aTransformations );
mpFS->endElementNS( XML_a, nTokenId );
}
else
+ {
// write mock <a:*Ref> tag
mpFS->singleElementNS( XML_a, nTokenId, XML_idx, I32S( 0 ), FSEND );
+ }
}
void DrawingML::WriteShapeStyle( Reference< XPropertySet > xPropSet )
@@ -2153,12 +2275,14 @@ void DrawingML::WriteShapeStyle( Reference< XPropertySet > xPropSet )
Sequence< PropertyValue > aFillRefProperties, aLnRefProperties, aEffectRefProperties;
mAny >>= aGrabBag;
for( sal_Int32 i=0; i < aGrabBag.getLength(); ++i)
+ {
if( aGrabBag[i].Name == "StyleFillRef" )
aGrabBag[i].Value >>= aFillRefProperties;
else if( aGrabBag[i].Name == "StyleLnRef" )
aGrabBag[i].Value >>= aLnRefProperties;
else if( aGrabBag[i].Name == "StyleEffectRef" )
aGrabBag[i].Value >>= aEffectRefProperties;
+ }
WriteStyleProperties( XML_lnRef, aLnRefProperties );
WriteStyleProperties( XML_fillRef, aFillRefProperties );
@@ -2388,6 +2512,7 @@ void DrawingML::WriteShape3DEffects( Reference< XPropertySet > xPropSet )
Sequence< PropertyValue > aGrabBag, aEffectProps, aLightRigProps, aShape3DProps;
mAny >>= aGrabBag;
for( sal_Int32 i=0; i < aGrabBag.getLength(); ++i )
+ {
if( aGrabBag[i].Name == "3DEffectProperties" )
{
Sequence< PropertyValue > a3DEffectProps;
@@ -2403,6 +2528,7 @@ void DrawingML::WriteShape3DEffects( Reference< XPropertySet > xPropSet )
}
break;
}
+ }
if( aEffectProps.getLength() == 0 && aLightRigProps.getLength() == 0 && aShape3DProps.getLength() == 0 )
return;
@@ -2495,8 +2621,10 @@ void DrawingML::WriteShape3DEffects( Reference< XPropertySet > xPropSet )
mpFS->endElementNS( XML_a, XML_camera );
}
else
+ {
// a:camera with Word default values - Word won't open the document if this is not present
mpFS->singleElementNS( XML_a, XML_camera, XML_prst, "orthographicFront", FSEND );
+ }
if( aEffectProps.getLength() > 0 )
{
@@ -2508,8 +2636,10 @@ void DrawingML::WriteShape3DEffects( Reference< XPropertySet > xPropSet )
mpFS->endElementNS( XML_a, XML_lightRig );
}
else
+ {
// a:lightRig with Word default values - Word won't open the document if this is not present
mpFS->singleElementNS( XML_a, XML_lightRig, XML_rig, "threePt", XML_dir, "t", FSEND );
+ }
mpFS->endElementNS( XML_a, XML_scene3d );