3008 lines
107 KiB
C++
3008 lines
107 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 <boost/make_shared.hpp>
|
||
|
||
#include "PPTDocumentInfo.h"
|
||
|
||
#include "../Records/RecordsIncluder.h"
|
||
|
||
//#include "../Records/ExObjListContainer.h"
|
||
//#include "../Records/SoundCollectionContainer.h"
|
||
//#include "../Records/SoundContainer.h"
|
||
#include "../Enums/_includer.h"
|
||
|
||
using namespace PPT;
|
||
using namespace ODRAW;
|
||
|
||
CPPTUserInfo::CPPTUserInfo() : CDocument(),
|
||
m_oUser(),
|
||
m_mapOffsetInPIDs(),
|
||
m_oDocument(),
|
||
m_mapMasters(),
|
||
m_mapNotes(),
|
||
m_mapSlides(),
|
||
m_bEncrypt(false),
|
||
m_pStorageDecrypt(NULL),
|
||
m_pDecryptor(NULL),
|
||
m_arOffsetPictures()
|
||
{
|
||
m_pDocumentInfo = NULL;
|
||
m_lIndexThisUser = -1;
|
||
|
||
m_pNotesMasterWrapper = NULL;
|
||
m_pHandoutMasterWrapper = NULL;
|
||
|
||
m_nWriteSlideTimeOffset = 0.0;
|
||
m_nWriteSlideTime = 0.0;
|
||
|
||
m_bIsSetupEmpty = false;
|
||
|
||
m_bRtl = false;
|
||
m_bShowComments = false;
|
||
|
||
m_bHasDate = false;
|
||
m_bHasSlideNumber = false;
|
||
m_bHasFooter = false;
|
||
m_nFormatDate = 1;
|
||
|
||
m_current_elements = NULL;
|
||
m_current_level = 0;
|
||
}
|
||
|
||
CPPTUserInfo::~CPPTUserInfo()
|
||
{
|
||
Clear();
|
||
}
|
||
|
||
void CPPTUserInfo::Clear()
|
||
{
|
||
CDocument::Clear();
|
||
|
||
RELEASEOBJECT(m_pDecryptor);
|
||
RELEASEOBJECT(m_pStorageDecrypt);
|
||
|
||
for (std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapSlides.begin(); pPair != m_mapSlides.end(); ++pPair)
|
||
{
|
||
RELEASEINTERFACE(pPair->second);
|
||
}
|
||
m_mapSlides.clear();
|
||
m_arrSlidesOrder.clear();
|
||
|
||
for (std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapMasters.begin(); pPair != m_mapMasters.end(); ++pPair)
|
||
{
|
||
RELEASEINTERFACE(pPair->second);
|
||
}
|
||
m_mapMasters.clear();
|
||
m_arrMastersOrder.clear();
|
||
|
||
for (std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapNotesMasters.begin(); pPair != m_mapNotesMasters.end(); ++pPair)
|
||
{
|
||
RELEASEINTERFACE(pPair->second);
|
||
}
|
||
m_mapNotesMasters.clear();
|
||
|
||
for (std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapHandoutMasters.begin(); pPair != m_mapHandoutMasters.end(); ++pPair)
|
||
{
|
||
RELEASEINTERFACE(pPair->second);
|
||
}
|
||
m_mapHandoutMasters.clear();
|
||
|
||
RELEASEOBJECT(m_pNotesMasterWrapper);
|
||
RELEASEOBJECT(m_pHandoutMasterWrapper);
|
||
|
||
for (std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapNotes.begin(); pPair != m_mapNotes.end(); ++pPair)
|
||
{
|
||
RELEASEINTERFACE(pPair->second);
|
||
}
|
||
m_mapNotes.clear();
|
||
m_arrNotesOrder.clear();
|
||
|
||
m_oExMedia.Clear();
|
||
m_arrFonts.clear();
|
||
|
||
// for (size_t nIndex = 0; nIndex < m_mapAnimations.size(); ++nIndex)
|
||
// {
|
||
// RELEASEOBJECT ( m_mapAnimations[nIndex]);
|
||
// }
|
||
|
||
// m_mapAnimations.clear();
|
||
m_mapTransitions.clear();
|
||
m_arOffsetPictures.clear();
|
||
}
|
||
|
||
bool CPPTUserInfo::ReadFromStream(CRecordUserEditAtom* pUser, POLE::Stream* pStream)
|
||
{
|
||
m_oUser.FromAtom(pUser);
|
||
|
||
//--------------------------------------------------------------------------------------------------
|
||
SRecordHeader oHeader;
|
||
CRecordUserEditAtom oUserAtom;
|
||
|
||
StreamUtils::StreamSeek(m_oUser.m_nOffsetPersistDirectory, pStream);
|
||
|
||
oHeader.ReadFromStream(pStream);
|
||
|
||
if (RT_PersistDirectoryAtom != oHeader.RecType)
|
||
{
|
||
return false;
|
||
}
|
||
|
||
CRecordPersistDirectoryAtom oPersist;
|
||
oPersist.m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
oPersist.ReadFromStream(oHeader, pStream);
|
||
oPersist.ToMap(&m_mapOffsetInPIDs);
|
||
//--------------------------------------------------------------------------------------------------
|
||
std::map<_UINT32, _UINT32>::iterator pPair = m_mapOffsetInPIDs.find(m_oUser.m_nEncryptRef);
|
||
|
||
if (pPair != m_mapOffsetInPIDs.end())
|
||
{
|
||
StreamUtils::StreamSeek(pPair->second, pStream);
|
||
oHeader.ReadFromStream(pStream);
|
||
|
||
if (RT_CryptSession10Container == oHeader.RecType)
|
||
{
|
||
m_bEncrypt = true;
|
||
m_oEncryptionHeader.ReadFromStream(oHeader, pStream);
|
||
|
||
m_pDecryptor = new CRYPT::ECMADecryptor();
|
||
m_pDecryptor->SetCryptData(m_oEncryptionHeader.crypt_data_aes);
|
||
|
||
if (m_strPassword.empty())
|
||
{
|
||
if (m_pDecryptor->SetPassword(L"VelvetSweatshop") == false)
|
||
return false;
|
||
}
|
||
else if (m_pDecryptor->SetPassword(m_strPassword) == false)
|
||
{
|
||
return false;
|
||
}
|
||
std::wstring sTemp = m_pDocumentInfo->m_pCommonInfo->tempPath + FILE_SEPARATOR_STR + L"~tempFile.ppt";
|
||
|
||
m_pStorageDecrypt = new POLE::Storage(sTemp.c_str());
|
||
m_pStorageDecrypt->open(true, true);
|
||
}
|
||
}
|
||
|
||
ReadDocumentPersists(pStream);
|
||
return true;
|
||
}
|
||
|
||
void CPPTUserInfo::DecryptStream(POLE::Stream* pStream, int block)
|
||
{
|
||
long size = long(pStream->size() - pStream->tell());
|
||
|
||
POLE::Stream* pStreamTmp = new POLE::Stream(m_pStorageDecrypt, L"Tmp" + std::to_wstring(m_arStreamDecrypt.size() + 1), true, size);
|
||
unsigned char* data_stream = new unsigned char[size];
|
||
|
||
pStream->read(data_stream, size);
|
||
m_pDecryptor->Decrypt((char*)data_stream, size, block);
|
||
pStreamTmp->write(data_stream, size);
|
||
pStreamTmp->flush();
|
||
pStreamTmp->seek(0);
|
||
|
||
m_arStreamDecrypt.push_back(XLS::CFStreamPtr(new XLS::CFStream(pStreamTmp)));
|
||
}
|
||
|
||
bool CPPTUserInfo::ReadDocumentPersists(POLE::Stream* pStream)
|
||
{
|
||
SRecordHeader oHeader;
|
||
std::map<_UINT32, _UINT32>::iterator pPair = m_mapOffsetInPIDs.find(m_oUser.m_nDocumentRef);
|
||
|
||
if (pPair == m_mapOffsetInPIDs.end())
|
||
return false;
|
||
|
||
_UINT32 offset_stream = pPair->second;
|
||
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, m_oUser.m_nDocumentRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
if (RT_Document != oHeader.RecType)
|
||
{
|
||
return false;
|
||
}
|
||
m_oDocument.m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
m_oDocument.ReadFromStream(oHeader, pStreamTmp);
|
||
|
||
std::map<_UINT32, _UINT32>::iterator nIndexPsrRef;
|
||
|
||
for (size_t index = 0; index < m_oDocument.m_arMasterPersists.size(); ++index)
|
||
{
|
||
nIndexPsrRef = m_mapOffsetInPIDs.find(m_oDocument.m_arMasterPersists[index].m_nPsrRef);
|
||
|
||
if (nIndexPsrRef != m_mapOffsetInPIDs.end())
|
||
{
|
||
offset_stream = nIndexPsrRef->second;
|
||
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, m_oDocument.m_arMasterPersists[index].m_nPsrRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
|
||
CRecordSlide* pSlide = new CRecordSlide();
|
||
pSlide->m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
pSlide->ReadFromStream(oHeader, pStreamTmp);
|
||
pSlide->m_oPersist = m_oDocument.m_arMasterPersists[index];
|
||
|
||
pSlide->m_Index = m_mapMasters.size();
|
||
m_mapMasters.insert(m_mapMasters.end(), std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arMasterPersists[index].m_nSlideID, pSlide));
|
||
pSlide = NULL;
|
||
}
|
||
else
|
||
{
|
||
m_mapMasters.insert(m_mapMasters.end(), std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arMasterPersists[index].m_nSlideID, NULL));
|
||
}
|
||
m_arrMastersOrder.push_back(m_oDocument.m_arMasterPersists[index].m_nSlideID);
|
||
}
|
||
for (size_t index = 0; index < m_oDocument.m_arNotePersists.size(); ++index)
|
||
{
|
||
nIndexPsrRef = m_mapOffsetInPIDs.find(m_oDocument.m_arNotePersists[index].m_nPsrRef);
|
||
|
||
if (m_mapOffsetInPIDs.end() != nIndexPsrRef)
|
||
{
|
||
offset_stream = nIndexPsrRef->second;
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, m_oDocument.m_arNotePersists[index].m_nPsrRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
|
||
CRecordSlide* pSlide = new CRecordSlide();
|
||
pSlide->m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
pSlide->ReadFromStream(oHeader, pStreamTmp);
|
||
pSlide->m_oPersist = m_oDocument.m_arNotePersists[index];
|
||
|
||
pSlide->m_Index = m_mapNotes.size();
|
||
m_mapNotes.insert(std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arNotePersists[index].m_nSlideID, pSlide));
|
||
pSlide = NULL;
|
||
}
|
||
else
|
||
{
|
||
m_mapNotes.insert(std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arNotePersists[index].m_nSlideID, NULL));
|
||
}
|
||
m_arrNotesOrder.push_back(m_oDocument.m_arNotePersists[index].m_nSlideID);
|
||
}
|
||
|
||
for (size_t index = 0; index < m_oDocument.m_arSlidePersists.size(); ++index)
|
||
{
|
||
nIndexPsrRef = m_mapOffsetInPIDs.find(m_oDocument.m_arSlidePersists[index].m_nPsrRef);
|
||
|
||
if (m_mapOffsetInPIDs.end() != nIndexPsrRef)
|
||
{
|
||
offset_stream = (long)nIndexPsrRef->second;
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, m_oDocument.m_arSlidePersists[index].m_nPsrRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
|
||
CRecordSlide* pSlide = new CRecordSlide();
|
||
pSlide->m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
pSlide->ReadFromStream(oHeader, pStreamTmp);
|
||
pSlide->m_oPersist = m_oDocument.m_arSlidePersists[index];
|
||
|
||
pSlide->m_Index = m_mapSlides.size(); // in m_arrSlidesOrder
|
||
|
||
m_mapSlides.insert(std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arSlidePersists[index].m_nSlideID, pSlide));
|
||
|
||
if (pSlide->m_bExistsTransition)
|
||
{
|
||
m_mapTransitions.insert(std::pair<_UINT32, CSlideShowSlideInfoAtom>((_UINT32)index, pSlide->m_oSlideShowSlideInfoAtom));
|
||
}
|
||
|
||
if (pSlide->m_pSlideProgTagsContainer)
|
||
{
|
||
// Animations::CSlideTimeLine* pEffects = pSlide->m_pSlideProgTagsContainer->GetTimeLine ();
|
||
// if (pEffects)
|
||
// {
|
||
// m_mapAnimations.insert(std::pair<_UINT32, Animations::CSlideTimeLine*>((_UINT32)index, pEffects));
|
||
// }
|
||
}
|
||
}
|
||
else
|
||
{
|
||
m_mapSlides.insert(std::pair<_UINT32, CRecordSlide*>(m_oDocument.m_arSlidePersists[index].m_nSlideID, NULL));
|
||
}
|
||
m_arrSlidesOrder.push_back(m_oDocument.m_arSlidePersists[index].m_nSlideID);
|
||
}
|
||
std::vector<CRecordDocumentAtom*> oArrayDoc;
|
||
m_oDocument.GetRecordsByType(&oArrayDoc, true, true);
|
||
|
||
if (!oArrayDoc.empty())
|
||
{
|
||
nIndexPsrRef = m_mapOffsetInPIDs.find(oArrayDoc[0]->m_nNotesMasterPersistIDRef);
|
||
|
||
if (m_mapOffsetInPIDs.end() != nIndexPsrRef)
|
||
{
|
||
offset_stream = nIndexPsrRef->second;
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, oArrayDoc[0]->m_nNotesMasterPersistIDRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
|
||
CRecordSlide* pSlide = new CRecordSlide();
|
||
pSlide->m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
pSlide->ReadFromStream(oHeader, pStreamTmp);
|
||
pSlide->m_oPersist.m_nPsrRef = oArrayDoc[0]->m_nNotesMasterPersistIDRef;
|
||
pSlide->m_Index = 0;
|
||
|
||
m_mapNotesMasters.insert(std::pair<_UINT32, CRecordSlide*>(0, pSlide));
|
||
}
|
||
nIndexPsrRef = m_mapOffsetInPIDs.find(oArrayDoc[0]->m_nHandoutMasterPersistIDRef);
|
||
|
||
if (m_mapOffsetInPIDs.end() != nIndexPsrRef)
|
||
{
|
||
offset_stream = nIndexPsrRef->second;
|
||
StreamUtils::StreamSeek(offset_stream, pStream);
|
||
|
||
POLE::Stream* pStreamTmp = pStream;
|
||
if (m_pDecryptor)
|
||
{
|
||
DecryptStream(pStream, oArrayDoc[0]->m_nHandoutMasterPersistIDRef);
|
||
pStreamTmp = m_arStreamDecrypt.back()->stream_;
|
||
}
|
||
oHeader.ReadFromStream(pStreamTmp);
|
||
|
||
CRecordSlide* pSlide = new CRecordSlide();
|
||
pSlide->m_pCommonInfo = m_pDocumentInfo->m_pCommonInfo;
|
||
|
||
pSlide->ReadFromStream(oHeader, pStreamTmp);
|
||
pSlide->m_oPersist.m_nPsrRef = oArrayDoc[0]->m_nHandoutMasterPersistIDRef;
|
||
pSlide->m_Index = 0;
|
||
|
||
m_mapHandoutMasters.insert(std::pair<_UINT32, CRecordSlide*>(0, pSlide));
|
||
}
|
||
}
|
||
|
||
return true;
|
||
}
|
||
//--------------------------------------------------------------------------------------------
|
||
void CPPTUserInfo::ReadExtenalObjects()
|
||
{
|
||
// так... теперь берем всю инфу о ExObject -----------------------------
|
||
m_oExMedia.m_strPresentationDirectory = m_pDocumentInfo->m_pCommonInfo->tempPath;
|
||
|
||
PPT::CExFilesInfo oInfo;
|
||
|
||
oInfo.m_strFilePath = m_oExMedia.m_strPresentationDirectory;
|
||
oInfo.m_dwID = 0xFFFFFFFF;
|
||
m_oExMedia.m_arImages.push_back(oInfo);
|
||
|
||
// читаем все внешние объекты
|
||
std::vector<CRecordExObjListContainer*> oArrayExObjects;
|
||
m_oDocument.GetRecordsByType(&oArrayExObjects, false, true);
|
||
|
||
if (!oArrayExObjects.empty())
|
||
{
|
||
LoadExternal(oArrayExObjects[0]);
|
||
}
|
||
else
|
||
{
|
||
// прочитать все равно надо, так как там может быть
|
||
// транзишн
|
||
LoadExternal(NULL);
|
||
}
|
||
|
||
// -------------------------------------------------------------------
|
||
|
||
// а теперь заберем всю информацию о шрифтах
|
||
std::vector<CRecordFontEntityAtom*> oArrayFonts;
|
||
m_oDocument.GetRecordsByType(&oArrayFonts, true);
|
||
|
||
for (size_t nIndex = 0; nIndex < oArrayFonts.size(); ++nIndex)
|
||
{
|
||
CFontProperty oFont;
|
||
|
||
oFont.Name = oArrayFonts[nIndex]->m_strFaceName;
|
||
oFont.Charset = oArrayFonts[nIndex]->m_lfCharSet;
|
||
oFont.PitchFamily = oArrayFonts[nIndex]->m_lfPitchAndFamily;
|
||
|
||
m_arrFonts.push_back(oFont);
|
||
}
|
||
m_oDocument.GetRecordsByType(&m_arrBlipStore, true, true);
|
||
if (0 < m_arrBlipStore.size())
|
||
{
|
||
m_bIsSetupEmpty = TRUE;
|
||
m_arrBlipStore[0]->SetUpPicturesInfos(&m_arOffsetPictures);
|
||
}
|
||
|
||
if (m_bMacroEnabled)
|
||
{
|
||
m_bMacroEnabled = false;
|
||
std::vector<CRecordDocInfoListContainer*> oArrayDocInfo;
|
||
m_oDocument.GetRecordsByType(&oArrayDocInfo, true, true);
|
||
|
||
CRecordVBAInfoAtom* pVbaAtom = nullptr;
|
||
if (!oArrayDocInfo.empty())
|
||
pVbaAtom = oArrayDocInfo[0]->getVBAInfoAtom();
|
||
|
||
if (pVbaAtom)
|
||
{
|
||
if (pVbaAtom->m_nHasMacros)
|
||
{
|
||
m_sVbaProjectFile = m_pDocumentInfo->GetBinFromStg(L"vbaProject.bin", pVbaAtom->m_nObjStgDataRef);
|
||
|
||
m_bMacroEnabled = (false == m_sVbaProjectFile.empty());
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::FromDocument()
|
||
{
|
||
m_arSlides.clear();
|
||
|
||
std::vector<CRecordDocumentAtom*> oArrayDoc;
|
||
m_oDocument.GetRecordsByType(&oArrayDoc, true, true);
|
||
|
||
if (0 == oArrayDoc.size())
|
||
return;
|
||
|
||
std::vector<CRecordDocumentTextInfo*> oArrayInfo;
|
||
m_oDocument.GetRecordsByType(&oArrayInfo, false, true);
|
||
|
||
if (0 != oArrayInfo.size())
|
||
{
|
||
std::vector<CRecordTextMasterStyleAtom*> oStyles;
|
||
oArrayInfo[0]->GetRecordsByType(&oStyles, false, false);
|
||
|
||
if (0 != oStyles.size())
|
||
m_oDefaultTextStyle.SetStyles((PPT::CTextStyles*)oStyles[0]);
|
||
|
||
std::vector<CRecordTextSIExceptionAtom*> oSI;
|
||
oArrayInfo[0]->GetRecordsByType(&oSI, false, false);
|
||
|
||
if (0 != oSI.size())
|
||
{
|
||
if (oSI[0]->m_oSIRun.bLang)
|
||
m_wLanguage = oSI[0]->m_oSIRun.Lang;
|
||
|
||
m_oDefaultTextStyle.SetLanguage(m_wLanguage);
|
||
}
|
||
}
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
m_oDocument.GetRecordsByType(&oArrayHeadersFootersInfo, false, false);
|
||
|
||
if (0 != oArrayHeadersFootersInfo.size())
|
||
{
|
||
for (int i = 0; i < 3; i++)
|
||
{
|
||
m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
m_bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate/* ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate*/;
|
||
m_bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
m_bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) m_nFormatDate = 2;
|
||
}
|
||
}
|
||
|
||
double master_to_emu = 1. / 576.;//inch
|
||
|
||
master_to_emu *= 72;//pt
|
||
master_to_emu *= 12700;//emu
|
||
|
||
m_lSlideWidth = (oArrayDoc[0]->m_oSlideSize.X * 1587.5 + 0.5);
|
||
m_lSlideHeight = (oArrayDoc[0]->m_oSlideSize.Y * 1587.5 + 0.5);
|
||
|
||
m_lNotesWidth = (oArrayDoc[0]->m_oNotesSize.X * 1587.5 + 0.5);
|
||
m_lNotesHeight = (oArrayDoc[0]->m_oNotesSize.Y * 1587.5 + 0.5);
|
||
|
||
m_bRtl = (oArrayDoc[0]->m_bRightToLeft != 0);
|
||
m_bShowComments = (oArrayDoc[0]->m_bShowComments != 0);
|
||
|
||
for (size_t i = 0; i < m_arrSlidesOrder.size(); i++)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapSlides.find(m_arrSlidesOrder[i]);
|
||
|
||
if (pPair == m_mapSlides.end())
|
||
continue;
|
||
|
||
LoadSlideFromPrevUsers(pPair->first);
|
||
|
||
TestSlide(pPair->first);
|
||
}
|
||
|
||
LoadMasters();
|
||
|
||
double DurationSlide = PPT_DEFAULT_SLIDE_DURATION;
|
||
|
||
m_arSlides.reserve(m_arrSlidesOrder.size());
|
||
for (size_t i = 0; i < m_arrSlidesOrder.size(); i++)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapSlides.find(m_arrSlidesOrder[i]);
|
||
|
||
if (pPair == m_mapSlides.end())
|
||
continue;
|
||
|
||
LoadSlideFromPrevUsers(pPair->first);
|
||
|
||
DurationSlide = PPT_DEFAULT_SLIDE_DURATION;
|
||
|
||
m_arSlides.push_back(new CSlide());
|
||
|
||
// если на слайде есть анимации
|
||
// std::map <_UINT32, Animations::CSlideTimeLine*>::iterator pTimeLine = m_mapAnimations.find( pPair->first);
|
||
|
||
// if ( m_mapAnimations.end() != pTimeLine )
|
||
// {
|
||
// if ( (pTimeLine->second) && (0.0 != pTimeLine->second->GetTime () ))
|
||
// {
|
||
// DurationSlide = pTimeLine->second->GetTime ();
|
||
// }
|
||
// }
|
||
|
||
CSlide* pSlide = m_arSlides.back();
|
||
|
||
pSlide->m_dStartTime = 0.0;
|
||
pSlide->m_dEndTime = DurationSlide;
|
||
pSlide->m_dDuration = DurationSlide;
|
||
|
||
pSlide->m_lSlideID = pPair->first;
|
||
|
||
LoadSlide(pPair->first, pSlide);
|
||
}
|
||
|
||
m_arNotes.reserve(m_arrNotesOrder.size());
|
||
for (size_t i = 0; i < m_arrNotesOrder.size(); i++)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapNotes.find(m_arrNotesOrder[i]);
|
||
|
||
if (pPair == m_mapNotes.end())
|
||
continue;
|
||
|
||
LoadNotesFromPrevUsers(pPair->first);
|
||
|
||
DurationSlide = PPT_DEFAULT_SLIDE_DURATION;
|
||
|
||
m_arNotes.push_back(new CSlide());
|
||
|
||
CSlide* pSlide = m_arNotes.back();
|
||
|
||
LoadNotes(pPair->first, pSlide);
|
||
}
|
||
|
||
CalculateEditor();
|
||
}
|
||
|
||
void CPPTUserInfo::LoadNotes(_UINT32 dwNoteID, CSlide* pNotes)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairNotes = m_mapNotes.find(dwNoteID);
|
||
|
||
if (pPairNotes == m_mapNotes.end()) return;
|
||
|
||
CRecordSlide* pRecordSlide = pPairNotes->second;
|
||
|
||
if (NULL == pRecordSlide) return;
|
||
|
||
pNotes->m_bUseLayoutColorScheme = true;
|
||
|
||
CSlideInfo slide_info;
|
||
m_arNotesWrapper.push_back(slide_info);
|
||
|
||
CSlideInfo* pNotesWrapper = &m_arNotesWrapper.back();
|
||
|
||
int indexUser = pRecordSlide->m_IndexUser;
|
||
|
||
if (m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures.empty())
|
||
pNotesWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[0]->m_arOffsetPictures;
|
||
else
|
||
pNotesWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures;
|
||
|
||
pNotesWrapper->m_mapFilePictures = &m_pDocumentInfo->m_mapStoreImageFile;
|
||
// pNotesWrapper->m_arTextPlaceHolders = pRecordSlide->m_oPersist.m_arTextAttrs;
|
||
pNotesWrapper->m_arTextPlaceHolders.clear();
|
||
for (auto* pTextAttr : pRecordSlide->m_oPersist.m_arTextAttrs)
|
||
if (pTextAttr)
|
||
pNotesWrapper->m_arTextPlaceHolders.push_back(*pTextAttr);
|
||
|
||
|
||
std::vector<CRecordNotesAtom*> oArrayNotesAtoms;
|
||
pRecordSlide->GetRecordsByType(&oArrayNotesAtoms, false, true);
|
||
if (0 == oArrayNotesAtoms.size())
|
||
{
|
||
// ошибка!!!
|
||
return;
|
||
}
|
||
bool bMasterColorScheme = oArrayNotesAtoms[0]->m_bMasterScheme;
|
||
bool bMasterBackGround = oArrayNotesAtoms[0]->m_bMasterBackground;
|
||
bool bMasterObjects = oArrayNotesAtoms[0]->m_bMasterObjects;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairSlide = m_mapSlides.find(oArrayNotesAtoms[0]->m_nSlideIDRef);
|
||
|
||
if (pPairSlide == m_mapSlides.end())
|
||
{
|
||
//????? у заметок нет слайда !!!
|
||
}
|
||
//-----------------------------------------------------
|
||
size_t index = pPairSlide->second->m_Index;
|
||
if (index >= m_arSlides.size())
|
||
return;
|
||
CSlide* pSlide = m_arSlides[pPairSlide->second->m_Index];
|
||
|
||
pNotes->m_lSlideID = pPairSlide->second->m_Index;
|
||
pSlide->m_lNotesID = m_arNotes.size() - 1;
|
||
//-----------------------------------------------------
|
||
|
||
CTheme* pTheme = m_pNotesMaster.get();
|
||
CSlideInfo* pThemeWrapper = m_pNotesMasterWrapper;
|
||
|
||
CLayout* pLayout = NULL;
|
||
//-----------------------------------------------------
|
||
std::vector<ODRAW::CColor>* pArrayColorScheme = pTheme ? &pTheme->m_arColorScheme : NULL;
|
||
|
||
// читаем цветовую схему -----------------------------------------------------------
|
||
pNotes->m_bUseLayoutColorScheme = true;
|
||
if (!bMasterColorScheme)
|
||
{
|
||
std::vector<CRecordColorSchemeAtom*> oArrayColors;
|
||
pRecordSlide->GetRecordsByType(&oArrayColors, false);
|
||
|
||
for (size_t i = 0; i < oArrayColors.size(); ++i)
|
||
{
|
||
if (0x01 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
pNotes->m_bUseLayoutColorScheme = false;
|
||
oArrayColors[i]->ToArray(&pNotes->m_arColorScheme);
|
||
CorrectColorScheme(pNotes->m_arColorScheme);
|
||
|
||
// проверим на совпадение
|
||
size_t nCountC = pNotes->m_arColorScheme.size();
|
||
size_t nIndexC = 0;
|
||
if (pArrayColorScheme && nCountC == pArrayColorScheme->size())
|
||
{
|
||
for (; nIndexC < nCountC; ++nIndexC)
|
||
{
|
||
if (pNotes->m_arColorScheme[i].IsEqual(pArrayColorScheme->at(i)))
|
||
break;
|
||
}
|
||
}
|
||
|
||
if (nIndexC == nCountC)
|
||
{
|
||
pNotes->m_bUseLayoutColorScheme = true;
|
||
pNotes->m_arColorScheme.clear();
|
||
}
|
||
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
//------------------------------------------------------------------------------------
|
||
bool bHasDate = false;
|
||
bool bHasSlideNumber = false;
|
||
bool bHasFooter = false;
|
||
int nFormatDate = 1;
|
||
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
pRecordSlide->GetRecordsByType(&oArrayHeadersFootersInfo, true, false);
|
||
|
||
if (!oArrayHeadersFootersInfo.empty())
|
||
{
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate/* ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate*/;
|
||
bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) nFormatDate = 2;
|
||
}
|
||
for (int i = 0; i < 3; i++)
|
||
pNotes->m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
pNotes->m_bIsBackground = false;
|
||
|
||
//-------------------------------------------------------------------------------------------------------
|
||
std::vector<CRecordDrawingContainer*> oArrayDrawing;
|
||
|
||
pRecordSlide->GetRecordsByType(&oArrayDrawing, true);
|
||
|
||
m_current_level = 0;
|
||
m_current_elements = &pNotes->m_arElements;
|
||
|
||
if (!oArrayDrawing.empty())
|
||
{
|
||
for (size_t nIndex = 0; nIndex < oArrayDrawing[0]->m_arRecords.size(); ++nIndex)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, NULL, pTheme, pLayout, pThemeWrapper, pNotesWrapper, pNotes);
|
||
}
|
||
else
|
||
{
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(false, &m_oExMedia,
|
||
pTheme, pLayout, pThemeWrapper, pNotesWrapper, pNotes);
|
||
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
if (NULL != pShape && pShape->m_bIsBackground && !pShape->m_bHaveAnchor)
|
||
{
|
||
pShape->SetupProperties(pNotes, pTheme, pLayout);
|
||
|
||
pNotes->m_bIsBackground = true;
|
||
pNotes->m_oBackground = pShape->m_oBrush;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::TestSlide(_UINT32 dwSlideID)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairSlide = m_mapSlides.find(dwSlideID);
|
||
|
||
if (pPairSlide == m_mapSlides.end()) return;
|
||
|
||
CRecordSlide* pRecordSlide = pPairSlide->second;
|
||
if (NULL == pRecordSlide) return;
|
||
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
pRecordSlide->GetRecordsByType(&oArraySlideAtoms, false, true);
|
||
if (0 == oArraySlideAtoms.size())
|
||
{
|
||
// ошибка!!!
|
||
return;
|
||
}
|
||
std::map<_UINT32, LONG>::iterator pFind = m_mapRealUsedMaster.find(oArraySlideAtoms[0]->m_nMasterIDRef);
|
||
|
||
if (pFind == m_mapRealUsedMaster.end())
|
||
{
|
||
m_mapRealUsedMaster.insert(std::make_pair(oArraySlideAtoms[0]->m_nMasterIDRef, 1));
|
||
}
|
||
else
|
||
{
|
||
pFind->second++;
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadSlide(_UINT32 dwSlideID, CSlide* pSlide)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairSlide = m_mapSlides.find(dwSlideID);
|
||
|
||
if (pPairSlide == m_mapSlides.end()) return;
|
||
|
||
CRecordSlide* pRecordSlide = pPairSlide->second;
|
||
|
||
if (NULL == pRecordSlide) return;
|
||
|
||
// транзишн
|
||
|
||
CTransition* pTransition = &pSlide->m_oSlideShow.m_oTransition;
|
||
|
||
if (pRecordSlide->m_bExistsTransition)
|
||
{
|
||
CSlideShowSlideInfoAtom* pAtom = &pRecordSlide->m_oSlideShowSlideInfoAtom;
|
||
|
||
pTransition->m_bAudioPresent = pAtom->m_bSound;
|
||
|
||
PPT::CExFilesInfo* pInfo = m_oExMedia.LockAudioFromCollection(pAtom->m_nSoundRef);
|
||
if (NULL != pInfo)
|
||
{
|
||
pTransition->m_oAudio.m_strAudioFileName = pInfo->m_strFilePath;
|
||
}
|
||
|
||
pTransition->m_bLoopSound = pAtom->m_bLoopSound;
|
||
pTransition->m_bStopSound = pAtom->m_bStopSound;
|
||
pTransition->m_nEffectDirection = pAtom->m_nEffectDirection;
|
||
pTransition->m_nEffectType = pAtom->m_nEffectType; // тут нужно сконвертить тип // конвертится в Converter.cpp
|
||
pTransition->m_nSpeed = pAtom->m_nSpeed;
|
||
|
||
pSlide->m_oSlideShow.m_dSlideDuration = pAtom->m_nSlideTime;
|
||
pSlide->m_oSlideShow.m_bManulClick = pAtom->m_bManualAdvance;
|
||
pSlide->m_oSlideShow.m_bAdvClick = pAtom->m_bAutoAdvance;
|
||
|
||
pSlide->m_bHidden = pAtom->m_bHidden;
|
||
}
|
||
|
||
CSlideShowSlideInfoAtom* pAtom = &pRecordSlide->m_oSlideShowSlideInfoAtom;
|
||
if (pAtom->m_bSound)
|
||
{
|
||
PPT::CExFilesInfo* pInfo = m_oExMedia.LockAudioFromCollection(pAtom->m_nSoundRef);
|
||
if (NULL != pInfo)
|
||
AddAudioTransition(pAtom->m_nSoundRef, pTransition, pInfo->m_strFilePath);
|
||
}
|
||
|
||
// анимации
|
||
|
||
pSlide->m_bUseLayoutColorScheme = true;
|
||
|
||
CSlideInfo slide_info;
|
||
m_arSlideWrapper.push_back(slide_info);
|
||
|
||
CSlideInfo* pSlideWrapper = &m_arSlideWrapper.back();
|
||
|
||
int indexUser = pRecordSlide->m_IndexUser;
|
||
|
||
if (m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures.empty())
|
||
pSlideWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[0]->m_arOffsetPictures;
|
||
else
|
||
pSlideWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures;
|
||
|
||
pSlideWrapper->m_mapFilePictures = &m_pDocumentInfo->m_mapStoreImageFile;
|
||
// pSlideWrapper->m_arTextPlaceHolders = pRecordSlide->m_oPersist.m_arTextAttrs;
|
||
pSlideWrapper->m_arTextPlaceHolders.clear();
|
||
for (auto* pTextAttr : pRecordSlide->m_oPersist.m_arTextAttrs)
|
||
if (pTextAttr)
|
||
pSlideWrapper->m_arTextPlaceHolders.push_back(*pTextAttr);
|
||
|
||
// записываем шрифты
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
pRecordSlide->GetRecordsByType(&oArraySlideAtoms, false, true);
|
||
if (0 == oArraySlideAtoms.size())
|
||
{
|
||
// ошибка!!!
|
||
return;
|
||
}
|
||
bool bMasterColorScheme = oArraySlideAtoms[0]->m_bMasterScheme;
|
||
bool bMasterBackGround = oArraySlideAtoms[0]->m_bMasterBackground;
|
||
bool bMasterObjects = oArraySlideAtoms[0]->m_bMasterObjects;
|
||
|
||
std::map<_UINT32, LONG>::iterator pPairTheme = m_mapMasterToTheme.find(oArraySlideAtoms[0]->m_nMasterIDRef);
|
||
|
||
if (pPairTheme == m_mapMasterToTheme.end())
|
||
{
|
||
//????? слайду не присвоена тема !!!
|
||
if (false == m_mapMasterToTheme.empty())
|
||
pPairTheme = m_mapMasterToTheme.begin();
|
||
else
|
||
{
|
||
throw 1; // 第58课时 绘制频数直方图.ppt
|
||
}
|
||
}
|
||
//-----------------
|
||
pSlide->m_lThemeID = pPairTheme->second;
|
||
|
||
CTheme* pTheme = m_arThemes[pSlide->m_lThemeID].get();
|
||
CSlideInfo* pThemeWrapper = &m_arMasterWrapper[pSlide->m_lThemeID];
|
||
|
||
CLayout* pLayout = NULL;
|
||
|
||
std::map<_UINT32, LONG>::iterator pPairLayoutTitle = pTheme->m_mapTitleLayout.find(oArraySlideAtoms[0]->m_nMasterIDRef);
|
||
if (pPairLayoutTitle != pTheme->m_mapTitleLayout.end())
|
||
{
|
||
//основан на заголовочном шаблоне
|
||
pSlide->m_bShowMasterShapes = bMasterObjects;
|
||
pSlide->m_lLayoutID = pPairLayoutTitle->second;
|
||
pLayout = pTheme->m_arLayouts[pSlide->m_lLayoutID].get();
|
||
}
|
||
else
|
||
{
|
||
pSlide->m_bShowMasterShapes = true; //???
|
||
//основан на типовом шаблоне
|
||
std::map<_UINT64, LONG>::iterator pPairLayoutGeom = pTheme->m_mapGeomToLayout.find(oArraySlideAtoms[0]->m_oLayout.m_hash);
|
||
|
||
if (pPairLayoutGeom == pTheme->m_mapGeomToLayout.end())
|
||
{
|
||
pSlide->m_lLayoutID = AddNewLayout(pTheme, pRecordSlide, true, bMasterObjects);
|
||
|
||
pLayout = pTheme->m_arLayouts[pSlide->m_lLayoutID].get();
|
||
pLayout->m_bShowMasterShapes = true;
|
||
}
|
||
else
|
||
{
|
||
pSlide->m_lLayoutID = pPairLayoutGeom->second;
|
||
pLayout = pTheme->m_arLayouts[pSlide->m_lLayoutID].get();
|
||
}
|
||
}
|
||
|
||
std::vector<ODRAW::CColor>* pArrayColorScheme = &pTheme->m_arColorScheme;
|
||
if (!pLayout->m_bUseThemeColorScheme)
|
||
pArrayColorScheme = &pLayout->m_arColorScheme;
|
||
|
||
// читаем цветовую схему -----------------------------------------------------------
|
||
pSlide->m_bUseLayoutColorScheme = true;
|
||
if (!bMasterColorScheme)
|
||
{
|
||
std::vector<CRecordColorSchemeAtom*> oArrayColors;
|
||
pRecordSlide->GetRecordsByType(&oArrayColors, false);
|
||
|
||
for (size_t i = 0; i < oArrayColors.size(); ++i)
|
||
{
|
||
if (0x01 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
pSlide->m_bUseLayoutColorScheme = false;
|
||
oArrayColors[i]->ToArray(&pSlide->m_arColorScheme);
|
||
CorrectColorScheme(pSlide->m_arColorScheme);
|
||
|
||
// проверим на совпадение
|
||
size_t nCountC = pSlide->m_arColorScheme.size();
|
||
size_t nIndexC = 0;
|
||
if (pArrayColorScheme && nCountC == pArrayColorScheme->size())
|
||
{
|
||
for (; nIndexC < nCountC; ++nIndexC)
|
||
{
|
||
if (pSlide->m_arColorScheme[i].IsEqual(pArrayColorScheme->at(i)))
|
||
break;
|
||
}
|
||
}
|
||
|
||
if (nIndexC == nCountC)
|
||
{
|
||
pSlide->m_bUseLayoutColorScheme = true;
|
||
pSlide->m_arColorScheme.clear();
|
||
}
|
||
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
//------------------------------------------------------------------------------------
|
||
bool bHasDate = false;
|
||
bool bHasSlideNumber = false;
|
||
bool bHasFooter = false;
|
||
int nFormatDate = 1;
|
||
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
pRecordSlide->GetRecordsByType(&oArrayHeadersFootersInfo, true, false);
|
||
|
||
if (!oArrayHeadersFootersInfo.empty())
|
||
{
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate/* ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate*/;
|
||
bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) nFormatDate = 2;
|
||
}
|
||
for (int i = 0; i < 3; i++) pSlide->m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
else
|
||
{
|
||
bHasDate = pLayout->m_bHasDate;
|
||
bHasFooter = pLayout->m_bHasFooter;
|
||
bHasSlideNumber = pLayout->m_bHasSlideNumber;
|
||
nFormatDate = pLayout->m_nFormatDate;
|
||
|
||
for (int i = 0; i < 3; i++) pSlide->m_PlaceholdersReplaceString[i] = pLayout->m_PlaceholdersReplaceString[i];
|
||
}
|
||
//-------------------------------------------------------------------------------------------------------
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
pRecordSlide->GetRecordsByType(&oArrayStrings, false, false);
|
||
|
||
for (size_t i = 0; i < oArrayStrings.size(); i++)
|
||
{
|
||
if (oArrayStrings[i]->m_oHeader.RecType == 0x0fba)
|
||
{
|
||
pSlide->m_sName = oArrayStrings[i]->m_strText;
|
||
}
|
||
}
|
||
pSlide->m_bIsBackground = false;
|
||
//-------------------------------------------------------------------------------------------------------
|
||
std::vector<CRecordDrawingContainer*> oArrayDrawing;
|
||
pRecordSlide->GetRecordsByType(&oArrayDrawing, true);
|
||
|
||
m_current_level = 0;
|
||
m_current_elements = &pSlide->m_arElements;
|
||
|
||
if (!oArrayDrawing.empty())
|
||
{
|
||
for (size_t nIndex = 0; nIndex < oArrayDrawing[0]->m_arRecords.size(); ++nIndex)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, NULL, pTheme, pLayout, pThemeWrapper, pSlideWrapper, pSlide);
|
||
}
|
||
else
|
||
{
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(false, &m_oExMedia,
|
||
pTheme, pLayout, pThemeWrapper, pSlideWrapper, pSlide);
|
||
|
||
if (pElement->m_bIsBackground && !pElement->m_bHaveAnchor && !bMasterBackGround)
|
||
{
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
if (NULL != pShape && pSlide)
|
||
{
|
||
pShape->SetupProperties(pSlide, pTheme, pLayout);
|
||
|
||
pSlide->m_bIsBackground = true;
|
||
pSlide->m_oBackground = pShape->m_oBrush;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
std::multimap<int, int>::iterator it;
|
||
|
||
if (bHasSlideNumber) AddLayoutSlidePlaceholder(pSlide, PT_MasterSlideNumber, pLayout, true);
|
||
|
||
if (bHasDate)
|
||
{
|
||
CElementPtr pElement = AddLayoutSlidePlaceholder(pSlide, PT_MasterDate, pLayout, true);
|
||
|
||
if (pElement) pElement->m_nFormatDate = nFormatDate;
|
||
}
|
||
|
||
if (bHasFooter) AddLayoutSlidePlaceholder(pSlide, PT_MasterFooter, pLayout, true);
|
||
}
|
||
|
||
void CPPTUserInfo::LoadGroupShapeContainer(CRecordGroupShapeContainer* pGroupContainer, std::vector<CElementPtr>* pParentElements, CTheme* pTheme, CLayout* pLayout,
|
||
CSlideInfo* pThemeWrapper, CSlideInfo* pSlideWrapper, CSlide* pSlide)
|
||
{
|
||
if (!pGroupContainer) return;
|
||
if (pGroupContainer->m_arRecords.empty()) return;
|
||
|
||
// LoadAutoNumbering(pGroupContainer, pTheme);
|
||
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(pGroupContainer->m_arRecords[0]);
|
||
|
||
CElementPtr pElement;
|
||
if (pShapeGroup)
|
||
{
|
||
pShapeGroup->bGroupShape = true;
|
||
|
||
pElement = pShapeGroup->GetElement(m_current_level > 1, &m_oExMedia, pTheme, pLayout, pThemeWrapper, pSlideWrapper, pSlide);
|
||
}
|
||
|
||
if (!pElement) return;
|
||
pElement->m_pParentElements = pParentElements;
|
||
m_current_elements->push_back(pElement);
|
||
|
||
m_current_level++;
|
||
|
||
pParentElements = m_current_elements;
|
||
m_current_elements = &pElement->m_pChildElements;
|
||
|
||
for (size_t i = 1; i < pGroupContainer->m_arRecords.size(); i++)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(pGroupContainer->m_arRecords[i]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, pParentElements, pTheme, pLayout, pThemeWrapper, pSlideWrapper, pSlide);
|
||
}
|
||
else
|
||
{
|
||
pShapeGroup = dynamic_cast<CRecordShapeContainer*>(pGroupContainer->m_arRecords[i]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(m_current_level > 1, &m_oExMedia, pTheme, pLayout, pThemeWrapper, pSlideWrapper, pSlide);
|
||
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
// LoadBulletBlip(pShape);
|
||
LoadAutoNumBullet(pShape, pSlide ? pSlide->m_lSlideID : -1);
|
||
if (NULL != pElement)
|
||
{
|
||
pElement->m_pParentElements = pParentElements;
|
||
|
||
// AddAnimation ( dwSlideID, pSlide->m_lOriginalWidth, pSlide->m_lOriginalHeight, pElement );
|
||
|
||
if (NULL != pShape)
|
||
pShape->SetupProperties(pSlide, pTheme, pLayout);
|
||
|
||
if (pElement->m_lPlaceholderType > 0)
|
||
{
|
||
if (pSlide)
|
||
{
|
||
pSlide->m_mapPlaceholders.insert(std::make_pair(pElement->m_lPlaceholderType, pElement));
|
||
}
|
||
else if (pTheme)
|
||
{
|
||
pTheme->m_mapPlaceholders.insert(std::make_pair(pElement->m_lPlaceholderType, pElement));
|
||
}
|
||
else
|
||
{
|
||
if (pElement->m_lPlaceholderID >= 0)
|
||
{
|
||
if (pElement->m_lPlaceholderType == PT_MasterSlideNumber) pLayout->m_bHasSlideNumber = true;
|
||
if (pElement->m_lPlaceholderType == PT_MasterDate) pLayout->m_bHasDate = true;
|
||
if (pElement->m_lPlaceholderType == PT_MasterFooter) pLayout->m_bHasFooter = true;
|
||
}
|
||
pLayout->m_mapPlaceholders.insert(std::make_pair(pElement->m_lPlaceholderType, pElement));
|
||
}
|
||
}
|
||
if (pElement->m_bHaveAnchor)
|
||
{
|
||
m_current_elements->push_back(pElement);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
m_current_level--;
|
||
|
||
if (false == m_current_elements->empty())
|
||
{
|
||
m_current_elements = m_current_elements->front()->m_pParentElements;
|
||
}
|
||
}
|
||
|
||
CElementPtr CPPTUserInfo::AddLayoutSlidePlaceholder(CSlide* pSlide, int placeholderType, CLayout* pLayout, bool idx_only)
|
||
{
|
||
CElementPtr pElement;
|
||
|
||
for (std::multimap<int, CElementPtr>::iterator it = pLayout->m_mapPlaceholders.begin(); it != pLayout->m_mapPlaceholders.end(); ++it)
|
||
{
|
||
CElementPtr pElementPlaceholder = it->second;
|
||
if (it->first == placeholderType)
|
||
{
|
||
if (idx_only == false)
|
||
{
|
||
if (pElementPlaceholder->m_lPlaceholderID >= 0) continue;
|
||
|
||
pElement = pElementPlaceholder->CreateDublicate();
|
||
|
||
pSlide->m_arElements.push_back(pElement);
|
||
pSlide->m_mapPlaceholders.insert(std::make_pair(placeholderType, pElement));
|
||
}
|
||
else
|
||
{
|
||
if (pElementPlaceholder->m_lPlaceholderID < 0) continue;
|
||
|
||
for (std::multimap<int, CElementPtr>::iterator it1 = pSlide->m_mapPlaceholders.begin(); it1 != pSlide->m_mapPlaceholders.end(); it1++)
|
||
{
|
||
if (it1->first == placeholderType && (it1->second)->m_lPlaceholderID >= 0)
|
||
{
|
||
pElement = it1->second;
|
||
break;
|
||
}
|
||
}
|
||
if (!pElement)
|
||
{
|
||
pElement = pElementPlaceholder->CreateDublicate();
|
||
|
||
pSlide->m_arElements.push_back(pElement);
|
||
pSlide->m_mapPlaceholders.insert(std::make_pair(placeholderType, pElement));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
return pElement;
|
||
}
|
||
|
||
CElementPtr CPPTUserInfo::AddThemeLayoutPlaceholder(CLayout* pLayout, int placeholderType, CTheme* pTheme, bool idx_only)
|
||
{
|
||
CElementPtr pElement;
|
||
|
||
for (std::multimap<int, CElementPtr>::iterator it = pTheme->m_mapPlaceholders.begin(); it != pTheme->m_mapPlaceholders.end(); ++it)
|
||
{
|
||
CElementPtr pElementPlaceholder = it->second;
|
||
|
||
if (it->first == placeholderType)
|
||
{
|
||
if (idx_only && pElementPlaceholder->m_lPlaceholderID < 0) continue;
|
||
|
||
pElement = pElementPlaceholder->CreateDublicate();
|
||
|
||
pElement->m_bPlaceholderSet = true;
|
||
|
||
if (pElement->m_lPlaceholderType == 14)
|
||
pElement->m_lPlaceholderType = PT_Body_Empty; // для добавления разных типов объектов
|
||
|
||
pLayout->m_arElements.push_back(pElement);
|
||
pLayout->m_mapPlaceholders.insert(std::make_pair(placeholderType, pElement));
|
||
}
|
||
}
|
||
|
||
return pElement; //last added
|
||
}
|
||
|
||
CElementPtr CPPTUserInfo::AddNewLayoutPlaceholder(CLayout* pLayout, int placeholderType, int placeholderSizePreset)
|
||
{
|
||
if (placeholderType < 1) return CElementPtr();
|
||
|
||
CShapeElement* pShape = new CShapeElement(NSBaseShape::ppt, PPTShapes::sptCRect);
|
||
|
||
pShape->m_lPlaceholderType = placeholderType;
|
||
pShape->m_lPlaceholderSizePreset = placeholderSizePreset;
|
||
|
||
pShape->m_bPlaceholderSet = false;
|
||
pShape->m_bLine = false;
|
||
pShape->m_bAnchorEnabled = false;
|
||
pShape->m_bChildAnchorEnabled = false;
|
||
|
||
CorrectPlaceholderType(pShape->m_lPlaceholderType);
|
||
|
||
CElementPtr pElement = CElementPtr(pShape);
|
||
|
||
pLayout->m_arElements.push_back(pElement);
|
||
pLayout->m_mapPlaceholders.insert(std::make_pair(pShape->m_lPlaceholderType, pElement));
|
||
|
||
return pElement;
|
||
}
|
||
|
||
int CPPTUserInfo::AddNewLayout(CTheme* pTheme, CRecordSlide* pRecordSlide, bool addShapes, bool bMasterObjects)
|
||
{
|
||
if (pTheme == NULL) return -1;
|
||
if (pRecordSlide == NULL) return -1;
|
||
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
|
||
pRecordSlide->GetRecordsByType(&oArraySlideAtoms, true);
|
||
if (0 == oArraySlideAtoms.size()) return -1;
|
||
|
||
SSlideLayoutAtom& layoutRecord = oArraySlideAtoms[0]->m_oLayout;
|
||
|
||
int ind = pTheme->m_arLayouts.size();
|
||
|
||
pTheme->m_arLayouts.push_back(boost::make_shared<PPT::CLayout>());
|
||
CLayout* pLayout = pTheme->m_arLayouts.back().get();
|
||
|
||
pLayout->m_bUseThemeColorScheme = true;
|
||
pLayout->m_bShowMasterShapes = true;
|
||
|
||
ConvertLayoutType(layoutRecord, pLayout->m_strLayoutType, pLayout->m_sName);
|
||
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
pRecordSlide->GetRecordsByType(&oArrayStrings, false, false);
|
||
|
||
if (false == addShapes && false == bMasterObjects) return ind;
|
||
//далее только для типовых шаблонов
|
||
pTheme->m_mapGeomToLayout.insert(std::pair<_UINT64, LONG>(layoutRecord.m_hash, ind));
|
||
|
||
int defObjSize = -1;
|
||
switch (layoutRecord.m_nGeom)
|
||
{
|
||
case 0x01: // SL_TitleBody
|
||
defObjSize = 0; break;
|
||
case 0x08: //SL_TwoColumns
|
||
case 0x09: //SL_TwoRows
|
||
defObjSize = 1; break;
|
||
case 0x0A: //SL_ColumnTwoRows
|
||
defObjSize = 3; break;
|
||
case 0x0B: //SL_TwoRowsColumn
|
||
defObjSize = 3; break;
|
||
case 0x0D: //SL_TwoColumnsRow
|
||
defObjSize = 3; break;
|
||
case 0x0E://SL_FourObjects
|
||
defObjSize = 2; break;
|
||
case 0x0F: //SL_BigObject
|
||
case 0x11: //SL_VerticalTitleBody
|
||
case 0x12: //SL_VerticalTwoRows
|
||
defObjSize = 0; break;
|
||
case 0x10: // SL_Blank
|
||
break;
|
||
}
|
||
|
||
for (int i = 0; i < 8; i++)
|
||
{
|
||
if (layoutRecord.m_pPlaceHolderID[i] == 0) break;
|
||
|
||
switch (layoutRecord.m_pPlaceHolderID[i])
|
||
{
|
||
case PT_MasterTitle:
|
||
case PT_MasterBody:
|
||
case PT_MasterCenterTitle:
|
||
case PT_MasterSubTitle:
|
||
case PT_MasterNotesSlideImage:
|
||
case PT_MasterNotesBody:
|
||
{
|
||
int usualType = layoutRecord.m_pPlaceHolderID[i];
|
||
CorrectPlaceholderType(usualType);
|
||
|
||
if (!AddThemeLayoutPlaceholder(pLayout, usualType, pTheme))
|
||
{
|
||
}
|
||
}break;
|
||
case PT_MasterDate:
|
||
case PT_MasterSlideNumber:
|
||
case PT_MasterFooter:
|
||
case PT_MasterHeader:
|
||
{
|
||
int usualType = layoutRecord.m_pPlaceHolderID[i];
|
||
CorrectPlaceholderType(usualType);
|
||
|
||
if (!AddThemeLayoutPlaceholder(pLayout, usualType, pTheme))
|
||
{
|
||
AddNewLayoutPlaceholder(pLayout, usualType, defObjSize);
|
||
}
|
||
}break;
|
||
default:
|
||
AddNewLayoutPlaceholder(pLayout, layoutRecord.m_pPlaceHolderID[i], defObjSize);
|
||
break;
|
||
}
|
||
}
|
||
//if (layoutRecord.m_nGeom==0x0F) return ind; // big object only !!!
|
||
if (false == addShapes) return ind;
|
||
|
||
//копируем все элементы без idx которые не были прописаны явно
|
||
for (std::multimap<int, CElementPtr>::iterator it = pTheme->m_mapPlaceholders.begin(); it != pTheme->m_mapPlaceholders.end(); ++it)
|
||
{
|
||
CElementPtr pElemTheme = it->second;
|
||
if (pElemTheme->m_lPlaceholderID >= 0) continue;
|
||
|
||
bool found = false;
|
||
for (std::multimap<int, CElementPtr>::iterator it1 = pLayout->m_mapPlaceholders.begin(); it1 != pLayout->m_mapPlaceholders.end(); it1++)
|
||
{
|
||
if (it1->first == it->first)
|
||
{
|
||
CElementPtr pElemLayout = it1->second;
|
||
if (pElemLayout->m_lPlaceholderID == pElemTheme->m_lPlaceholderID)
|
||
{
|
||
found = true;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
if (found == false)
|
||
{
|
||
CElementPtr pElement = pElemTheme->CreateDublicate();
|
||
|
||
pLayout->m_arElements.push_back(pElement);
|
||
pLayout->m_mapPlaceholders.insert(std::make_pair(it->first, pElement));
|
||
}
|
||
}
|
||
|
||
pLayout->m_bHasDate = pTheme->m_bHasDate;
|
||
pLayout->m_bHasFooter = pTheme->m_bHasFooter;
|
||
pLayout->m_bHasSlideNumber = pTheme->m_bHasSlideNumber;
|
||
pLayout->m_nFormatDate = pTheme->m_nFormatDate;
|
||
|
||
for (int i = 0; i < 3; i++) pLayout->m_PlaceholdersReplaceString[i] = pTheme->m_PlaceholdersReplaceString[i];
|
||
|
||
if (pLayout->m_bHasSlideNumber) AddThemeLayoutPlaceholder(pLayout, PT_MasterSlideNumber, pTheme, true);
|
||
if (pLayout->m_bHasDate) AddThemeLayoutPlaceholder(pLayout, PT_MasterDate, pTheme, true);
|
||
if (pLayout->m_bHasFooter) AddThemeLayoutPlaceholder(pLayout, PT_MasterFooter, pTheme, true);
|
||
|
||
return ind;
|
||
}
|
||
|
||
CElementPtr CPPTUserInfo::AddNewThemePlaceholder(CTheme* pTheme, int placeholderType, int placeholderSizePreset)
|
||
{
|
||
if (placeholderType < 1) return CElementPtr();
|
||
|
||
CShapeElement* pShape = new CShapeElement(NSBaseShape::ppt, PPTShapes::sptCRect);
|
||
|
||
pShape->m_lPlaceholderType = placeholderType;
|
||
pShape->m_lPlaceholderSizePreset = placeholderSizePreset;
|
||
|
||
pShape->m_bPlaceholderSet = false;
|
||
pShape->m_bLine = false;
|
||
pShape->m_bAnchorEnabled = false;
|
||
pShape->m_bChildAnchorEnabled = false;
|
||
|
||
CorrectPlaceholderType(pShape->m_lPlaceholderType);
|
||
|
||
CElementPtr pElement = CElementPtr(pShape);
|
||
|
||
pTheme->m_arElements.push_back(pElement);
|
||
pTheme->m_mapPlaceholders.insert(std::make_pair(pShape->m_lPlaceholderType, pElement));
|
||
|
||
return pElement;
|
||
}
|
||
void CPPTUserInfo::LoadMainMaster(_UINT32 dwMasterID, bool alwaysLoad)
|
||
{
|
||
std::map<_UINT32, LONG>::iterator pPair = m_mapMasterToTheme.find(dwMasterID);
|
||
if (pPair != m_mapMasterToTheme.end())
|
||
{
|
||
// мастер уже загружен
|
||
return;
|
||
}
|
||
|
||
LoadMasterFromPrevUsers(dwMasterID);
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairMaster = m_mapMasters.find(dwMasterID);
|
||
|
||
if (m_mapMasters.end() == pPairMaster)//??? не может быть
|
||
return;
|
||
|
||
CRecordSlide* pMaster = pPairMaster->second;
|
||
|
||
if (pMaster == NULL)//??? не может быть
|
||
return;
|
||
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
pMaster->GetRecordsByType(&oArraySlideAtoms, true);
|
||
if (0 == oArraySlideAtoms.size())
|
||
return;
|
||
|
||
_UINT32 dwID = (_UINT32)oArraySlideAtoms[0]->m_nMasterIDRef;
|
||
if (0 != dwID)
|
||
{
|
||
// этот мастер - не main!!!
|
||
// сначала загрузим все main, а потом - title
|
||
// title нужно грузить как обычный слайд.
|
||
return;
|
||
}
|
||
std::vector<RoundTripCompositeMasterId12Atom*> oArrayCompId;
|
||
pMaster->GetRecordsByType(&oArrayCompId, false, true);
|
||
if (0 != oArrayCompId.size() && !alwaysLoad)
|
||
{
|
||
// этот мастер - не main!!!
|
||
// сначала загрузим все main, а потом - title
|
||
// title нужно грузить как обычный слайд.
|
||
// 第58课时 绘制频数直方图.ppt
|
||
return;
|
||
}
|
||
|
||
bool bMasterColorScheme = oArraySlideAtoms[0]->m_bMasterScheme;
|
||
bool bMasterBackGround = oArraySlideAtoms[0]->m_bMasterBackground;
|
||
bool bMasterObjects = oArraySlideAtoms[0]->m_bMasterObjects;
|
||
|
||
std::vector<RoundTripOriginalMainMasterId12Atom*> oArrayOrigId;
|
||
pMaster->GetRecordsByType(&oArrayOrigId, false, true);
|
||
|
||
if (0 != oArrayOrigId.size())
|
||
m_mapMasterOriginalIds.insert(std::pair<_UINT32, _UINT32>(oArrayOrigId[0]->m_dwID, dwMasterID));
|
||
|
||
LONG lIndexTheme = (LONG)m_arThemes.size();
|
||
|
||
m_mapMasterToTheme.insert(std::pair<_UINT32, LONG>(dwMasterID, lIndexTheme));
|
||
|
||
m_arThemes.push_back(boost::make_shared<PPT::CTheme>());
|
||
CTheme* pTheme = m_arThemes[lIndexTheme].get();
|
||
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
pMaster->GetRecordsByType(&oArrayHeadersFootersInfo, true, false);
|
||
|
||
if (0 != oArrayHeadersFootersInfo.size())
|
||
{
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
pTheme->m_bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate;
|
||
pTheme->m_bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
pTheme->m_bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) pTheme->m_nFormatDate = 2;
|
||
}
|
||
for (int i = 0; i < 3; i++) pTheme->m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
else
|
||
{
|
||
pTheme->m_bHasDate = m_bHasDate;
|
||
pTheme->m_bHasFooter = m_bHasFooter;
|
||
pTheme->m_bHasSlideNumber = m_bHasSlideNumber;
|
||
pTheme->m_nFormatDate = m_nFormatDate;
|
||
for (int i = 0; i < 3; i++) pTheme->m_PlaceholdersReplaceString[i] = m_PlaceholdersReplaceString[i];
|
||
}
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
pMaster->GetRecordsByType(&oArrayStrings, false, false);
|
||
|
||
for (size_t i = 0; i < oArrayStrings.size(); i++)
|
||
{
|
||
if (oArrayStrings[i]->m_oHeader.RecType == 0x0fba)
|
||
{
|
||
pTheme->m_sThemeName = oArrayStrings[i]->m_strText;
|
||
}
|
||
}
|
||
|
||
CSlideInfo slide_info;
|
||
m_arMasterWrapper.push_back(slide_info);
|
||
CSlideInfo* pMasterWrapper = &m_arMasterWrapper[lIndexTheme];
|
||
|
||
// записываем шрифты ---------------------------------------------------------------
|
||
for (size_t i = 0; i < m_arrFonts.size(); ++i)
|
||
{
|
||
pTheme->m_arFonts.push_back(m_arrFonts[i]);
|
||
}
|
||
// ---------------------------------------------------------------------------------
|
||
|
||
// читаем цветовую схему -----------------------------------------------------------
|
||
std::vector<CRecordColorSchemeAtom*> oArrayColors;
|
||
pMaster->GetRecordsByType(&oArrayColors, false);
|
||
|
||
int nColorCount = oArrayColors.size();
|
||
for (int i = 0; i < nColorCount; ++i)
|
||
{
|
||
if (0x01 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
if (m_oSchemeColors.empty())
|
||
{
|
||
oArrayColors[i]->ToArray(&m_oSchemeColors);
|
||
CorrectColorScheme(m_oSchemeColors);//??
|
||
}
|
||
if (pTheme->m_arColorScheme.empty())
|
||
{
|
||
oArrayColors[i]->ToArray(&pTheme->m_arColorScheme);
|
||
CorrectColorScheme(pTheme->m_arColorScheme);
|
||
}
|
||
}
|
||
|
||
if (0x06 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
std::vector<CColor> extra;
|
||
oArrayColors[i]->ToArray(&extra);
|
||
|
||
CorrectColorScheme(extra);
|
||
pTheme->m_arExtraColorScheme.push_back(extra);
|
||
}
|
||
}
|
||
if (pTheme->m_arColorScheme.empty() && !pTheme->m_arExtraColorScheme.empty())
|
||
{
|
||
pTheme->m_arColorScheme = pTheme->m_arExtraColorScheme[0];
|
||
}
|
||
|
||
// ---------------------------------------------------------------------------------
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairMaster1 = m_mapMasters.find(dwMasterID);
|
||
|
||
int indexUser = 0;
|
||
if (pPairMaster1 != m_mapMasters.end())
|
||
{
|
||
indexUser = pPairMaster1->second->m_IndexUser;
|
||
// pMasterWrapper->m_arTextPlaceHolders = pPairMaster1->second->m_oPersist.m_arTextAttrs;
|
||
pMasterWrapper->m_arTextPlaceHolders.clear();
|
||
for (auto* pTextAttr : pPairMaster1->second->m_oPersist.m_arTextAttrs)
|
||
if (pTextAttr)
|
||
pMasterWrapper->m_arTextPlaceHolders.push_back(*pTextAttr);
|
||
}
|
||
if (m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures.empty() == false)
|
||
pMasterWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures;
|
||
else
|
||
pMasterWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[0]->m_arOffsetPictures;
|
||
|
||
pMasterWrapper->m_mapFilePictures = &m_pDocumentInfo->m_mapStoreImageFile;
|
||
|
||
// читаем настройки текстовых стилей -----------------------------------------------
|
||
std::vector<CRecordTextMasterStyleAtom*> oArrayTextMasters;
|
||
pMaster->GetRecordsByType(&oArrayTextMasters, true, false);
|
||
|
||
for (size_t i = 0; i < oArrayTextMasters.size(); ++i)
|
||
{
|
||
LONG lType = (LONG)oArrayTextMasters[i]->m_oHeader.RecInstance;
|
||
if ((0 > lType) || (lType > 8))
|
||
continue;
|
||
|
||
pMasterWrapper->m_pStyles[lType] = new PPT::CTextStyles();
|
||
pMasterWrapper->m_pStyles[lType]->SetStyles((PPT::CTextStyles*)oArrayTextMasters[i]);
|
||
|
||
CTheme::CalculateStyle(pTheme, pMasterWrapper->m_pStyles[lType].get());
|
||
}
|
||
if (pMasterWrapper->m_pStyles[3].is_init())
|
||
pMasterWrapper->m_pStyles[3]->ApplyBefore(m_oDefaultTextStyle);
|
||
else
|
||
pMasterWrapper->m_pStyles[3] = m_oDefaultTextStyle;
|
||
|
||
CTextStyles oPPTDefaultStyle;
|
||
CreateDefaultStyle(oPPTDefaultStyle, pTheme);
|
||
oPPTDefaultStyle.ApplyAfter(m_oDefaultTextStyle);
|
||
|
||
// выставим стили теме
|
||
pTheme->m_pStyles[0] = oPPTDefaultStyle;
|
||
pTheme->m_pStyles[1] = oPPTDefaultStyle;
|
||
pTheme->m_pStyles[2] = oPPTDefaultStyle;
|
||
pTheme->m_pStyles[3] = oPPTDefaultStyle;
|
||
|
||
if (pMasterWrapper->m_pStyles[0].is_init())
|
||
pTheme->m_pStyles[1].ApplyAfter(pMasterWrapper->m_pStyles[0].get());
|
||
if (pMasterWrapper->m_pStyles[1].is_init())
|
||
pTheme->m_pStyles[2].ApplyAfter(pMasterWrapper->m_pStyles[1].get());
|
||
if (pMasterWrapper->m_pStyles[3].is_init())
|
||
pTheme->m_pStyles[3].ApplyAfter(pMasterWrapper->m_pStyles[3].get());
|
||
|
||
pTheme->CalculateStyles();
|
||
|
||
CLayout* pLayout = NULL; // ну нету тут разметок ...!!
|
||
// ---------------------------------------------------------------------------------
|
||
|
||
std::vector<CRecordDrawingContainer*> oArrayDrawing;
|
||
pMaster->GetRecordsByType(&oArrayDrawing, true);
|
||
|
||
m_current_level = 0;
|
||
m_current_elements = &pTheme->m_arElements;
|
||
|
||
if (!oArrayDrawing.empty())
|
||
{
|
||
for (size_t nIndex = 0; nIndex < oArrayDrawing[0]->m_arRecords.size(); ++nIndex)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, NULL, pTheme, pLayout, pMasterWrapper, pMasterWrapper);
|
||
}
|
||
else
|
||
{
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(false, &m_oExMedia, pTheme, pLayout, pMasterWrapper, pMasterWrapper);
|
||
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
if (NULL != pShape)
|
||
{
|
||
pShape->SetupProperties(NULL, pTheme, pLayout);
|
||
|
||
pTheme->m_bIsBackground = true;
|
||
pTheme->m_oBackground = pShape->m_oBrush;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
int lLayoutID = AddNewLayout(pTheme, pMaster, false, true);
|
||
|
||
if (lLayoutID >= 0 && false == pTheme->m_arLayouts.empty())
|
||
{
|
||
CLayout* pLayout_ = pTheme->m_arLayouts.back().get();
|
||
//pLayout_->m_strLayoutType = L"obj";
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::LoadMasters()
|
||
{
|
||
for (size_t i = 0; i < m_arrMastersOrder.size(); i++)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapMasters.find(m_arrMastersOrder[i]);
|
||
if (pPair == m_mapMasters.end())continue;
|
||
|
||
LoadMainMaster(pPair->first, false);
|
||
}
|
||
if (m_mapMasterToTheme.empty())
|
||
{
|
||
for (auto master : m_mapRealUsedMaster)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapMasters.find(master.first);
|
||
if (pPair == m_mapMasters.end())continue;
|
||
|
||
LoadMainMaster(pPair->first, true);
|
||
}
|
||
}
|
||
for (size_t i = 0; i < m_arrMastersOrder.size(); i++)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapMasters.find(m_arrMastersOrder[i]);
|
||
if (pPair == m_mapMasters.end())continue;
|
||
|
||
LoadNoMainMaster(pPair->first);
|
||
}
|
||
|
||
LoadNotesMasterFromPrevUsers(0);
|
||
if (!m_mapNotesMasters.empty())
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapNotesMasters.begin();
|
||
|
||
LoadMaster(typeNotesMaster, pPair->second, m_pNotesMasterWrapper, m_pNotesMaster);
|
||
}
|
||
|
||
LoadHandoutMasterFromPrevUsers(0);
|
||
if (!m_mapHandoutMasters.empty())
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapHandoutMasters.begin();
|
||
|
||
LoadMaster(typeHandoutMaster, pPair->second, m_pHandoutMasterWrapper, m_pHandoutMaster);
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadMaster(_typeMaster type, CRecordSlide* pMaster, CSlideInfo*& pMasterWrapper, CThemePtr& pTheme)
|
||
{
|
||
if (pMaster == NULL)
|
||
return;
|
||
|
||
bool bMasterColorScheme = false;
|
||
bool bMasterBackGround = false;
|
||
bool bMasterObjects = false;
|
||
|
||
_UINT32 dwID = 0;
|
||
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
pMaster->GetRecordsByType(&oArraySlideAtoms, true);
|
||
|
||
if (!oArraySlideAtoms.empty())
|
||
{
|
||
dwID = (_UINT32)oArraySlideAtoms[0]->m_nMasterIDRef;
|
||
|
||
bMasterColorScheme = oArraySlideAtoms[0]->m_bMasterScheme;
|
||
bMasterBackGround = oArraySlideAtoms[0]->m_bMasterBackground;
|
||
bMasterObjects = oArraySlideAtoms[0]->m_bMasterObjects;
|
||
}
|
||
else
|
||
{
|
||
std::vector<CRecordNotesAtom*> oArrayNotesAtoms;
|
||
pMaster->GetRecordsByType(&oArrayNotesAtoms, true);
|
||
|
||
if (!oArrayNotesAtoms.empty())
|
||
{
|
||
dwID = (_UINT32)oArrayNotesAtoms[0]->m_nSlideIDRef;
|
||
|
||
bMasterColorScheme = oArrayNotesAtoms[0]->m_bMasterScheme;
|
||
bMasterBackGround = oArrayNotesAtoms[0]->m_bMasterBackground;
|
||
bMasterObjects = oArrayNotesAtoms[0]->m_bMasterObjects;
|
||
}
|
||
}
|
||
|
||
pTheme = boost::make_shared<PPT::CTheme>(type);
|
||
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
pMaster->GetRecordsByType(&oArrayHeadersFootersInfo, true, false);
|
||
|
||
if (0 != oArrayHeadersFootersInfo.size())
|
||
{
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
pTheme->m_bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate;
|
||
pTheme->m_bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
pTheme->m_bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) pTheme->m_nFormatDate = 2;
|
||
}
|
||
for (int i = 0; i < 3; i++) pTheme->m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
else
|
||
{
|
||
pTheme->m_bHasDate = m_bHasDate;
|
||
pTheme->m_bHasFooter = m_bHasFooter;
|
||
pTheme->m_bHasSlideNumber = m_bHasSlideNumber;
|
||
pTheme->m_nFormatDate = m_nFormatDate;
|
||
for (int i = 0; i < 3; i++) pTheme->m_PlaceholdersReplaceString[i] = m_PlaceholdersReplaceString[i];
|
||
}
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
pMaster->GetRecordsByType(&oArrayStrings, false, false);
|
||
|
||
for (size_t i = 0; i < oArrayStrings.size(); i++)
|
||
{
|
||
if (oArrayStrings[i]->m_oHeader.RecType == 0x0fba)
|
||
{
|
||
pTheme->m_sThemeName = oArrayStrings[i]->m_strText;
|
||
}
|
||
}
|
||
|
||
pMasterWrapper = new CSlideInfo();
|
||
|
||
// записываем шрифты ---------------------------------------------------------------
|
||
for (size_t i = 0; i < m_arrFonts.size(); ++i)
|
||
{
|
||
pTheme->m_arFonts.push_back(m_arrFonts[i]);
|
||
}
|
||
// ---------------------------------------------------------------------------------
|
||
|
||
// читаем цветовую схему -----------------------------------------------------------
|
||
std::vector<CRecordColorSchemeAtom*> oArrayColors;
|
||
pMaster->GetRecordsByType(&oArrayColors, false);
|
||
|
||
int nColorCount = oArrayColors.size();
|
||
for (int i = 0; i < nColorCount; ++i)
|
||
{
|
||
if (0x01 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
if (m_oSchemeColors.empty())
|
||
{
|
||
oArrayColors[i]->ToArray(&m_oSchemeColors);
|
||
CorrectColorScheme(m_oSchemeColors);//??
|
||
}
|
||
if (pTheme->m_arColorScheme.empty())
|
||
{
|
||
oArrayColors[i]->ToArray(&pTheme->m_arColorScheme);
|
||
CorrectColorScheme(pTheme->m_arColorScheme);
|
||
}
|
||
}
|
||
|
||
if (0x06 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
std::vector<CColor> extra;
|
||
oArrayColors[i]->ToArray(&extra);
|
||
|
||
CorrectColorScheme(extra);
|
||
pTheme->m_arExtraColorScheme.push_back(extra);
|
||
}
|
||
}
|
||
if (pTheme->m_arColorScheme.empty() && !pTheme->m_arExtraColorScheme.empty())
|
||
{
|
||
pTheme->m_arColorScheme = pTheme->m_arExtraColorScheme[0];
|
||
}
|
||
|
||
// ---------------------------------------------------------------------------------
|
||
int indexUser = 0;
|
||
//std::map<_UINT32, CRecordSlide*>::iterator pPairMaster1 = m_mapMasters.find(dwMasterID);
|
||
//if (pPairMaster1 != m_mapMasters.end())
|
||
//{
|
||
// indexUser = pPairMaster1->second->m_IndexUser;
|
||
// pMasterWrapper->m_arTextPlaceHolders = pPairMaster1->second->m_oPersist.m_arTextAttrs;
|
||
//}
|
||
pMasterWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[indexUser]->m_arOffsetPictures;
|
||
pMasterWrapper->m_mapFilePictures = &m_pDocumentInfo->m_mapStoreImageFile;
|
||
|
||
//настройки текстовых стилей -----------------------------------------------
|
||
|
||
for (size_t i = 0; i < 9 && false == m_arMasterWrapper.empty(); ++i)
|
||
{
|
||
pMasterWrapper->m_pStyles[i] = m_arMasterWrapper[0].m_pStyles[i]; //main master
|
||
}
|
||
|
||
CLayout* pLayout = NULL; // ну нету тут разметок ...!!
|
||
|
||
//-------------------------------------------------------------------------------------------------------
|
||
std::vector<CRecordDrawingContainer*> oArrayDrawing;
|
||
pMaster->GetRecordsByType(&oArrayDrawing, true);
|
||
|
||
m_current_level = 0;
|
||
m_current_elements = &pTheme->m_arElements;
|
||
|
||
if (!oArrayDrawing.empty())
|
||
{
|
||
for (size_t nIndex = 0; nIndex < oArrayDrawing[0]->m_arRecords.size(); ++nIndex)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, NULL, pTheme.get(), pLayout, pMasterWrapper, pMasterWrapper);
|
||
}
|
||
else
|
||
{
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(false, &m_oExMedia, pTheme.get(), pLayout, pMasterWrapper, pMasterWrapper);
|
||
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
if (NULL != pShape && pShape->m_bIsBackground && !pShape->m_bHaveAnchor)
|
||
{
|
||
pShape->SetupProperties(NULL, pTheme.get(), pLayout);
|
||
|
||
pTheme->m_bIsBackground = true;
|
||
pTheme->m_oBackground = pShape->m_oBrush;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadNoMainMaster(_UINT32 dwMasterID)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_mapMasters.find(dwMasterID);
|
||
|
||
if (pPair == m_mapMasters.end())
|
||
return;
|
||
|
||
CRecordSlide* pCurMaster = pPair->second;
|
||
|
||
if (pCurMaster == NULL)
|
||
return;
|
||
_UINT32 dwCurID = pCurMaster->m_oPersist.m_nSlideID;
|
||
|
||
std::vector<CRecordSlideAtom*> oArraySlideAtoms;
|
||
|
||
pCurMaster->GetRecordsByType(&oArraySlideAtoms, true);
|
||
if (0 == oArraySlideAtoms.size())
|
||
return;
|
||
|
||
bool bMasterColorScheme = oArraySlideAtoms[0]->m_bMasterScheme;
|
||
bool bMasterBackGround = oArraySlideAtoms[0]->m_bMasterBackground;
|
||
bool bMasterObjects = oArraySlideAtoms[0]->m_bMasterObjects;
|
||
|
||
_UINT32 dwID = (_UINT32)oArraySlideAtoms[0]->m_nMasterIDRef;
|
||
|
||
if (0 == dwID)
|
||
{
|
||
std::vector<RoundTripCompositeMasterId12Atom*> oArrayCompId;
|
||
pCurMaster->GetRecordsByType(&oArrayCompId, false, true);
|
||
if (0 != oArrayCompId.size())
|
||
{
|
||
std::map<_UINT32, _UINT32>::iterator pPair1 = m_mapMasterOriginalIds.find(oArrayCompId[0]->m_dwID);
|
||
if (m_mapMasterOriginalIds.end() != pPair1)
|
||
{
|
||
dwID = pPair1->second;
|
||
}
|
||
}
|
||
}
|
||
|
||
// проверяем, если это MainMaster - то его грузим как мастер
|
||
if (0 == dwID)
|
||
{
|
||
// он уже загружен как тема !!!
|
||
return;
|
||
}
|
||
|
||
// теперь аналог функции LoadSlide
|
||
CSlideInfo elm;
|
||
m_arMasterWrapper.push_back(elm);
|
||
|
||
CSlideInfo* pMasterWrapper = &m_arMasterWrapper[m_arMasterWrapper.size() - 1];
|
||
|
||
// pMasterWrapper->m_arTextPlaceHolders = pCurMaster->m_oPersist.m_arTextAttrs;
|
||
pMasterWrapper->m_arTextPlaceHolders.clear();
|
||
for (auto* pTextAttr : pCurMaster->m_oPersist.m_arTextAttrs)
|
||
if (pTextAttr)
|
||
pMasterWrapper->m_arTextPlaceHolders.push_back(*pTextAttr);
|
||
|
||
pMasterWrapper->m_mapFilePictures = &m_pDocumentInfo->m_mapStoreImageFile;
|
||
|
||
if (m_pDocumentInfo->m_arUsers[pCurMaster->m_IndexUser]->m_arOffsetPictures.empty() == false)
|
||
pMasterWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[pCurMaster->m_IndexUser]->m_arOffsetPictures;
|
||
else
|
||
pMasterWrapper->m_parEmptyPictures = &m_pDocumentInfo->m_arUsers[0]->m_arOffsetPictures;
|
||
|
||
std::map<_UINT32, LONG>::iterator pPairTheme = m_mapMasterToTheme.find(dwID);
|
||
|
||
if (m_mapMasterToTheme.end() == pPairTheme)
|
||
return;
|
||
|
||
m_mapMasterToTheme.insert(std::pair<_UINT32, LONG>(dwMasterID, pPairTheme->second));
|
||
|
||
CSlideInfo* pThemeWrapper = &m_arMasterWrapper[pPairTheme->second];
|
||
CTheme* pTheme = m_arThemes[pPairTheme->second].get();
|
||
|
||
std::wstring strLayoutType, strLayoutName;
|
||
ConvertLayoutType(oArraySlideAtoms[0]->m_oLayout, strLayoutType, strLayoutName);
|
||
|
||
CLayout* pLayout = NULL;
|
||
|
||
int lLayoutID = AddNewLayout(pTheme, pCurMaster, false, false);
|
||
|
||
pLayout = pTheme->m_arLayouts[lLayoutID].get();
|
||
pLayout->m_bShowMasterShapes = false;
|
||
pLayout->m_bIsTitleMaster = true;
|
||
|
||
pTheme->m_mapTitleLayout[dwMasterID] = lLayoutID;
|
||
|
||
std::vector<ODRAW::CColor>* pArrayColorScheme = &pTheme->m_arColorScheme;
|
||
// читаем цветовую схему -----------------------------------------------------------
|
||
if (!bMasterColorScheme)
|
||
{
|
||
std::vector<CRecordColorSchemeAtom*> oArrayColors;
|
||
pCurMaster->GetRecordsByType(&oArrayColors, false);
|
||
|
||
pLayout->m_arColorScheme.clear();
|
||
for (size_t i = 0; i < oArrayColors.size(); ++i)
|
||
{
|
||
if (0x01 == oArrayColors[i]->m_oHeader.RecInstance)
|
||
{
|
||
oArrayColors[i]->ToArray(&pLayout->m_arColorScheme);
|
||
pLayout->m_bUseThemeColorScheme = false;
|
||
CorrectColorScheme(pLayout->m_arColorScheme);
|
||
|
||
// проверим на совпадение
|
||
size_t nCountC = pLayout->m_arColorScheme.size();
|
||
size_t nIndexC = 0;
|
||
if (pArrayColorScheme && nCountC == pArrayColorScheme->size())
|
||
{
|
||
for (; nIndexC < nCountC; ++nIndexC)
|
||
{
|
||
if (pLayout->m_arColorScheme[i].IsEqual(pArrayColorScheme->at(i)))
|
||
break;
|
||
}
|
||
}
|
||
|
||
if (nIndexC == nCountC)
|
||
{
|
||
pLayout->m_bUseThemeColorScheme = true;
|
||
pLayout->m_arColorScheme.clear();
|
||
}
|
||
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
std::vector<CRecordHeadersFootersContainer*> oArrayHeadersFootersInfo;
|
||
pCurMaster->GetRecordsByType(&oArrayHeadersFootersInfo, true, false);
|
||
|
||
if (0 != oArrayHeadersFootersInfo.size())
|
||
{
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom)
|
||
{
|
||
pLayout->m_bHasDate = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasTodayDate ||
|
||
oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate;
|
||
pLayout->m_bHasFooter = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasFooter;
|
||
pLayout->m_bHasSlideNumber = oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasSlideNumber;
|
||
|
||
if (oArrayHeadersFootersInfo[0]->m_oHeadersFootersAtom->m_bHasUserDate) pLayout->m_nFormatDate = 2;
|
||
|
||
for (int i = 0; i < 3; i++) pLayout->m_PlaceholdersReplaceString[i] = oArrayHeadersFootersInfo[0]->m_HeadersFootersString[i];
|
||
}
|
||
}
|
||
else
|
||
{//????
|
||
pLayout->m_bHasDate = m_bHasDate;
|
||
pLayout->m_bHasFooter = m_bHasFooter;
|
||
pLayout->m_bHasSlideNumber = m_bHasSlideNumber;
|
||
pLayout->m_nFormatDate = m_nFormatDate;
|
||
for (int i = 0; i < 3; i++) pLayout->m_PlaceholdersReplaceString[i] = m_PlaceholdersReplaceString[i];
|
||
}
|
||
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
pCurMaster->GetRecordsByType(&oArrayStrings, false, false);
|
||
|
||
for (size_t i = 0; i < oArrayStrings.size(); i++)
|
||
{
|
||
if (oArrayStrings[i]->m_oHeader.RecType == 0x0fba)
|
||
{
|
||
pLayout->m_sName = oArrayStrings[i]->m_strText;
|
||
}
|
||
}
|
||
if (pLayout->m_sName.empty()) pLayout->m_sName = strLayoutName;
|
||
|
||
//-------------------------------------------------------------------------------------------------------
|
||
std::vector<CRecordDrawingContainer*> oArrayDrawing;
|
||
pCurMaster->GetRecordsByType(&oArrayDrawing, true);
|
||
|
||
m_current_level = 0;
|
||
m_current_elements = &pLayout->m_arElements;
|
||
|
||
if (!oArrayDrawing.empty())
|
||
{
|
||
for (size_t nIndex = 0; nIndex < oArrayDrawing[0]->m_arRecords.size(); ++nIndex)
|
||
{
|
||
CRecordGroupShapeContainer* pGroup = dynamic_cast<CRecordGroupShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
|
||
if (pGroup)
|
||
{
|
||
LoadGroupShapeContainer(pGroup, NULL, pTheme, pLayout, pThemeWrapper, pMasterWrapper);
|
||
}
|
||
else
|
||
{
|
||
CRecordShapeContainer* pShapeGroup = dynamic_cast<CRecordShapeContainer*>(oArrayDrawing[0]->m_arRecords[nIndex]);
|
||
if (pShapeGroup)
|
||
{
|
||
CElementPtr pElement = pShapeGroup->GetElement(false, &m_oExMedia, pTheme, pLayout, pThemeWrapper, pMasterWrapper);
|
||
|
||
CShapeElement* pShape = dynamic_cast<CShapeElement*>(pElement.get());
|
||
|
||
if (NULL != pShape && pShape->m_bIsBackground && !pShape->m_bHaveAnchor)
|
||
{
|
||
pShape->SetupProperties(NULL, pTheme, pLayout);
|
||
|
||
pLayout->m_bIsBackground = true;
|
||
pLayout->m_oBackground = pShape->m_oBrush;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
if (pLayout->m_bHasSlideNumber)
|
||
{
|
||
if (pLayout->m_mapPlaceholders.find(PT_MasterSlideNumber) == pLayout->m_mapPlaceholders.end())
|
||
{
|
||
AddNewLayoutPlaceholder(pLayout, PT_MasterSlideNumber, 2);
|
||
}
|
||
}
|
||
if (pLayout->m_bHasDate && pLayout->m_nFormatDate == 1)
|
||
{
|
||
if (pLayout->m_mapPlaceholders.find(PT_MasterDate) == pLayout->m_mapPlaceholders.end())
|
||
{
|
||
AddNewLayoutPlaceholder(pLayout, PT_MasterDate, 2);
|
||
}
|
||
}
|
||
if (pLayout->m_bHasFooter)
|
||
{
|
||
if (pLayout->m_mapPlaceholders.find(PT_MasterFooter) == pLayout->m_mapPlaceholders.end())
|
||
{
|
||
AddNewLayoutPlaceholder(pLayout, PT_MasterFooter, 1);
|
||
}
|
||
}
|
||
|
||
}
|
||
|
||
void CPPTUserInfo::LoadSlideFromPrevUsers(_UINT32 dwSlideID)
|
||
{
|
||
if ((NULL == m_pDocumentInfo) || (-1 == m_lIndexThisUser))
|
||
return;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairSlide = m_mapSlides.find(dwSlideID);
|
||
|
||
if (pPairSlide != m_mapSlides.end() && pPairSlide->second)
|
||
return; //есть
|
||
|
||
size_t lUsersCount = m_pDocumentInfo->m_arUsers.size();
|
||
|
||
for (size_t lIndexUser = m_lIndexThisUser + 1; lIndexUser < lUsersCount; ++lIndexUser)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapSlides.find(dwSlideID);
|
||
if (pPair == m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapSlides.end())
|
||
continue;
|
||
|
||
CRecordSlide* pSlideCur = pPair->second;
|
||
if (NULL != pSlideCur)
|
||
{
|
||
pSlideCur->AddRef();
|
||
|
||
pSlideCur->m_IndexUser = lIndexUser;
|
||
|
||
if (pPairSlide != m_mapSlides.end())
|
||
{
|
||
pPairSlide->second = pSlideCur;
|
||
}
|
||
else
|
||
{
|
||
m_mapSlides.insert(m_mapSlides.end(), std::pair<_UINT32, CRecordSlide*>(dwSlideID, pSlideCur));
|
||
m_arrSlidesOrder.push_back(dwSlideID);
|
||
}
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadMasterFromPrevUsers(_UINT32 dwMasterID)
|
||
{
|
||
if ((NULL == m_pDocumentInfo) || (-1 == m_lIndexThisUser))
|
||
return;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairMaster = m_mapMasters.find(dwMasterID);
|
||
|
||
if (pPairMaster != m_mapMasters.end() && pPairMaster->second)
|
||
return;//есть
|
||
|
||
size_t lUsersCount = m_pDocumentInfo->m_arUsers.size();
|
||
|
||
for (size_t lIndexUser = m_lIndexThisUser + 1; lIndexUser < lUsersCount; ++lIndexUser)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapMasters.find(dwMasterID);
|
||
|
||
if (pPair == m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapMasters.end())
|
||
continue;
|
||
|
||
CRecordSlide* pSlideCur = pPair->second;
|
||
if (NULL != pSlideCur)
|
||
{
|
||
pSlideCur->AddRef();
|
||
|
||
//для каждого пользователя СВОИ активные картинки !!!
|
||
pSlideCur->m_IndexUser = lIndexUser;
|
||
|
||
if (pPairMaster != m_mapMasters.end())
|
||
{
|
||
//был найден ранее нулевым
|
||
pPairMaster->second = pSlideCur;
|
||
}
|
||
else
|
||
{
|
||
m_mapMasters.insert(m_mapMasters.end(), std::pair<_UINT32, CRecordSlide*>(dwMasterID, pSlideCur));
|
||
m_arrMastersOrder.push_back(dwMasterID);
|
||
}
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadNotesFromPrevUsers(_UINT32 dwSlideID)
|
||
{
|
||
if ((NULL == m_pDocumentInfo) || (-1 == m_lIndexThisUser))
|
||
return;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairSlide = m_mapNotes.find(dwSlideID);
|
||
|
||
if (pPairSlide != m_mapNotes.end() && pPairSlide->second)
|
||
return; //есть
|
||
|
||
size_t lUsersCount = m_pDocumentInfo->m_arUsers.size();
|
||
|
||
for (size_t lIndexUser = m_lIndexThisUser + 1; lIndexUser < lUsersCount; ++lIndexUser)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapNotes.find(dwSlideID);
|
||
if (pPair == m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapNotes.end())
|
||
continue;
|
||
|
||
CRecordSlide* pSlideCur = pPair->second;
|
||
if (NULL != pSlideCur)
|
||
{
|
||
pSlideCur->AddRef();
|
||
|
||
pSlideCur->m_IndexUser = lIndexUser;
|
||
|
||
if (pPairSlide != m_mapNotes.end())
|
||
{
|
||
pPairSlide->second = pSlideCur;
|
||
}
|
||
else
|
||
{
|
||
m_mapNotes.insert(m_mapSlides.end(), std::pair<_UINT32, CRecordSlide*>(dwSlideID, pSlideCur));
|
||
m_arrNotesOrder.push_back(dwSlideID);
|
||
}
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::LoadNotesMasterFromPrevUsers(_UINT32 dwMasterID)
|
||
{
|
||
if ((NULL == m_pDocumentInfo) || (-1 == m_lIndexThisUser))
|
||
return;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairMaster = m_mapNotesMasters.find(dwMasterID);
|
||
|
||
if (pPairMaster != m_mapNotesMasters.end() && pPairMaster->second)
|
||
return;//есть
|
||
|
||
size_t lUsersCount = m_pDocumentInfo->m_arUsers.size();
|
||
|
||
for (size_t lIndexUser = m_lIndexThisUser + 1; lIndexUser < lUsersCount; ++lIndexUser)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapNotesMasters.find(dwMasterID);
|
||
|
||
if (pPair == m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapNotesMasters.end())
|
||
continue;
|
||
|
||
CRecordSlide* pSlideCur = pPair->second;
|
||
if (NULL != pSlideCur)
|
||
{
|
||
pSlideCur->AddRef();
|
||
|
||
//для каждого пользователя СВОИ активные картинки !!!
|
||
pSlideCur->m_IndexUser = lIndexUser;
|
||
|
||
if (pPairMaster != m_mapNotesMasters.end())
|
||
{
|
||
//был найден ранее нулевым
|
||
pPairMaster->second = pSlideCur;
|
||
}
|
||
else
|
||
{
|
||
m_mapNotesMasters.insert(m_mapNotesMasters.end(), std::pair<_UINT32, CRecordSlide*>(dwMasterID, pSlideCur));
|
||
}
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadHandoutMasterFromPrevUsers(_UINT32 dwMasterID)
|
||
{
|
||
if ((NULL == m_pDocumentInfo) || (-1 == m_lIndexThisUser))
|
||
return;
|
||
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPairMaster = m_mapHandoutMasters.find(dwMasterID);
|
||
|
||
if (pPairMaster != m_mapHandoutMasters.end() && pPairMaster->second)
|
||
return;//есть
|
||
|
||
size_t lUsersCount = m_pDocumentInfo->m_arUsers.size();
|
||
|
||
for (size_t lIndexUser = m_lIndexThisUser + 1; lIndexUser < lUsersCount; ++lIndexUser)
|
||
{
|
||
std::map<_UINT32, CRecordSlide*>::iterator pPair = m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapHandoutMasters.find(dwMasterID);
|
||
|
||
if (pPair == m_pDocumentInfo->m_arUsers[lIndexUser]->m_mapHandoutMasters.end())
|
||
continue;
|
||
|
||
CRecordSlide* pSlideCur = pPair->second;
|
||
if (NULL != pSlideCur)
|
||
{
|
||
pSlideCur->AddRef();
|
||
|
||
//для каждого пользователя СВОИ активные картинки !!!
|
||
pSlideCur->m_IndexUser = lIndexUser;
|
||
|
||
if (pPairMaster != m_mapHandoutMasters.end())
|
||
{
|
||
//был найден ранее нулевым
|
||
pPairMaster->second = pSlideCur;
|
||
}
|
||
else
|
||
{
|
||
m_mapHandoutMasters.insert(m_mapHandoutMasters.end(), std::pair<_UINT32, CRecordSlide*>(dwMasterID, pSlideCur));
|
||
}
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadExternal(CRecordExObjListContainer* pExObjects)
|
||
{
|
||
// читаем SoundCollection
|
||
std::vector<CRecordSoundCollectionContainer*> oArrayCollection;
|
||
m_oDocument.GetRecordsByType(&oArrayCollection, false, true);
|
||
|
||
if (!oArrayCollection.empty())
|
||
{
|
||
std::vector<CRecordSoundContainer*> oArraySounds;
|
||
oArrayCollection[0]->GetRecordsByType(&oArraySounds, false);
|
||
|
||
int nSize = oArraySounds.size();
|
||
|
||
for (int i = 0; i < nSize; ++i)
|
||
{
|
||
std::vector<CRecordCString*> oArrayStrings;
|
||
std::vector<CRecordSoundDataBlob*> oArrayData;
|
||
|
||
oArraySounds[i]->GetRecordsByType(&oArrayStrings, false);
|
||
oArraySounds[i]->GetRecordsByType(&oArrayData, false);
|
||
|
||
if ((3 <= oArrayStrings.size()) && (1 == oArrayData.size()))
|
||
{
|
||
PPT::CExFilesInfo oInfo;
|
||
|
||
oInfo.m_strFilePath = m_oExMedia.m_strPresentationDirectory + FILE_SEPARATOR_STR + L"audio" + std::to_wstring(m_oExMedia.m_arAudioCollection.size() + 1) + L".audio";
|
||
oInfo.m_dwID = (_UINT32)XmlUtils::GetInteger(oArrayStrings[2]->m_strText.c_str());
|
||
oInfo.m_name = oArrayStrings[0]->m_strText;
|
||
oInfo.m_strFileExt = oArrayStrings[1]->m_strText;
|
||
|
||
m_oExMedia.m_arAudioCollection.push_back(oInfo);
|
||
oArrayData[0]->SaveToFile(oInfo.m_strFilePath);
|
||
}
|
||
}
|
||
}
|
||
|
||
if (NULL == pExObjects)
|
||
return;
|
||
|
||
// читаем видео ----------------------------------------------
|
||
std::vector<CRecordExVideoContainer*> oArrayVideo;
|
||
pExObjects->GetRecordsByType(&oArrayVideo, true);
|
||
|
||
for (size_t nIndex = 0; nIndex < oArrayVideo.size(); ++nIndex)
|
||
{
|
||
LoadExVideo(oArrayVideo[nIndex]);
|
||
}
|
||
// читаем ole ----------------------------------------------
|
||
std::vector<CRecordExOleEmbedContainer*> oArrayObj;
|
||
pExObjects->GetRecordsByType(&oArrayObj, true);
|
||
|
||
for (size_t nIndex = 0; nIndex < oArrayObj.size(); ++nIndex)
|
||
{
|
||
LoadExOleObject(oArrayObj[nIndex]);
|
||
}
|
||
oArrayObj.clear();
|
||
// -----------------------------------------------------------
|
||
|
||
// читаем аудио ----------------------------------------------
|
||
std::vector<CRecordExCDAudioContainer*> oArrayAudioCD;
|
||
std::vector<CRecordExMIDIAudioContainer*> oArrayAudioMIDI;
|
||
std::vector<CRecordWAVAudioLinkContainer*> oArrayWAVLink;
|
||
std::vector<CRecordWAVAudioEmbeddedContainer*> oArrayAudioEmbedded;
|
||
|
||
pExObjects->GetRecordsByType(&oArrayAudioCD, true);
|
||
pExObjects->GetRecordsByType(&oArrayAudioMIDI, true);
|
||
pExObjects->GetRecordsByType(&oArrayWAVLink, true);
|
||
pExObjects->GetRecordsByType(&oArrayAudioEmbedded, true);
|
||
|
||
for (size_t nIndex = 0; nIndex < oArrayAudioMIDI.size(); ++nIndex)
|
||
{
|
||
LoadExAudio(oArrayAudioMIDI[nIndex]);
|
||
}
|
||
for (size_t nIndex = 0; nIndex < oArrayWAVLink.size(); ++nIndex)
|
||
{
|
||
LoadExAudio(oArrayWAVLink[nIndex]);
|
||
}
|
||
for (size_t nIndex = 0; nIndex < oArrayAudioEmbedded.size(); ++nIndex)
|
||
{
|
||
_UINT32 dwKeySound = oArrayAudioEmbedded[nIndex]->m_nSoundID;
|
||
_UINT32 dwKeyObj = oArrayAudioEmbedded[nIndex]->m_oMedia.m_nExObjID;
|
||
|
||
PPT::CExFilesInfo* pInfo = m_oExMedia.LockAudioFromCollection(dwKeySound);
|
||
if (NULL != pInfo)
|
||
{
|
||
PPT::CExFilesInfo oAudio;
|
||
|
||
oAudio.m_dwID = dwKeyObj;
|
||
oAudio.m_strFilePath = pInfo->m_strFilePath;
|
||
oAudio.m_bLoop = oArrayAudioEmbedded[nIndex]->m_oMedia.m_bLoop;
|
||
|
||
m_oExMedia.m_arAudios.push_back(oAudio);
|
||
}
|
||
}
|
||
for (size_t nIndex = 0; nIndex < oArrayAudioCD.size(); ++nIndex)
|
||
{
|
||
_UINT32 dwKeyObj = oArrayAudioCD[nIndex]->m_oMedia.m_nExObjID;
|
||
|
||
PPT::CExFilesInfo* pInfo = m_oExMedia.LockAudio(dwKeyObj);
|
||
|
||
if (NULL != pInfo)
|
||
{
|
||
pInfo->m_dStartTime = oArrayAudioCD[nIndex]->m_dStartTime;
|
||
pInfo->m_dEndTime = oArrayAudioCD[nIndex]->m_dEndTime;
|
||
pInfo->m_bLoop = oArrayAudioCD[nIndex]->m_oMedia.m_bLoop;
|
||
}
|
||
}
|
||
|
||
//--------------------------------------------------------------------
|
||
|
||
std::vector<CRecordExHyperlinkContainer*> oArrayHyperlinkContainer;
|
||
pExObjects->GetRecordsByType(&oArrayHyperlinkContainer, true);
|
||
|
||
for (const auto* pExHyperlink : oArrayHyperlinkContainer)
|
||
{
|
||
if (!pExHyperlink || !pExHyperlink->hasCString())
|
||
continue;
|
||
|
||
PPT::CExFilesInfo oInfo;
|
||
oInfo.m_dwID = pExHyperlink->m_exHyperlinkAtom.m_nHyperlinkID;
|
||
|
||
bool wasSlide = false;
|
||
// bool wasLink = false;
|
||
|
||
// it isn't normal that here we should catch slide number.
|
||
if (pExHyperlink->m_friendlyNameAtom.IsInit())
|
||
{
|
||
std::wstring& recStr = pExHyperlink->m_friendlyNameAtom->m_strText;
|
||
int slideNum = oInfo.GetSlideNumber(recStr);
|
||
if (slideNum != -1)
|
||
{
|
||
oInfo.m_strFilePath = recStr;
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftSlide;
|
||
m_oExMedia.m_arSlides.push_back(oInfo);
|
||
wasSlide = true;
|
||
} /*else if (oInfo.isHTTPLink(recStr))
|
||
{
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftHyperlink;
|
||
m_oExMedia.m_arSlides.push_back(oInfo);
|
||
}*/
|
||
}
|
||
|
||
if (pExHyperlink->m_targetAtom.IsInit())
|
||
{
|
||
std::wstring& recStr = pExHyperlink->m_targetAtom->m_strText;
|
||
oInfo.m_strFilePath = recStr;
|
||
if (oInfo.isAudioLink(recStr))
|
||
{
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftAudio;
|
||
m_oExMedia.m_arAudioCollection.push_back(oInfo);
|
||
}
|
||
else if (oInfo.isHTTPLink(recStr))
|
||
{
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftHyperlink;
|
||
m_oExMedia.m_arHyperlinks.push_back(oInfo);
|
||
}
|
||
else {
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftHyperlink;
|
||
m_oExMedia.m_arHyperlinks.push_back(oInfo);
|
||
}
|
||
}
|
||
|
||
if (pExHyperlink->m_locationAtom.IsInit())
|
||
{
|
||
// Here we need to write some records like file's path and slides
|
||
std::wstring& recStr = pExHyperlink->m_locationAtom->m_strText;
|
||
oInfo.m_strFilePath = recStr;
|
||
if (!wasSlide)
|
||
{
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftSlide;
|
||
m_oExMedia.m_arSlides.push_back(oInfo);
|
||
}
|
||
else if (!m_oExMedia.m_arSlides.empty())
|
||
{
|
||
oInfo.m_type = CExFilesInfo::ExFilesType::eftSlide;
|
||
m_oExMedia.m_arSlides.back().m_strFilePath = recStr;
|
||
}
|
||
}
|
||
|
||
}
|
||
}
|
||
void CPPTUserInfo::LoadExOleObject(CRecordsContainer* pExObject)
|
||
{
|
||
//exOleEmbedAtom
|
||
//exOleObjAtom
|
||
//menuNameAtom
|
||
//progIdAtom
|
||
//clipboardNameAtom
|
||
//metafile(variable)
|
||
|
||
std::vector<CRecordExOleEmbedAtom*> oArrayExOleEmbed;
|
||
std::vector<CRecordExOleObjAtom*> oArrayExOleObj;
|
||
std::vector<CRecordCString*> oArrayCString;
|
||
|
||
pExObject->GetRecordsByType(&oArrayExOleEmbed, false);
|
||
pExObject->GetRecordsByType(&oArrayExOleObj, false);
|
||
pExObject->GetRecordsByType(&oArrayCString, false);
|
||
|
||
if (1 == oArrayExOleObj.size())
|
||
{
|
||
PPT::CExFilesInfo oInfo;
|
||
|
||
oInfo.m_dwID = oArrayExOleObj[0]->m_nExObjID;
|
||
|
||
if (oArrayCString.size() > 0)
|
||
oInfo.m_name = oArrayCString[0]->m_strText;
|
||
|
||
if (oArrayCString.size() > 1)
|
||
oInfo.m_progName = oArrayCString[1]->m_strText;
|
||
|
||
oInfo.m_strFilePath = m_pDocumentInfo->GetBinFromStg(L"", oArrayExOleObj[0]->m_nPersistID); // ExOleObjStg || ExControlStg
|
||
|
||
m_oExMedia.m_arOleObjects.push_back(oInfo);
|
||
}
|
||
|
||
oArrayExOleEmbed.clear();
|
||
oArrayExOleObj.clear();
|
||
oArrayCString.clear();
|
||
}
|
||
|
||
void CPPTUserInfo::LoadExVideo(CRecordsContainer* pExObject)
|
||
{
|
||
std::vector<CRecordExMediaAtom*> oArrayExMedia;
|
||
std::vector<CRecordCString*> oArrayCString;
|
||
|
||
pExObject->GetRecordsByType(&oArrayExMedia, false);
|
||
pExObject->GetRecordsByType(&oArrayCString, false);
|
||
|
||
if ((1 == oArrayExMedia.size()) && (1 == oArrayCString.size()))
|
||
{
|
||
PPT::CExFilesInfo oInfo;
|
||
|
||
oInfo.m_dwID = oArrayExMedia[0]->m_nExObjID;
|
||
oInfo.m_strFilePath = oArrayCString[0]->m_strText;
|
||
|
||
oInfo.m_bLoop = oArrayExMedia[0]->m_bLoop;
|
||
|
||
m_oExMedia.m_arVideos.push_back(oInfo);
|
||
}
|
||
|
||
oArrayExMedia.clear();
|
||
oArrayCString.clear();
|
||
}
|
||
void CPPTUserInfo::LoadExAudio(CRecordsContainer* pExObject)
|
||
{
|
||
std::vector<CRecordExMediaAtom*> oArrayExMedia;
|
||
std::vector<CRecordCString*> oArrayCString;
|
||
|
||
pExObject->GetRecordsByType(&oArrayExMedia, false);
|
||
pExObject->GetRecordsByType(&oArrayCString, false);
|
||
|
||
if ((1 == oArrayExMedia.size()) && (1 == oArrayCString.size()))
|
||
{
|
||
PPT::CExFilesInfo oInfo;
|
||
|
||
oInfo.m_dwID = oArrayExMedia[0]->m_nExObjID;
|
||
oInfo.m_strFilePath = oArrayCString[0]->m_strText;
|
||
|
||
oInfo.m_bLoop = oArrayExMedia[0]->m_bLoop;
|
||
|
||
oInfo.m_fNarration = oArrayExMedia[0]->m_bNarration;
|
||
oInfo.m_fRewind = oArrayExMedia[0]->m_bRewind;
|
||
|
||
m_oExMedia.m_arAudios.push_back(oInfo);
|
||
}
|
||
|
||
oArrayExMedia.clear();
|
||
oArrayCString.clear();
|
||
}
|
||
|
||
//void CPPTUserInfo::AddAnimation ( _UINT32 dwSlideID, double Width, double Height, CElementPtr pElement )
|
||
//{
|
||
// std::map <_UINT32, Animations::CSlideTimeLine*>::iterator pPair = m_mapAnimations.find( dwSlideID );
|
||
|
||
// if (pPair == m_mapAnimations.end()) return;
|
||
|
||
// Animations::CSlideTimeLine* pTimeLine = pPair->second;
|
||
// if (pTimeLine == NULL) return;
|
||
|
||
// std::map <_UINT32, Animations::Effects*>::iterator pPairA = pTimeLine->GetAnimation().find ( pElement->m_lID );
|
||
// if (pPairA == pTimeLine->GetAnimation().end()) return;
|
||
|
||
// Animations::Effects* arEffects = pPairA->second;
|
||
// if (arEffects == NULL) return;
|
||
|
||
// for ( long i = 0; i < (long)arEffects->size(); ++i )
|
||
// {
|
||
// CAnimationSimple oEffect = arEffects->at(i);
|
||
// CAnimationSimple oAnimation = oEffect;
|
||
|
||
// oAnimation.m_dTimeAccel = oEffect.m_nDuration * oEffect.m_dTimeAccel;
|
||
// oAnimation.m_dTimeDecel = oEffect.m_nDuration * oEffect.m_dTimeDecel;
|
||
|
||
// if (0 == oEffect.m_nSchemeColor) // RGB
|
||
// {
|
||
// oAnimation.m_nColorTo = oEffect.m_nColorTo;
|
||
// }
|
||
// else if (2 == oEffect.m_nSchemeColor) // Index From Table
|
||
// {
|
||
// if ((int)oAnimation.m_nColorTo >= (int)m_oSchemeColors.size())
|
||
// continue;
|
||
|
||
// oAnimation.m_nColorTo = m_oSchemeColors[oEffect.m_nColorTo].GetLONG();
|
||
// }
|
||
|
||
// pElement->m_oAnimations.m_dSlideWidth = Width;
|
||
// pElement->m_oAnimations.m_dSlideHeight = Height;
|
||
|
||
// pElement->m_oAnimations.m_arAnimations.push_back ( oAnimation );
|
||
// }
|
||
//}
|
||
|
||
void CPPTUserInfo::AddAudioTransition(_UINT32 refID, CTransition* pTransition, const std::wstring& strFilePath)
|
||
{
|
||
if (NULL == pTransition)
|
||
return;
|
||
|
||
std::vector<CRecordSoundCollectionContainer*> sound;
|
||
m_oDocument.GetRecordsByType(&sound, false);
|
||
if (sound.empty() || sound[0]->m_arRecords.size() <= refID)
|
||
return;
|
||
|
||
auto audio = dynamic_cast<CRecordSoundContainer*>(sound[0]->m_arRecords[refID]);
|
||
if (!audio)
|
||
return;
|
||
auto strRecord = dynamic_cast<CRecordCString*>(audio->m_arRecords[0]);
|
||
|
||
std::wstring audioName = strRecord->m_strText;
|
||
;
|
||
// audioName.erase(audioName.find(L"."), audioName.end()); todo
|
||
if (strRecord)
|
||
pTransition->m_oAudio.m_sImageName = audioName;
|
||
|
||
// ??? недоделка ???
|
||
}
|
||
|
||
void CPPTUserInfo::CreateDefaultStyle(PPT::CTextStyles& pStyle, PPT::CTheme* pTheme)
|
||
{
|
||
for (int i = 0; i < 10; ++i)
|
||
{
|
||
if (!pStyle.m_pLevels[i].is_init())
|
||
pStyle.m_pLevels[i] = new PPT::CTextStyleLevel();
|
||
|
||
PPT::CTextPFRun* pPF = &pStyle.m_pLevels[i]->m_oPFRun;
|
||
PPT::CTextCFRun* pCF = &pStyle.m_pLevels[i]->m_oCFRun;
|
||
|
||
pCF->Language = m_wLanguage;
|
||
|
||
pCF->Size = 18;
|
||
|
||
pCF->font.font = new PPT::CFontProperty(pTheme->m_arFonts.size() > 1 ? pTheme->m_arFonts[1] : pTheme->m_arFonts[0]);
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::CorrectColorScheme(std::vector<CColor>& oScheme)
|
||
{
|
||
if (oScheme.size() < 1) return;
|
||
|
||
std::vector<CColor> oArrayMem;
|
||
oArrayMem.push_back(oScheme[0]);//0
|
||
oArrayMem.push_back(oScheme[1]);//1
|
||
oArrayMem.push_back(oScheme[2]);//2
|
||
oArrayMem.push_back(oScheme[3]);//3
|
||
oArrayMem.push_back(oScheme[0]);//4
|
||
oArrayMem.push_back(oScheme[4]);//5 //accent1
|
||
oArrayMem.push_back(oScheme[5]);//6 //accent2
|
||
oArrayMem.push_back(CColor(0xAAAAAA));//(oScheme[0]);//7 //accent3
|
||
oArrayMem.push_back(CColor(0xDCDCDC));//(oScheme[5]);//8 //accent4
|
||
oArrayMem.push_back(CColor(0xDBF1FA));//(oScheme[4]);//9 //accent5
|
||
oArrayMem.push_back(CColor(0x4B9DCA));//(oScheme[7]);//10 //accent6
|
||
oArrayMem.push_back(oScheme[6]);//11 //hlink
|
||
oArrayMem.push_back(oScheme[7]);//12 //folHlink
|
||
oArrayMem.push_back(oScheme[0]);//13 //lt1
|
||
oArrayMem.push_back(oScheme[1]);//14 //dk1
|
||
oArrayMem.push_back(oScheme[2]);//15 //lt2
|
||
oArrayMem.push_back(oScheme[3]);//16 //dk2
|
||
|
||
//0x00 //Background color
|
||
//0x01 //Text color
|
||
//0x02 //Shadow color
|
||
//0x03 //Title text color
|
||
//0x04 //Fill color
|
||
//0x05 //Accent 1 color
|
||
//0x06 //Accent 2 color
|
||
//0x07 //Accent 3 color
|
||
|
||
oScheme = oArrayMem;
|
||
}
|
||
|
||
void CPPTUserInfo::ConvertLayoutType(SSlideLayoutAtom& layoutRecord, std::wstring& type, std::wstring& name)
|
||
{
|
||
name = L"Blank Slide";
|
||
type = L"blank";
|
||
|
||
switch (layoutRecord.m_nGeom)
|
||
{
|
||
case SL_TitleSlide:
|
||
case SL_MasterTitle:
|
||
{
|
||
name = L"Title Slide";
|
||
type = L"title";
|
||
}break;
|
||
case SL_TitleBody:
|
||
{
|
||
name = L"Title and Object Slide";
|
||
type = L"obj";
|
||
|
||
int ind = 0;
|
||
if (layoutRecord.m_pPlaceHolderID[0] == 13 && layoutRecord.m_pPlaceHolderID[1] != 0) ind++;
|
||
PlaceholderEnum phbody = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[ind];
|
||
switch (phbody)
|
||
{
|
||
case PT_MasterTitle: type = L"title"; name = L"Title and Object Slide"; break;
|
||
case PT_Table: type = L"tbl"; name = L"Title and Table Slide"; break;
|
||
case PT_OrgChart: type = L"dgm"; name = L"Title and Diagramma Slide"; break;
|
||
case PT_Graph: type = L"chart"; name = L"Title and Chart Slide"; break;
|
||
default:
|
||
break;
|
||
}
|
||
}break;
|
||
case SL_TitleOnly:
|
||
{
|
||
name = L"Title Only Slide";
|
||
type = L"titleOnly";
|
||
}break;
|
||
case SL_TwoColumns:
|
||
{
|
||
PlaceholderEnum leftType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[1];
|
||
PlaceholderEnum rightType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[2];
|
||
|
||
name = L"Two Objects Slide";
|
||
type = L"twoObj";
|
||
|
||
if (leftType == PT_Body && rightType == PT_Object)
|
||
{
|
||
name = L"Text And Object Slide";
|
||
type = L"txAndObj";
|
||
}
|
||
else if (leftType == PT_Object && rightType == PT_Body)
|
||
{
|
||
name = L"Object And Text Slide";
|
||
type = L"objAndTx";
|
||
}
|
||
else if (leftType == PT_Body && rightType == PT_ClipArt)
|
||
{
|
||
name = L"Text And ClipArt Slide";
|
||
type = L"txAndClipArt";
|
||
}
|
||
else if (leftType == PT_ClipArt && rightType == PT_Body)
|
||
{
|
||
name = L"ClipArt And Text Slide";
|
||
type = L"clipArtAndTx";
|
||
}
|
||
else if (leftType == PT_Body && rightType == PT_Graph)
|
||
{
|
||
name = L"Text And Chart Slide";
|
||
type = L"txAndChart";
|
||
}
|
||
else if (leftType == PT_Graph && rightType == PT_Body)
|
||
{
|
||
name = L"Chart And Text Slide";
|
||
type = L"chartAndTx";
|
||
}
|
||
else if (leftType == PT_Body && rightType == PT_Media)
|
||
{
|
||
name = L"Text And Media Slide";
|
||
type = L"txAndMedia";
|
||
}
|
||
else if (leftType == PT_Media && rightType == PT_Body)
|
||
{
|
||
name = L"Media And Text Slide";
|
||
type = L"mediaAndTx";
|
||
}
|
||
}break;
|
||
case SL_TwoRows:
|
||
{
|
||
PlaceholderEnum topType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[1];
|
||
PlaceholderEnum bottomType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[2];
|
||
|
||
if (topType == PT_Body && bottomType == PT_Object)
|
||
{
|
||
name = L"Text Over Object Slide";
|
||
type = L"txOverObj";
|
||
}
|
||
else
|
||
{
|
||
name = L"Object Over Text Slide";
|
||
type = L"objOverTx";
|
||
}
|
||
}break;
|
||
case SL_ColumnTwoRows:
|
||
{
|
||
PlaceholderEnum leftType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[1];
|
||
|
||
if (leftType == PT_Object)
|
||
{
|
||
type = L"objAndTwoObj";
|
||
}
|
||
else
|
||
{
|
||
type = L"txAndTwoObj";
|
||
}
|
||
}break;
|
||
case SL_TwoRowsColumn:
|
||
{
|
||
PlaceholderEnum rightType = (PlaceholderEnum)layoutRecord.m_pPlaceHolderID[2];
|
||
|
||
if (rightType == PT_Object)
|
||
{
|
||
type = L"twoObjAndObj";
|
||
}
|
||
else
|
||
{
|
||
type = L"twoObjAndTx";
|
||
}
|
||
}break;
|
||
case SL_TwoColumnsRow:
|
||
{
|
||
type = L"twoObjOverTx";
|
||
}break;
|
||
case SL_FourObjects:
|
||
{
|
||
type = L"fourObj";
|
||
}break;
|
||
case SL_BigObject:
|
||
{
|
||
name = L"Object Only Slide";
|
||
type = L"objOnly";
|
||
}break;
|
||
case SL_VerticalTitleBody:
|
||
{
|
||
type = L"vertTitleAndTx";
|
||
}break;
|
||
case SL_VerticalTwoRows:
|
||
{
|
||
type = L"vertTx";
|
||
}break;
|
||
case SL_Blank:
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::LoadAutoNumbering(CRecordGroupShapeContainer* pGroupContainer, CTheme* pTheme)
|
||
{
|
||
|
||
std::vector<CRecordOfficeArtClientData*> arrOfficeArtClientData;
|
||
pGroupContainer->GetRecordsByType(&arrOfficeArtClientData, true);
|
||
|
||
for (auto childOfficeArtClientData : arrOfficeArtClientData)
|
||
{
|
||
for (auto prog : childOfficeArtClientData->m_rgShapeClientRoundtripData)
|
||
{
|
||
if (prog->m_pTagName && prog->m_pTagContainer && prog->m_pTagName->m_strText == ___PPT9)
|
||
{
|
||
auto styleTextPropAtom = dynamic_cast<CRecordPP9ShapeBinaryTagExtension*>(prog->m_pTagContainer)->m_styleTextPropAtom;
|
||
for (auto& prop9 : styleTextPropAtom.m_rgStyleTextProp9)
|
||
{
|
||
if (prop9.m_pf9.m_optBulletAutoNumberScheme.is_init())
|
||
{
|
||
CBulletAutoNum bullet;
|
||
|
||
bullet.type = prop9.m_pf9.m_optBulletAutoNumberScheme->SchemeToStr();
|
||
bullet.startAt = prop9.m_pf9.m_optBulletAutoNumberScheme->m_nStartNum;
|
||
pTheme->m_arBullet.push_back(bullet);
|
||
}
|
||
}
|
||
}
|
||
|
||
}
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::LoadBulletBlip(CShapeElement* pShape)
|
||
{
|
||
if (pShape == nullptr || pShape->m_pShape == nullptr) return;
|
||
std::vector<CRecordDocInfoListContainer*> arrDocInfoCont;
|
||
m_oDocument.GetRecordsByType(&arrDocInfoCont, false, true);
|
||
|
||
if (arrDocInfoCont.empty())
|
||
return;
|
||
auto& arrPars = pShape->m_pShape->m_oText.m_arParagraphs;
|
||
|
||
// TODO need to find BlipEntity;
|
||
IRecord* pRecPPT9 = arrDocInfoCont[0]->getDocBinaryTagExtension(___PPT9);
|
||
auto* pProgBinaryTag = dynamic_cast<CRecordPP9DocBinaryTagExtension*>(pRecPPT9);
|
||
if (pProgBinaryTag == nullptr || !pProgBinaryTag->m_blipCollectionContainer.is_init())
|
||
return;
|
||
|
||
const auto& arrBlipEntity = pProgBinaryTag->m_blipCollectionContainer.get().m_rgBlipEntityAtom;
|
||
// const auto& arrAutoNum = pProgBinaryTag->m_outlineTextPropsContainer.get()
|
||
if (arrBlipEntity.empty())
|
||
return;
|
||
|
||
for (auto& par : arrPars)
|
||
{
|
||
if (par.m_oPFRun.bulletBlip.IsInit())
|
||
{
|
||
auto& buBlip = par.m_oPFRun.bulletBlip.get();
|
||
if (buBlip.bulletBlipRef >= 0 && (UINT)buBlip.bulletBlipRef < arrBlipEntity.size())
|
||
{
|
||
buBlip.tmpImagePath = arrBlipEntity[buBlip.bulletBlipRef]->getTmpImgPath();
|
||
}
|
||
}
|
||
|
||
}
|
||
}
|
||
|
||
void CPPTUserInfo::LoadAutoNumBullet(CShapeElement* pShape, int slideID)
|
||
{
|
||
if (pShape == nullptr || pShape->m_pShape == nullptr) return;
|
||
std::vector<CRecordDocInfoListContainer*> arrDocInfoCont;
|
||
m_oDocument.GetRecordsByType(&arrDocInfoCont, false, true);
|
||
|
||
if (arrDocInfoCont.empty())
|
||
return;
|
||
auto& arrPars = pShape->m_pShape->m_oText.m_arParagraphs;
|
||
|
||
// TODO need to find BlipEntity;
|
||
IRecord* pRecPPT9 = arrDocInfoCont[0]->getDocBinaryTagExtension(___PPT9);
|
||
auto* pProgBinaryTag = dynamic_cast<CRecordPP9DocBinaryTagExtension*>(pRecPPT9);
|
||
if (pProgBinaryTag == nullptr)
|
||
return;
|
||
|
||
const auto& optOutlineCont = pProgBinaryTag->m_outlineTextPropsContainer;
|
||
if (optOutlineCont.IsInit() == false)
|
||
return;
|
||
|
||
const auto& vecOutline9Entry = optOutlineCont->m_rgOutlineTextProps9Entry;
|
||
std::vector<SStyleTextProp9>* arrStyleTextProp9 = nullptr;
|
||
for (const auto& entry : vecOutline9Entry)
|
||
if ((int)entry->m_slideIdRef == slideID)
|
||
{
|
||
arrStyleTextProp9 = &(entry->m_styleTextProp9Atom.m_rgStyleTextProp9);
|
||
break;
|
||
}
|
||
if (!arrStyleTextProp9)
|
||
return;
|
||
|
||
|
||
WORD pp9rt = 0;
|
||
for (auto& par : arrPars)
|
||
{
|
||
if (par.m_arSpans.empty())
|
||
continue;
|
||
|
||
if (par.m_arSpans[0].m_oRun.pp9rt.is_init())
|
||
pp9rt = par.m_arSpans[0].m_oRun.pp9rt.get();
|
||
|
||
if (pp9rt >= arrStyleTextProp9->size())
|
||
continue;
|
||
|
||
auto& prop9 = (*arrStyleTextProp9)[pp9rt];
|
||
|
||
if (prop9.m_pf9.m_optBulletAutoNumberScheme.is_init() &&
|
||
prop9.m_pf9.m_optfBulletHasAutoNumber.get_value_or(false))
|
||
{
|
||
auto* pBuAutoNum = new CBulletAutoNum;
|
||
pBuAutoNum->type = prop9.m_pf9.m_optBulletAutoNumberScheme->SchemeToStr();
|
||
pBuAutoNum->startAt = prop9.m_pf9.m_optBulletAutoNumberScheme->m_nStartNum;
|
||
|
||
par.m_oPFRun.bulletAutoNum.reset(pBuAutoNum);
|
||
}
|
||
if (prop9.m_pf9.m_optBulletBlipRef.is_init())
|
||
{
|
||
auto* pBuBlip = new CBulletBlip;
|
||
if (prop9.m_pf9.m_optBulletBlipRef.IsInit())
|
||
pBuBlip->bulletBlipRef = prop9.m_pf9.m_optBulletBlipRef.get();
|
||
else
|
||
pBuBlip->bulletBlipRef = -1;
|
||
|
||
par.m_oPFRun.bulletBlip.reset(pBuBlip);
|
||
}
|
||
}
|
||
}
|