mirror of
https://github.com/ONLYOFFICE/core.git
synced 2026-04-07 13:55:33 +08:00
PPTXFormat: Logic (root files)
PPTXFormatLib compiled(release/debug). x2t compiled.
This commit is contained in:
@ -29,6 +29,9 @@
|
||||
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
|
||||
*
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#ifndef PPTX_LOGIC_EXTP_PROPERTIES_INCLUDE_H_
|
||||
#define PPTX_LOGIC_EXTP_PROPERTIES_INCLUDE_H_
|
||||
|
||||
@ -98,165 +101,20 @@ namespace PPTX
|
||||
public:
|
||||
WritingElement_AdditionConstructors(Ext)
|
||||
|
||||
Ext()
|
||||
{
|
||||
}
|
||||
Ext();
|
||||
|
||||
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader)
|
||||
{
|
||||
ReadAttributes(oReader);
|
||||
|
||||
if ( oReader.IsEmptyNode() )
|
||||
return;
|
||||
|
||||
int nParentDepth = oReader.GetDepth();
|
||||
while( oReader.ReadNextSiblingNode( nParentDepth ) )
|
||||
{
|
||||
std::wstring strName = XmlUtils::GetNameNoNS(oReader.GetName());
|
||||
virtual void fromXML(XmlUtils::CXmlLiteReader& oReader);
|
||||
|
||||
if (strName == L"media")
|
||||
{
|
||||
ReadAttributes1(oReader);
|
||||
if ( oReader.IsEmptyNode() )
|
||||
continue;
|
||||
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader);
|
||||
void ReadAttributes1(XmlUtils::CXmlLiteReader& oReader);
|
||||
void ReadAttributes2(XmlUtils::CXmlLiteReader& oReader);
|
||||
void ReadAttributes3(XmlUtils::CXmlLiteReader& oReader);
|
||||
|
||||
int nParentDepth1 = oReader.GetDepth();
|
||||
while( oReader.ReadNextSiblingNode( nParentDepth1 ) )
|
||||
{
|
||||
std::wstring strName1 = XmlUtils::GetNameNoNS(oReader.GetName());
|
||||
virtual void fromXML(XmlUtils::CXmlNode& node);
|
||||
virtual std::wstring toXML() const;
|
||||
virtual void toXmlWriter(NSBinPptxRW::CXmlWriter* pWriter) const;
|
||||
virtual void toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const;
|
||||
|
||||
if (strName1 == L"trim")
|
||||
{
|
||||
ReadAttributes2(oReader);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (strName == L"compatExt")
|
||||
{
|
||||
ReadAttributes3(oReader);
|
||||
}
|
||||
}
|
||||
}
|
||||
void ReadAttributes(XmlUtils::CXmlLiteReader& oReader)
|
||||
{
|
||||
WritingElement_ReadAttributes_Start( oReader )
|
||||
WritingElement_ReadAttributes_ReadSingle ( oReader, L"uri", uri)
|
||||
WritingElement_ReadAttributes_End( oReader )
|
||||
}
|
||||
void ReadAttributes1(XmlUtils::CXmlLiteReader& oReader)
|
||||
{
|
||||
WritingElement_ReadAttributes_Start( oReader )
|
||||
WritingElement_ReadAttributes_ReadSingle( oReader, L"r:embed", link)
|
||||
WritingElement_ReadAttributes_End( oReader )
|
||||
}
|
||||
void ReadAttributes2(XmlUtils::CXmlLiteReader& oReader)
|
||||
{
|
||||
WritingElement_ReadAttributes_Start( oReader )
|
||||
WritingElement_ReadAttributes_Read_if ( oReader, L"st", st)
|
||||
WritingElement_ReadAttributes_Read_else_if ( oReader, L"end", end)
|
||||
WritingElement_ReadAttributes_End( oReader )
|
||||
}
|
||||
void ReadAttributes3(XmlUtils::CXmlLiteReader& oReader)
|
||||
{
|
||||
WritingElement_ReadAttributes_Start( oReader );
|
||||
WritingElement_ReadAttributes_ReadSingle ( oReader, L"spid", spid)
|
||||
WritingElement_ReadAttributes_End( oReader )
|
||||
}
|
||||
virtual void fromXML(XmlUtils::CXmlNode& node)
|
||||
{
|
||||
XmlUtils::CXmlNodes oNodes;
|
||||
if (node.GetNodes(L"*", oNodes))
|
||||
{
|
||||
int nCount = oNodes.GetCount();
|
||||
for (int i = 0; i < nCount; ++i)
|
||||
{
|
||||
XmlUtils::CXmlNode oNode;
|
||||
oNodes.GetAt(i, oNode);
|
||||
|
||||
std::wstring strName = XmlUtils::GetNameNoNS(oNode.GetName());
|
||||
|
||||
if (L"media" == strName)
|
||||
{
|
||||
link = oNode.GetAttribute(L"r:embed");
|
||||
|
||||
XmlUtils::CXmlNode trim = oNode.ReadNodeNoNS(L"trim");
|
||||
if (trim.IsValid())
|
||||
{
|
||||
XmlMacroReadAttributeBase(trim, L"st", st);
|
||||
XmlMacroReadAttributeBase(trim, L"end", end);
|
||||
}
|
||||
}
|
||||
else if (L"compatExt" == strName)
|
||||
{
|
||||
spid = oNode.GetAttribute(L"spid");
|
||||
}
|
||||
else if (L"sectionLst" == strName)
|
||||
{
|
||||
sectionLst = oNode;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
virtual std::wstring toXML() const
|
||||
{
|
||||
XmlUtils::CAttribute oAttr;
|
||||
XmlUtils::CNodeValue oValue;
|
||||
|
||||
return XmlUtils::CreateNode(L"p:ext", oValue);
|
||||
}
|
||||
|
||||
virtual void toXmlWriter(NSBinPptxRW::CXmlWriter* pWriter) const
|
||||
{
|
||||
std::wstring namespace_ext = L"p";
|
||||
if (pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX ||
|
||||
pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX_GLOSSARY ||
|
||||
pWriter->m_lDocType == XMLWRITER_DOC_TYPE_XLSX) namespace_ext= L"a";
|
||||
|
||||
if (link.IsInit())
|
||||
{
|
||||
std::wstring namespace_link = L"p14";
|
||||
if (pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX ||
|
||||
pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX_GLOSSARY) namespace_link= L"wp15";
|
||||
|
||||
pWriter->StartNode(namespace_ext + L":ext");
|
||||
pWriter->StartAttributes();
|
||||
pWriter->WriteAttribute(L"uri", std::wstring(L"{DAA4B4D4-6D71-4841-9C94-3DE7FCFB9230}"));
|
||||
pWriter->EndAttributes();
|
||||
|
||||
pWriter->StartNode(namespace_link + L":media");
|
||||
pWriter->StartAttributes();
|
||||
if (pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX ||
|
||||
pWriter->m_lDocType == XMLWRITER_DOC_TYPE_DOCX_GLOSSARY)
|
||||
pWriter->WriteAttribute(L"xmlns:wp15", std::wstring(L"http://schemas.microsoft.com/office/word/2012/wordprocessingDrawing"));
|
||||
else
|
||||
pWriter->WriteAttribute(L"xmlns:p14", std::wstring(L"http://schemas.microsoft.com/office/powerpoint/2010/main"));
|
||||
pWriter->WriteAttribute(L"r:embed", link->get());
|
||||
pWriter->EndAttributes();
|
||||
pWriter->EndNode(namespace_link + L":media");
|
||||
pWriter->EndNode(namespace_ext + L":ext");
|
||||
}
|
||||
if (sectionLst.IsInit())
|
||||
{
|
||||
pWriter->StartNode(namespace_ext + L":ext");
|
||||
pWriter->StartAttributes();
|
||||
pWriter->WriteAttribute(L"uri", std::wstring(L"{521415D9-36F7-43E2-AB2F-B90AF26B5E84}"));
|
||||
pWriter->EndAttributes();
|
||||
|
||||
sectionLst->toXmlWriter(pWriter);
|
||||
pWriter->EndNode(namespace_ext + L":ext");
|
||||
}
|
||||
}
|
||||
|
||||
virtual void toPPTY(NSBinPptxRW::CBinaryFileWriter* pWriter) const
|
||||
{
|
||||
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeStart);
|
||||
if (link.IsInit())
|
||||
link->toPPTY(0, pWriter);
|
||||
pWriter->WriteDouble2(1, st);
|
||||
pWriter->WriteDouble2(2, end);
|
||||
pWriter->WriteBYTE(NSBinPptxRW::g_nodeAttributeEnd);
|
||||
}
|
||||
//-------------------------------------------------------
|
||||
nullable_string uri;
|
||||
//media
|
||||
@ -271,10 +129,7 @@ namespace PPTX
|
||||
//table
|
||||
//sparklineGroups
|
||||
protected:
|
||||
virtual void FillParentPointersForChilds()
|
||||
{
|
||||
|
||||
}
|
||||
virtual void FillParentPointersForChilds();
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user