summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--filter/source/msfilter/msdffimp.cxx2
-rw-r--r--sw/source/filter/ww8/wrtw8esh.cxx57
2 files changed, 57 insertions, 2 deletions
diff --git a/filter/source/msfilter/msdffimp.cxx b/filter/source/msfilter/msdffimp.cxx
index cc2dbf6e9000..23c95fe7660d 100644
--- a/filter/source/msfilter/msdffimp.cxx
+++ b/filter/source/msfilter/msdffimp.cxx
@@ -2616,7 +2616,7 @@ void DffPropertyReader::ApplyAttributes( SvStream& rIn, SfxItemSet& rSet, DffObj
break;
}
}
- if ( ( ( nLineFlags & 0x08 ) == 0 ) && ( ( nFillFlags & 0x10 ) == 0 ) ) // if there is no fillstyle and linestyle
+ if ( ( ( nLineFlags & 0x08 ) == 0 ) && ( ( nFillFlags & 0x10 ) == 0 ) && ( rObjData.eShapeType != mso_sptPictureFrame )) // if there is no fillstyle and linestyle
bHasShadow = sal_False; // we are turning shadow off.
if ( bHasShadow )
diff --git a/sw/source/filter/ww8/wrtw8esh.cxx b/sw/source/filter/ww8/wrtw8esh.cxx
index 5e7add30c33f..be4f594a009c 100644
--- a/sw/source/filter/ww8/wrtw8esh.cxx
+++ b/sw/source/filter/ww8/wrtw8esh.cxx
@@ -44,6 +44,7 @@
#include <svx/svdoole2.hxx>
#include <editeng/editeng.hxx>
#include <editeng/flditem.hxx>
+#include <editeng/shaditem.hxx>
#include <unotools/ucbstreamhelper.hxx>
#include <svx/fmglob.hxx>
#include <svx/svdouno.hxx>
@@ -92,7 +93,6 @@
#include <fstream>
#include <unotools/streamwrap.hxx>
-
using ::editeng::SvxBorderLine;
using namespace com::sun::star;
using namespace sw::util;
@@ -1793,6 +1793,61 @@ sal_Int32 SwBasicEscherEx::WriteFlyFrameAttr(const SwFrmFmt& rFmt,
rPropOpt.AddOpt( ESCHER_Prop_dxTextLeft, 0 );
rPropOpt.AddOpt( ESCHER_Prop_dxTextRight, 0 );
}
+ const SwAttrSet& rAttrSet = rFmt.GetAttrSet();
+ if (SFX_ITEM_ON == rAttrSet.GetItemState(RES_BOX, false, &pItem))
+ {
+ const SvxBoxItem* pBox = (const SvxBoxItem*)pItem;
+ if( pBox )
+ {
+ const SfxPoolItem* pShadItem;
+ if (SFX_ITEM_ON
+ == rAttrSet.GetItemState(RES_SHADOW, true, &pShadItem))
+ {
+ const SvxShadowItem* pSI = (const SvxShadowItem*)pShadItem;
+
+ const sal_uInt16 nCstScale = 635; // unit scale between SODC and MS Word
+ const sal_uInt32 nShadowType = 131074; // shadow type of ms word. need to set the default value.
+
+ sal_uInt32 nColor = (sal_uInt32)(pSI->GetColor().GetColor()) ;
+ sal_uInt32 nOffX = pSI->GetWidth() * nCstScale;
+ sal_uInt32 nOffY = pSI->GetWidth() * nCstScale;
+ sal_uInt32 nShadow = nShadowType;
+
+ SvxShadowLocation eLocation = pSI->GetLocation();
+ if( (eLocation!=SVX_SHADOW_NONE) && (pSI->GetWidth()!=0) )
+ {
+ switch( eLocation )
+ {
+ case SVX_SHADOW_TOPLEFT:
+ {
+ nOffX = -nOffX;
+ nOffY = -nOffY;
+ }
+ break;
+ case SVX_SHADOW_TOPRIGHT:
+ {
+ nOffY = -nOffY;
+ }
+ break;
+ case SVX_SHADOW_BOTTOMLEFT:
+ {
+ nOffX = -nOffX;
+ }
+ break;
+ case SVX_SHADOW_BOTTOMRIGHT:
+ break;
+ default:
+ break;
+ }
+
+ rPropOpt.AddOpt( DFF_Prop_shadowColor, wwUtility::RGBToBGR((nColor)));
+ rPropOpt.AddOpt( DFF_Prop_shadowOffsetX, nOffX );
+ rPropOpt.AddOpt( DFF_Prop_shadowOffsetY, nOffY );
+ rPropOpt.AddOpt( DFF_Prop_fshadowObscured, nShadow );
+ }
+ }
+ }
+ }
// SwWW8ImplReader::Read_GrafLayer() imports these as opaque
// unconditionally, so if both are true, don't export the property.