diff options
author | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-02-21 19:53:40 +0100 |
---|---|---|
committer | Tomaž Vajngerl <tomaz.vajngerl@collabora.com> | 2014-02-21 23:33:04 +0100 |
commit | 02d8db735bd2166cda4e997775d3e41ecee65c6f (patch) | |
tree | a07df808f2a3c53af29d71b3605700b7f8936d1f /writerfilter | |
parent | 22a5e4db00a1372270b80f6f121fec91de1f20dd (diff) |
writerfilter: add more w14:glow attributes into GrabBag
Fix and add more attributes into the GrabBag, add attributes for
an element into its own collection.
Change-Id: I8d2e2fa35f4bc447c7e913e5c39223fc01f39d5a
Diffstat (limited to 'writerfilter')
-rw-r--r-- | writerfilter/source/dmapper/TextEffectsHandler.cxx | 62 | ||||
-rw-r--r-- | writerfilter/source/dmapper/TextEffectsHandler.hxx | 3 |
2 files changed, 58 insertions, 7 deletions
diff --git a/writerfilter/source/dmapper/TextEffectsHandler.cxx b/writerfilter/source/dmapper/TextEffectsHandler.cxx index ad3fb7557947..6e00b2003a27 100644 --- a/writerfilter/source/dmapper/TextEffectsHandler.cxx +++ b/writerfilter/source/dmapper/TextEffectsHandler.cxx @@ -9,12 +9,12 @@ */ #include <TextEffectsHandler.hxx> +#include <rtl/ustrbuf.hxx> +#include <comphelper/string.hxx> #include <ooxml/resourceids.hxx> #include "dmapperLoggers.hxx" - #include <stack> - namespace writerfilter { namespace dmapper { @@ -29,6 +29,7 @@ struct GrabBagStackElement std::vector<beans::PropertyValue> maPropertyList; }; +/// Tool that is useful for construction of a nested Sequence/PropertyValue hierarchy class GrabBagStack { public: @@ -43,6 +44,11 @@ public: std::stack<GrabBagStackElement> mStack; GrabBagStackElement mCurrentElement; + OUString getCurrentName() + { + return mCurrentElement.maName; + } + PropertyValue getRootProperty() { while(!mStack.empty()) @@ -92,6 +98,27 @@ public: } }; +OUString TextEffectsHandler::getSchemeColorTypeString(sal_Int32 nType) +{ + switch (nType) + { + case NS_ooxml::LN_ST_SchemeColorVal_bg1: return OUString("bg1"); + case NS_ooxml::LN_ST_SchemeColorVal_tx1: return OUString("tx1"); + case NS_ooxml::LN_ST_SchemeColorVal_bg2: return OUString("bg2"); + case NS_ooxml::LN_ST_SchemeColorVal_tx2: return OUString("tx2"); + case NS_ooxml::LN_ST_SchemeColorVal_accent1: return OUString("accent1"); + case NS_ooxml::LN_ST_SchemeColorVal_accent2: return OUString("accent2"); + case NS_ooxml::LN_ST_SchemeColorVal_accent3: return OUString("accent3"); + case NS_ooxml::LN_ST_SchemeColorVal_accent4: return OUString("accent4"); + case NS_ooxml::LN_ST_SchemeColorVal_accent5: return OUString("accent5"); + case NS_ooxml::LN_ST_SchemeColorVal_accent6: return OUString("accent6"); + + default: break; + } + return OUString(); +} + + TextEffectsHandler::TextEffectsHandler() : LoggedProperties(dmapper_logger, "TextEffectsHandler"), mpGrabBagStack(NULL) @@ -104,20 +131,35 @@ TextEffectsHandler::~TextEffectsHandler() void TextEffectsHandler::lcl_attribute(Id aName, Value& aValue) { - sal_Int32 nValue = aValue.getInt(); + + if (mpGrabBagStack->getCurrentName() != "attributes") + mpGrabBagStack->push("attributes"); + switch(aName) { case NS_ooxml::LN_CT_Percentage_val: - mpGrabBagStack->appendElement("val", makeAny(nValue)); + mpGrabBagStack->appendElement("val", makeAny(aValue.getInt())); break; case NS_ooxml::LN_CT_PositiveFixedPercentage_val: - mpGrabBagStack->appendElement("val", makeAny(nValue)); + mpGrabBagStack->appendElement("val", makeAny(aValue.getInt())); + break; + case NS_ooxml::LN_CT_PositivePercentage_val: + mpGrabBagStack->appendElement("val", makeAny(aValue.getInt())); break; case NS_ooxml::LN_CT_SchemeColor_val: - mpGrabBagStack->appendElement("val", makeAny(nValue)); + mpGrabBagStack->appendElement("val", makeAny(getSchemeColorTypeString(aValue.getInt()))); + break; + case NS_ooxml::LN_CT_SRgbColor_val: + { + OUStringBuffer aBuf = OUString::number(aValue.getInt(), 16); + OUStringBuffer aStr; + comphelper::string::padToLength(aStr, 6 - aBuf.getLength(), '0'); + aStr.append(aBuf.getStr()); + mpGrabBagStack->appendElement("val", makeAny(aStr.makeStringAndClear())); + } break; case NS_ooxml::LN_CT_Glow_rad: - mpGrabBagStack->appendElement("rad", makeAny(nValue)); + mpGrabBagStack->appendElement("rad", makeAny(aValue.getInt())); break; default: break; @@ -126,6 +168,9 @@ void TextEffectsHandler::lcl_attribute(Id aName, Value& aValue) void TextEffectsHandler::lcl_sprm(Sprm& rSprm) { + if (mpGrabBagStack->getCurrentName() == "attributes") + mpGrabBagStack->pop(); + sal_uInt32 nSprmId = rSprm.getId(); switch(nSprmId) @@ -177,6 +222,9 @@ void TextEffectsHandler::lcl_sprm(Sprm& rSprm) pProperties.get()->resolve( *this ); + if (mpGrabBagStack->getCurrentName() == "attributes") + mpGrabBagStack->pop(); + switch(nSprmId) { case NS_ooxml::LN_EG_ColorChoice_srgbClr: diff --git a/writerfilter/source/dmapper/TextEffectsHandler.hxx b/writerfilter/source/dmapper/TextEffectsHandler.hxx index 89c56260cd09..f224c63fc9dc 100644 --- a/writerfilter/source/dmapper/TextEffectsHandler.hxx +++ b/writerfilter/source/dmapper/TextEffectsHandler.hxx @@ -24,6 +24,7 @@ namespace dmapper class GrabBagStack; +/// Class to process all text effects like glow, textOutline, ... class TextEffectsHandler : public LoggedProperties { private: @@ -41,6 +42,8 @@ public: void enableInteropGrabBag(OUString aName); void disableInteropGrabBag(); bool isInteropGrabBagEnabled(); + + static OUString getSchemeColorTypeString(sal_Int32 nType); }; typedef boost::shared_ptr<TextEffectsHandler> TextEffectsHandlerPtr; |