mirror of
https://github.com/ONLYOFFICE/core.git
synced 2026-04-07 13:55:33 +08:00
592 lines
17 KiB
C++
592 lines
17 KiB
C++
/*
|
|
* (c) Copyright Ascensio System SIA 2010-2023
|
|
*
|
|
* This program is a free software product. You can redistribute it and/or
|
|
* modify it under the terms of the GNU Affero General Public License (AGPL)
|
|
* version 3 as published by the Free Software Foundation. In accordance with
|
|
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
|
|
* that Ascensio System SIA expressly excludes the warranty of non-infringement
|
|
* of any third-party rights.
|
|
*
|
|
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
|
|
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
|
|
*
|
|
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
|
|
* street, Riga, Latvia, EU, LV-1050.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of the Program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU AGPL version 3.
|
|
*
|
|
* Pursuant to Section 7(b) of the License you must retain the original Product
|
|
* logo when distributing the program. Pursuant to Section 7(e) we decline to
|
|
* grant you any rights under trademark law for use of our trademarks.
|
|
*
|
|
* All the Product's GUI elements, including illustrations and icon sets, as
|
|
* well as technical writing content are licensed under the terms of the
|
|
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
|
|
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
|
*
|
|
*/
|
|
|
|
|
|
#include "SpTreeElem.h"
|
|
#include "Shape.h"
|
|
#include "Pic.h"
|
|
#include "CxnSp.h"
|
|
#include "SpTree.h"
|
|
#include "GraphicFrame.h"
|
|
#include "Effects/AlphaModFix.h"
|
|
|
|
#include "../SlideMaster.h"
|
|
|
|
#include "../../DocxFormat/Media/Audio.h"
|
|
#include "../../DocxFormat/Media/Video.h"
|
|
#include "../../DocxFormat/Media/ActiveX.h"
|
|
#include "../../DocxFormat/Logic/Pict.h"
|
|
|
|
namespace PPTX
|
|
{
|
|
namespace Logic
|
|
{
|
|
std::wstring GetHexColor(const DWORD& ARGB)
|
|
{
|
|
BYTE r = (BYTE)((ARGB >> 16) & 0xFF);
|
|
BYTE g = (BYTE)((ARGB >> 8) & 0xFF);
|
|
BYTE b = (BYTE)((ARGB & 0xFF));
|
|
|
|
std::wstringstream sstream;
|
|
sstream << boost::wformat(L"%02X%02X%02X") % r % g % b;
|
|
|
|
return L"#" + sstream.str();
|
|
}
|
|
|
|
void CalculateFill(BYTE lDocType, PPTX::Logic::SpPr& oSpPr, nullable<ShapeStyle>& pShapeStyle, NSCommon::smart_ptr<PPTX::Theme>& oTheme,
|
|
NSCommon::smart_ptr<PPTX::Logic::ClrMap>& oClrMap, std::wstring& strAttr, std::wstring& strNode, bool bOle, bool bSignature)
|
|
{
|
|
PPTX::Logic::UniFill fill;
|
|
DWORD ARGB = 0;
|
|
if (pShapeStyle.is_init() && oTheme.is_init())
|
|
{
|
|
oTheme->GetFillStyle(pShapeStyle->fillRef.idx.get_value_or(0), fill);
|
|
|
|
if (pShapeStyle->fillRef.Color.is_init())
|
|
{
|
|
if (fill.is<PPTX::Logic::SolidFill>())
|
|
{
|
|
fill.as<PPTX::Logic::SolidFill>().Color = pShapeStyle->fillRef.Color;
|
|
}
|
|
}
|
|
ARGB = pShapeStyle->fillRef.Color.GetRGBColor(oTheme, oClrMap, ARGB);
|
|
}
|
|
|
|
if (oSpPr.Fill.is_init())
|
|
oSpPr.Fill.Merge(fill);
|
|
|
|
if (fill.is<BlipFill>())
|
|
{
|
|
BlipFill& oBlip = fill.as<BlipFill>();
|
|
|
|
if (oBlip.blip.is_init() && oBlip.blip->embed.is_init())
|
|
{
|
|
std::wstring fopacity;
|
|
size_t eff_count = oBlip.blip->Effects.size();
|
|
for (size_t eff = 0; eff < eff_count; ++eff)
|
|
{
|
|
|
|
if (oBlip.blip->Effects[eff].is<PPTX::Logic::AlphaModFix>())
|
|
{
|
|
PPTX::Logic::AlphaModFix& oAlpha = oBlip.blip->Effects[eff].as<PPTX::Logic::AlphaModFix>();
|
|
if (oAlpha.amt.is_init())
|
|
{
|
|
double dA = (double)(oAlpha.amt.get());
|
|
dA = (dA * 65536 / 100000);
|
|
int nA = (int)(dA + 0.5);
|
|
|
|
if (nA < 0)
|
|
nA = 0;
|
|
if (nA > 65536)
|
|
nA = 65536;
|
|
|
|
fopacity = L" opacity=\"" + std::to_wstring(nA) + L"f\"";
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
std::wstring strId = oBlip.blip->embed->ToString();
|
|
if (XMLWRITER_DOC_TYPE_XLSX == lDocType)
|
|
{
|
|
strId = L"o:relid=\"" + strId + L"\"";
|
|
}
|
|
else
|
|
{
|
|
strId = L"r:id=\"" + strId + L"\"";
|
|
}
|
|
if (bOle || bSignature)
|
|
{
|
|
strAttr = L" filled=\"f\"";
|
|
strNode = L"<v:imagedata " + strId + L" o:title=\"\" />";
|
|
}
|
|
else
|
|
{
|
|
if (oBlip.tile.is_init())
|
|
strNode = L"<v:fill " + strId + L" o:title=\"\" type=\"tile\"" + fopacity + L"/>";
|
|
else
|
|
strNode = L"<v:fill " + strId + L" o:title=\"\" type=\"frame\"" + fopacity + L"/>";
|
|
}
|
|
}
|
|
}
|
|
else if (fill.is<SolidFill>())
|
|
{
|
|
ARGB = fill.as<SolidFill>().Color.GetRGBColor(oTheme, oClrMap, ARGB);
|
|
strAttr = L" fillcolor=\"" + GetHexColor(ARGB) + L"\"";
|
|
|
|
BYTE A = (BYTE)((ARGB >> 24) & 0xFF);
|
|
if (A != 255)
|
|
{
|
|
int fopacity = 100 - (int)(((double)A / 255.0) * 65536);
|
|
strNode = L"<v:fill opacity=\"" + std::to_wstring(fopacity) + L"f\" />";
|
|
}
|
|
}
|
|
else if (fill.is<GradFill>())
|
|
{
|
|
GradFill& oGrad = fill.as<GradFill>();
|
|
if (oGrad.GsLst.size() > 0)
|
|
{
|
|
ARGB = oGrad.GsLst[0].color.GetRGBColor(oTheme, oClrMap, ARGB);
|
|
strAttr = L" fillcolor=\"" + GetHexColor(ARGB) + L"\"";
|
|
|
|
BYTE A = (BYTE)((ARGB >> 24) & 0xFF);
|
|
if (A != 255)
|
|
{
|
|
int fopacity = 100 - (int)(((double)A / 255.0) * 65536);
|
|
strNode = L"<v:fill opacity=\"" + std::to_wstring(fopacity) + L"f\" />";
|
|
}
|
|
}
|
|
}
|
|
else if (fill.is<NoFill>() || !fill.is_init())
|
|
{
|
|
strAttr = L" filled=\"f\"";
|
|
}
|
|
else
|
|
{
|
|
strAttr = L" fillcolor=\"" + GetHexColor(ARGB) + L"\"";
|
|
|
|
BYTE A = (BYTE)((ARGB >> 24) & 0xFF);
|
|
if (A != 255)
|
|
{
|
|
int fopacity = (int)(((double)A / 255.0) * 65536);
|
|
strNode = L"<v:fill opacity=\"" + std::to_wstring(fopacity) + L"f\" />";
|
|
}
|
|
}
|
|
|
|
/*
|
|
BYTE alpha = (BYTE)((ARGB >> 24) & 0xFF);
|
|
if (alpha < 255)
|
|
{
|
|
std::wstring strA = = std::to_string( alpha);
|
|
strAttr += _T(" opacity=\"") + strA + _T("\"");
|
|
}
|
|
*/
|
|
}
|
|
void CalculateLine(BYTE lDocType, PPTX::Logic::SpPr& oSpPr, nullable<ShapeStyle>& pShapeStyle, NSCommon::smart_ptr<PPTX::Theme>& oTheme,
|
|
NSCommon::smart_ptr<PPTX::Logic::ClrMap>& oClrMap, std::wstring& strAttr, std::wstring& strNode, bool bOle)
|
|
{
|
|
PPTX::Logic::Ln line;
|
|
DWORD ARGB = 0;
|
|
if (pShapeStyle.is_init() && oTheme.is_init())
|
|
{
|
|
oTheme->GetLineStyle(pShapeStyle->lnRef.idx.get_value_or(0), line);
|
|
ARGB = pShapeStyle->lnRef.Color.GetRGBColor(oTheme, oClrMap, ARGB);
|
|
}
|
|
|
|
if (oSpPr.ln.is_init())
|
|
oSpPr.ln->Merge(line);
|
|
|
|
if (line.Fill.is<SolidFill>())
|
|
{
|
|
ARGB = line.Fill.as<SolidFill>().Color.GetRGBColor(oTheme, oClrMap, ARGB);
|
|
strAttr = L" strokecolor=\"" + GetHexColor(ARGB) + L"\"";
|
|
}
|
|
else if (line.Fill.is<NoFill>() || bOle)
|
|
strAttr = L" stroked=\"f\"";
|
|
|
|
if (line.w.is_init())
|
|
{
|
|
double dW = 72.0 * (*line.w) / (25.4 * 36000);
|
|
std::wstring s = L" strokeweight=\"" + XmlUtils::ToString(dW, L"%.2lf") + L"pt\"";
|
|
strAttr += s;
|
|
}
|
|
|
|
if (line.prstDash.IsInit() && line.prstDash->val.IsInit())
|
|
{
|
|
std::wstring value;
|
|
switch (line.prstDash->val->GetBYTECode())
|
|
{
|
|
case 0: value = L"dash"; break;
|
|
case 1: value = L"dashdot"; break;
|
|
case 2: value = L"dot"; break;
|
|
case 3: value = L"longdash"; break;
|
|
case 4: value = L"longdashdot"; break;
|
|
case 5: value = L"longdashdotdot"; break;
|
|
case 6: value = L"solid"; break;
|
|
case 7: value = L"shortdash"; break;
|
|
case 8: value = L"shortdashdot"; break;
|
|
case 9: value = L"shortdashdotdot"; break;
|
|
case 10: value = L"shortdot"; break;
|
|
default: value = L"solid"; break;
|
|
}
|
|
if (false == value.empty())
|
|
strNode = L"<v:stroke dashstyle=\"" + value + L"\"/>";
|
|
}
|
|
}
|
|
|
|
SpTreeElem::SpTreeElem()
|
|
{
|
|
}
|
|
OOX::EElementType SpTreeElem::getType () const
|
|
{
|
|
if (m_elem.IsInit())
|
|
return m_elem->getType();
|
|
return OOX::et_Unknown;
|
|
}
|
|
SpTreeElem::~SpTreeElem()
|
|
{
|
|
}
|
|
SpTreeElem::SpTreeElem(XmlUtils::CXmlNode& node)
|
|
{
|
|
fromXML(node);
|
|
}
|
|
const SpTreeElem& SpTreeElem::operator =(XmlUtils::CXmlNode& node)
|
|
{
|
|
fromXML(node);
|
|
return *this;
|
|
}
|
|
SpTreeElem& SpTreeElem::operator=(const SpTreeElem& oSrc)
|
|
{
|
|
m_elem = oSrc.m_elem;
|
|
return *this;
|
|
}
|
|
SpTreeElem::SpTreeElem(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
fromXML(oReader);
|
|
}
|
|
const SpTreeElem& SpTreeElem::operator =(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
fromXML(oReader);
|
|
return *this;
|
|
}
|
|
void SpTreeElem::fromXML(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
std::wstring name = XmlUtils::GetNameNoNS(oReader.GetName());
|
|
|
|
if (name == L"sp" || name == L"wsp")
|
|
m_elem.reset(new Logic::Shape(oReader));
|
|
else if (name == L"pic")
|
|
m_elem.reset(new Logic::Pic(oReader));
|
|
else if (name == L"cxnSp")
|
|
m_elem.reset(new Logic::CxnSp(oReader));
|
|
else if (name == L"lockedCanvas")
|
|
m_elem.reset(CreatePtrXmlContent<Logic::LockedCanvas>(oReader));
|
|
else if (name == L"grpSp" || name == L"wgp" || name == L"spTree" || name == L"wpc")
|
|
m_elem.reset(CreatePtrXmlContent<Logic::SpTree>(oReader));
|
|
else if (name == L"graphicFrame")
|
|
{
|
|
Logic::GraphicFrame *pGraphic = new Logic::GraphicFrame();
|
|
pGraphic->m_sRequires = m_sRequires;
|
|
pGraphic->fromXML(oReader);
|
|
|
|
if (pGraphic && pGraphic->IsEmpty() == false)
|
|
m_elem.reset(pGraphic);
|
|
else
|
|
RELEASEOBJECT(pGraphic);
|
|
}
|
|
else if (name == L"AlternateContent")
|
|
{
|
|
if ( oReader.IsEmptyNode() )
|
|
return;
|
|
int nCurDepth = oReader.GetDepth();
|
|
while( oReader.ReadNextSiblingNode( nCurDepth ) )
|
|
{
|
|
std::wstring strName = oReader.GetName();
|
|
|
|
if ( oReader.IsEmptyNode() )
|
|
continue;
|
|
|
|
if (strName == L"mc:Choice")
|
|
{
|
|
ReadAttributesRequires(oReader);
|
|
oReader.ReadNextSiblingNode(nCurDepth + 1);
|
|
|
|
fromXML(oReader);
|
|
|
|
m_sRequires = L"";
|
|
if (m_elem.is_init())
|
|
break;
|
|
}
|
|
else if (strName == L"mc:Fallback")
|
|
{
|
|
oReader.ReadNextSiblingNode(nCurDepth + 1);
|
|
fromXML(oReader);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
void SpTreeElem::fromXML(XmlUtils::CXmlNode& node)
|
|
{
|
|
std::wstring name = XmlUtils::GetNameNoNS(node.GetName());
|
|
|
|
if (name == L"sp" || name == L"wsp")
|
|
m_elem.reset(new Logic::Shape(node));
|
|
else if (name == L"pic")
|
|
m_elem.reset(new Logic::Pic(node));
|
|
else if (name == L"cxnSp")
|
|
m_elem.reset(new Logic::CxnSp(node));
|
|
else if (name == L"lockedCanvas")
|
|
m_elem.reset(CreatePtrXmlContent<Logic::LockedCanvas>(node));
|
|
else if (name == L"grpSp" || name == L"wgp" || name == L"spTree" || name == L"wpc")
|
|
m_elem.reset(CreatePtrXmlContent<Logic::SpTree>(node));
|
|
else if (name == L"graphicFrame")
|
|
{
|
|
m_elem.reset(new Logic::GraphicFrame(node));
|
|
|
|
Logic::GraphicFrame *graphic_frame = dynamic_cast<Logic::GraphicFrame*>(m_elem.GetPointer());
|
|
if (graphic_frame)
|
|
{
|
|
if (graphic_frame->IsEmpty())
|
|
m_elem.reset();
|
|
}
|
|
}
|
|
else if (name == L"AlternateContent")
|
|
{
|
|
bool isEmpty = true;
|
|
XmlUtils::CXmlNode oNodeChoice;
|
|
if (node.GetNode(L"mc:Choice", oNodeChoice))
|
|
{
|
|
XmlUtils::CXmlNode oNodeFall;
|
|
std::vector<XmlUtils::CXmlNode> oNodesC;
|
|
std::wstring sRequires;
|
|
//todo better check (a14 can be math, slicer)
|
|
if(oNodeChoice.GetAttributeIfExist(L"Requires", sRequires) && (L"a14" == sRequires || L"cx1" == sRequires))
|
|
{
|
|
oNodeChoice.GetNodes(L"*", oNodesC);
|
|
|
|
if (1 == oNodesC.size())
|
|
{
|
|
XmlUtils::CXmlNode & oNodeC = oNodesC[0];
|
|
|
|
fromXML(oNodeC);
|
|
|
|
isEmpty = (false == m_elem.IsInit());
|
|
}
|
|
}
|
|
if (isEmpty && node.GetNode(L"mc:Fallback", oNodeFall))
|
|
{
|
|
oNodeFall.GetNodes(L"*", oNodesC);
|
|
|
|
if (1 == oNodesC.size())
|
|
{
|
|
XmlUtils::CXmlNode & oNodeC = oNodesC[0];
|
|
|
|
fromXML(oNodeC);
|
|
isEmpty = false;
|
|
}
|
|
}
|
|
}
|
|
if(isEmpty)
|
|
{
|
|
m_elem.reset();
|
|
}
|
|
|
|
}
|
|
else if (name == L"binData")
|
|
{
|
|
m_binaryData = node;
|
|
}
|
|
else m_elem.reset();
|
|
}
|
|
void SpTreeElem::ReadAttributesRequires(XmlUtils::CXmlLiteReader& oReader)
|
|
{
|
|
WritingElement_ReadAttributes_Start( oReader )
|
|
WritingElement_ReadAttributes_ReadSingle ( oReader, _T("Requires"), m_sRequires )
|
|
WritingElement_ReadAttributes_End( oReader )
|
|
}
|
|
std::wstring SpTreeElem::GetUriElem()
|
|
{
|
|
if (m_elem.IsInit() == false)
|
|
{
|
|
return L"";
|
|
//return L"http://schemas.microsoft.com/office/word/2010/wordprocessingShape";
|
|
}
|
|
else if (m_elem->getType() == OOX::et_lc_LockedCanvas)
|
|
{
|
|
return L"http://schemas.openxmlformats.org/drawingml/2006/lockedCanvas";
|
|
}
|
|
else if (m_elem->getType() == OOX::et_p_ShapeTree)
|
|
{
|
|
return L"http://schemas.microsoft.com/office/word/2010/wordprocessingGroup";
|
|
}
|
|
else if (m_elem->getType() == OOX::et_pic)
|
|
{
|
|
return L"http://schemas.openxmlformats.org/drawingml/2006/picture";
|
|
}
|
|
else
|
|
{
|
|
return L"http://schemas.microsoft.com/office/word/2010/wordprocessingShape";
|
|
}
|
|
}
|
|
void SpTreeElem::fromPPTY(NSBinPptxRW::CBinaryFileReader* pReader)
|
|
{
|
|
BYTE _type = pReader->GetUChar();
|
|
|
|
switch (_type)
|
|
{
|
|
case SPTREE_TYPE_SHAPE:
|
|
{
|
|
Logic::Shape* p = new Logic::Shape();
|
|
p->fromPPTY(pReader);
|
|
m_elem.reset(p);
|
|
}break;
|
|
case SPTREE_TYPE_OLE:
|
|
case SPTREE_TYPE_PIC:
|
|
case SPTREE_TYPE_AUDIO:
|
|
case SPTREE_TYPE_VIDEO:
|
|
{
|
|
Logic::Pic* p = new Logic::Pic();
|
|
|
|
if (_type == SPTREE_TYPE_AUDIO)
|
|
{
|
|
OOX::Audio *pAudio = new OOX::Audio(NULL, pReader->m_nDocumentType == XMLWRITER_DOC_TYPE_DOCX);
|
|
p->blipFill.additionalFile = smart_ptr<OOX::File>(dynamic_cast<OOX::File*>(pAudio));
|
|
}
|
|
else if (_type == SPTREE_TYPE_VIDEO)
|
|
{
|
|
OOX::Video* pVideo = new OOX::Video(NULL, pReader->m_nDocumentType == XMLWRITER_DOC_TYPE_DOCX);
|
|
p->blipFill.additionalFile = smart_ptr<OOX::File>(dynamic_cast<OOX::File*>(pVideo));
|
|
}
|
|
|
|
p->fromPPTY(pReader);
|
|
m_elem.reset(p);
|
|
}break;
|
|
case SPTREE_TYPE_CXNSP:
|
|
{
|
|
Logic::CxnSp* p = new Logic::CxnSp();
|
|
p->fromPPTY(pReader);
|
|
m_elem.reset(p);
|
|
}break;
|
|
case SPTREE_TYPE_LOCKED_CANVAS:
|
|
{
|
|
Logic::LockedCanvas* p = new Logic::LockedCanvas();
|
|
pReader->Seek(pReader->GetPos() - 5); // type back + len
|
|
p->fromPPTY(pReader);
|
|
|
|
if (getType() == OOX::et_lc_LockedCanvas)
|
|
{
|
|
smart_ptr<PPTX::Logic::LockedCanvas> parent = GetElem().smart_dynamic_cast<PPTX::Logic::LockedCanvas>();
|
|
p->m_lGroupIndex = parent->m_lGroupIndex + 1;
|
|
}
|
|
m_elem.reset(p);
|
|
}break;
|
|
case SPTREE_TYPE_SPTREE:
|
|
{
|
|
Logic::SpTree* p = new Logic::SpTree();
|
|
pReader->Seek(pReader->GetPos() - 5); // type back + len
|
|
p->fromPPTY(pReader);
|
|
|
|
if (getType() == OOX::et_p_ShapeTree)
|
|
{
|
|
smart_ptr<PPTX::Logic::SpTree> parent = GetElem().smart_dynamic_cast<PPTX::Logic::SpTree>();
|
|
p->m_lGroupIndex = parent->m_lGroupIndex + 1;
|
|
}
|
|
m_elem.reset(p);
|
|
}break;
|
|
case SPTREE_TYPE_GRFRAME:
|
|
{
|
|
Logic::GraphicFrame* pFrame = new Logic::GraphicFrame();
|
|
pFrame->fromPPTY(pReader);
|
|
m_elem.reset(pFrame);
|
|
}break;
|
|
case SPTREE_TYPE_NONE:
|
|
default:
|
|
{
|
|
pReader->SkipRecord();
|
|
}break;
|
|
}
|
|
}
|
|
void SpTreeElem::toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
|
{
|
|
if (m_elem.is_init())
|
|
m_elem->toPPTY(pWriter);
|
|
}
|
|
void SpTreeElem::InitElem(WrapperWritingElement* pElem)
|
|
{
|
|
m_elem.reset(pElem);
|
|
}
|
|
std::wstring SpTreeElem::toXML() const
|
|
{
|
|
if (m_elem.IsInit())
|
|
return m_elem->toXML();
|
|
return L"";
|
|
}
|
|
void SpTreeElem::toXmlWriterVML (NSBinPptxRW::CXmlWriter* pWriter, smart_ptr<PPTX::Theme>& oTheme, smart_ptr<PPTX::Logic::ClrMap>& oClrMap) const
|
|
{
|
|
if (m_elem.IsInit() == false) return;
|
|
|
|
switch(m_elem->getType())
|
|
{
|
|
case OOX::et_a_Shape:
|
|
{
|
|
smart_ptr<PPTX::Logic::Shape> oShape = m_elem.smart_dynamic_cast<PPTX::Logic::Shape>();
|
|
if (oShape.IsInit()) oShape->toXmlWriterVML(pWriter, oTheme, oClrMap);
|
|
}break;
|
|
case OOX::et_pic:
|
|
{
|
|
smart_ptr<PPTX::Logic::Pic> oPic = m_elem.smart_dynamic_cast<PPTX::Logic::Pic>();
|
|
if (oPic.IsInit()) oPic->toXmlWriterVML(pWriter, oTheme, oClrMap);
|
|
}break;
|
|
case OOX::et_p_ShapeTree:
|
|
case OOX::et_lc_LockedCanvas:
|
|
{
|
|
smart_ptr<PPTX::Logic::SpTree> oSpTree = m_elem.smart_dynamic_cast<PPTX::Logic::SpTree>();
|
|
if (oSpTree.IsInit()) oSpTree->toXmlWriterVML(pWriter, oTheme, oClrMap);
|
|
}break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
void SpTreeElem::toXmlWriter(NSBinPptxRW::CXmlWriter* pWriter) const
|
|
{
|
|
if (m_elem.is_init())
|
|
m_elem->toXmlWriter(pWriter);
|
|
}
|
|
std::wstring SpTreeElem::GetSlicerRequires()
|
|
{
|
|
if (m_elem.IsInit() && m_elem.is<PPTX::Logic::GraphicFrame>())
|
|
{
|
|
PPTX::Logic::GraphicFrame& oGraphicFrame = m_elem.as<PPTX::Logic::GraphicFrame>();
|
|
if(oGraphicFrame.slicer.IsInit())
|
|
{
|
|
return L"a14";
|
|
}
|
|
else if(oGraphicFrame.slicerExt.IsInit())
|
|
{
|
|
return L"sle15";
|
|
}
|
|
}
|
|
return L"";
|
|
}
|
|
smart_ptr<WrapperWritingElement> SpTreeElem::GetElem()
|
|
{
|
|
return m_elem;
|
|
}
|
|
void SpTreeElem::SetParentPointer(const WrapperWritingElement* pParent)
|
|
{
|
|
if (is_init())
|
|
m_elem->SetParentPointer(pParent);
|
|
}
|
|
void SpTreeElem::FillParentPointersForChilds(){}
|
|
} // namespace Logic
|
|
} // namespace PPTX
|