690 lines
20 KiB
C++
690 lines
20 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 "imagemanager.h"
|
|
|
|
#ifndef DISABLE_FILE_DOWNLOADER
|
|
#include "../../../Common/Network/FileTransporter/include/FileTransporter.h"
|
|
#endif
|
|
|
|
#include <list>
|
|
#include "../../../DesktopEditor/graphics/pro/Image.h"
|
|
#include "../../../DesktopEditor/raster/ImageFileFormatChecker.h"
|
|
#include "../../../OfficeUtils/src/OfficeUtils.h"
|
|
#include "../../../DesktopEditor/common/Directory.h"
|
|
|
|
#include "../../SystemUtility/File.h"
|
|
#include "../../SystemUtility/SystemUtility.h"
|
|
|
|
#include "../../Base/Unit.h"
|
|
|
|
namespace NSShapeImageGen
|
|
{
|
|
const long c_nMaxImageSize = 2000;
|
|
|
|
CMediaManager::CMediaManager()
|
|
{
|
|
m_lMaxSizeImage = c_nMaxImageSize;
|
|
m_lNextIDImage = 0;
|
|
m_lDstFormat = 0;
|
|
m_pFontManager = NULL;
|
|
}
|
|
CMediaManager::~CMediaManager()
|
|
{
|
|
m_pFontManager = NULL;
|
|
}
|
|
|
|
CMediaInfo CMediaManager::WriteImage(CBgraFrame& oImage, double& x, double& y, double& width, double& height)
|
|
{
|
|
CMediaInfo info;
|
|
|
|
if (height < 0)
|
|
{
|
|
FlipY(oImage);
|
|
height = -height;
|
|
y -= height;
|
|
}
|
|
|
|
return GenerateImageID(oImage, (std::max)(1.0, width), (std::max)(1.0, height));
|
|
}
|
|
CMediaInfo CMediaManager::WriteImage(const std::string& strFile, double& x, double& y, double& width, double& height, const std::wstring& strAdditionalFile, int typeAdditionalFile)
|
|
{
|
|
if (width < 0 && height < 0)
|
|
return GenerateImageID(strFile, L"", -1, -1, strAdditionalFile, typeAdditionalFile);
|
|
|
|
return GenerateImageID(strFile, L"", (std::max)(1.0, width), (std::max)(1.0, height), strAdditionalFile, typeAdditionalFile);
|
|
}
|
|
CMediaInfo CMediaManager::WriteImage(const std::wstring& strFile, double& x, double& y, double& width, double& height, const std::wstring& strAdditionalFile, int typeAdditionalFile)
|
|
{
|
|
bool bIsDownload = false;
|
|
int n1 = (int)strFile.find(L"www");
|
|
int n2 = (int)strFile.find(L"http");
|
|
int n3 = (int)strFile.find(L"ftp");
|
|
int n4 = (int)strFile.find(L"https");
|
|
|
|
//если nI сранивать не с 0, то будут проблемы
|
|
//потому что в инсталяции мы кладем файлы в /var/www...
|
|
if (0 == n1 || 0 == n2 || 0 == n3 || 0 == n4)
|
|
bIsDownload = true;
|
|
|
|
if (bIsDownload)
|
|
{
|
|
std::wstring strFileUrl = strFile;
|
|
|
|
XmlUtils::replace_all(strFileUrl, L"\\", L"/");
|
|
XmlUtils::replace_all(strFileUrl, L"http:/", L"http://");
|
|
XmlUtils::replace_all(strFileUrl, L"https:/", L"https://");
|
|
XmlUtils::replace_all(strFileUrl, L"ftp:/", L"ftp://");
|
|
|
|
CMediaInfo oInfo;
|
|
std::map<std::wstring, CMediaInfo>::iterator pPair = m_mapMediaFiles.find(strFileUrl);
|
|
|
|
if (pPair != m_mapMediaFiles.end())
|
|
return pPair->second;
|
|
|
|
std::wstring strDownload;
|
|
|
|
#ifndef DISABLE_FILE_DOWNLOADER
|
|
NSNetwork::NSFileTransport::CFileDownloader oDownloader(strFileUrl, true);
|
|
if (oDownloader.DownloadSync())
|
|
{
|
|
strDownload = oDownloader.GetFilePath();
|
|
|
|
CImageFileFormatChecker checker;
|
|
if (false == checker.isImageFile(strDownload))
|
|
{
|
|
strDownload.clear();
|
|
}
|
|
}
|
|
#endif
|
|
return GenerateImageID(strDownload, strFileUrl, (std::max)(1.0, width), (std::max)(1.0, height), strAdditionalFile, typeAdditionalFile);
|
|
}
|
|
|
|
if (strAdditionalFile.empty())
|
|
{
|
|
CMediaInfo info;
|
|
NSFile::CFileBinary oFile;
|
|
if (false == oFile.OpenFile(strFile) && std::wstring::npos == strFile.find(L"data:base64,"))
|
|
{
|
|
return info;
|
|
}
|
|
oFile.CloseFile();
|
|
}
|
|
|
|
|
|
if (width < 0 && height < 0)
|
|
return GenerateImageID(strFile, L"", -1, -1, strAdditionalFile, typeAdditionalFile);
|
|
|
|
return GenerateImageID(strFile, L"", (std::max)(1.0, width), (std::max)(1.0, height), strAdditionalFile, typeAdditionalFile);
|
|
}
|
|
CMediaInfo CMediaManager::WriteMedia(const std::wstring& strFile)
|
|
{
|
|
bool bIsDownload = false;
|
|
int n1 = (int)strFile.find (L"www");
|
|
int n2 = (int)strFile.find (L"http");
|
|
int n3 = (int)strFile.find (L"ftp");
|
|
int n4 = (int)strFile.find (L"https");
|
|
|
|
//если nI сранивать не с 0, то будут проблемы
|
|
//потому что в инсталяции мы кладем файлы в /var/www...
|
|
if (0 == n1 || 0 == n2 || 0 == n3 || 0 == n4)
|
|
bIsDownload = true;
|
|
|
|
if (bIsDownload)
|
|
{
|
|
std::wstring strFileUrl = strFile;
|
|
|
|
XmlUtils::replace_all(strFileUrl, L"\\", L"/");
|
|
XmlUtils::replace_all(strFileUrl, L"http:/", L"http://");
|
|
XmlUtils::replace_all(strFileUrl, L"https:/", L"https://");
|
|
XmlUtils::replace_all(strFileUrl, L"ftp:/", L"ftp://");
|
|
|
|
|
|
CMediaInfo oInfo;
|
|
std::map<std::wstring, CMediaInfo>::iterator pPair = m_mapMediaFiles.find(strFileUrl);
|
|
|
|
if (pPair != m_mapMediaFiles.end())
|
|
return pPair->second;
|
|
|
|
std::wstring strDownload;
|
|
|
|
#ifndef DISABLE_FILE_DOWNLOADER
|
|
NSNetwork::NSFileTransport::CFileDownloader oDownloader(strFileUrl, true);
|
|
if (oDownloader.DownloadSync())
|
|
{
|
|
strDownload = oDownloader.GetFilePath();
|
|
|
|
CImageFileFormatChecker checker;
|
|
if (false == checker.isImageFile(strDownload))
|
|
{
|
|
strDownload.clear();
|
|
}
|
|
}
|
|
#endif
|
|
return GenerateMediaID(strDownload, strFileUrl);
|
|
}
|
|
|
|
return GenerateMediaID(strFile, L"");
|
|
}
|
|
void CMediaManager::SetFontManager(NSFonts::IFontManager* pFontManager)
|
|
{
|
|
m_pFontManager = pFontManager;
|
|
}
|
|
|
|
void CMediaManager::SaveImage(const std::wstring& strFileName, CMediaInfo& oInfo, LONG __width, LONG __height)
|
|
{
|
|
bool result = false;
|
|
CImageFileFormatChecker checker;
|
|
|
|
std::wstring sTempUnpacked;
|
|
std::wstring strFileSrc = strFileName;
|
|
|
|
COfficeUtils officeUtils(NULL);
|
|
|
|
bool bIsImage = checker.isImageFile(strFileSrc);
|
|
|
|
if (false == bIsImage && true == officeUtils.IsArchive(strFileSrc))
|
|
{
|
|
sTempUnpacked = m_strTempMedia + FILE_SEPARATOR_STR + L"zip_unpacked";
|
|
NSDirectory::CreateDirectory(sTempUnpacked);
|
|
|
|
if (S_OK == officeUtils.ExtractToDirectory(strFileSrc, sTempUnpacked, NULL, 0))
|
|
{
|
|
std::vector<std::wstring> arrFiles = NSDirectory::GetFiles(sTempUnpacked, false);
|
|
if (1 == arrFiles.size())
|
|
{
|
|
strFileSrc = arrFiles[0];
|
|
}
|
|
}
|
|
else
|
|
{//gzip
|
|
BYTE *pData = NULL;
|
|
DWORD nBytesCount = 0;
|
|
|
|
NSFile::CFileBinary file;
|
|
if (file.ReadAllBytes(strFileSrc, &pData, nBytesCount))
|
|
{
|
|
ULONG nBytesUncompress = nBytesCount * 10;
|
|
BYTE* pDataUncompress = new BYTE[nBytesUncompress];
|
|
if (S_OK == officeUtils.Uncompress(pDataUncompress, &nBytesUncompress, pData, nBytesCount))
|
|
{
|
|
std::wstring tempFile = NSFile::CFileBinary::CreateTempFileWithUniqueName(sTempUnpacked, L"img");
|
|
file.CreateFileW(tempFile);
|
|
file.WriteFile(pDataUncompress, nBytesUncompress);
|
|
file.CloseFile();
|
|
|
|
strFileSrc = tempFile;
|
|
}
|
|
if (pDataUncompress) delete []pDataUncompress; pDataUncompress = NULL;
|
|
if (pData) delete []pData; pData = NULL;
|
|
}
|
|
}
|
|
|
|
bIsImage = checker.isImageFile(strFileSrc);
|
|
}
|
|
if (bIsImage)
|
|
{
|
|
if (checker.eFileType == _CXIMAGE_FORMAT_JPG)
|
|
{
|
|
oInfo.m_eType = itJPG;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else if (checker.eFileType == _CXIMAGE_FORMAT_GIF)
|
|
{
|
|
oInfo.m_eType = itGIF;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else if (checker.eFileType == _CXIMAGE_FORMAT_PNG)
|
|
{
|
|
oInfo.m_eType = itPNG;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else if (checker.eFileType == _CXIMAGE_FORMAT_WMF)
|
|
{
|
|
oInfo.m_eType = itWMF;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else if (checker.eFileType == _CXIMAGE_FORMAT_EMF)
|
|
{
|
|
oInfo.m_eType = itEMF;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else if (checker.eFileType == _CXIMAGE_FORMAT_SVG)
|
|
{
|
|
oInfo.m_eType = itSVG;
|
|
|
|
OOX::CPath pathSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileSrc, pathSaveItem.GetPath());
|
|
|
|
result = true;
|
|
}
|
|
else
|
|
{
|
|
CBgraFrame oBgraFrame;
|
|
if (oBgraFrame.OpenFile(strFileSrc) == true)
|
|
{
|
|
SaveImage(oBgraFrame, oInfo, __width, __height);
|
|
|
|
result = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (false == result)
|
|
{
|
|
//конвертация неудачная - берем оригинальный файл
|
|
OOX::CPath pathOriginal = strFileSrc;
|
|
|
|
//default is itJPG. set itUnknown to use original extension
|
|
oInfo.m_eType = itUnknown;
|
|
oInfo.m_sExt = pathOriginal.GetExtention();
|
|
|
|
std::wstring strSaveItem = oInfo.GetPathWithoutExtension();
|
|
|
|
strSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + strSaveItem + pathOriginal.GetExtention();
|
|
|
|
CDirectory::CopyFile(strFileSrc, strSaveItem);
|
|
}
|
|
|
|
if (false == sTempUnpacked.empty())
|
|
{
|
|
NSDirectory::DeleteDirectory(sTempUnpacked);
|
|
}
|
|
}
|
|
void CMediaManager::SaveImage(CBgraFrame& oBgraFrame, CMediaInfo& oInfo, LONG __width, LONG __height)
|
|
{
|
|
LONG lWidth = oBgraFrame.get_Width();
|
|
LONG lHeight = oBgraFrame.get_Height();
|
|
|
|
oInfo.m_eType = GetImageType(oBgraFrame);
|
|
|
|
std::wstring strSaveItem = L"";
|
|
unsigned int nOutputFormat;
|
|
if (itJPG == oInfo.m_eType)
|
|
{
|
|
strSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
nOutputFormat = _CXIMAGE_FORMAT_JPG;
|
|
}
|
|
else
|
|
{
|
|
oInfo.m_eType = itPNG;
|
|
strSaveItem = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
nOutputFormat = _CXIMAGE_FORMAT_PNG;
|
|
}
|
|
OOX::CPath pathSaveItem = strSaveItem;
|
|
|
|
LONG lMaxSize = (std::min)((std::max)(lWidth, lHeight), m_lMaxSizeImage);
|
|
|
|
if (!((lWidth <= lMaxSize) && (lHeight <= lMaxSize)))
|
|
{
|
|
LONG lW = 0;
|
|
LONG lH = 0;
|
|
double dAspect = (double)lWidth / lHeight;
|
|
|
|
if (lWidth >= lHeight)
|
|
{
|
|
lW = lMaxSize;
|
|
lH = (LONG)((double)lW / dAspect);
|
|
}
|
|
else
|
|
{
|
|
lH = lMaxSize;
|
|
lW = (LONG)(dAspect * lH);
|
|
}
|
|
|
|
oBgraFrame.Resize(lW, lH);
|
|
}
|
|
oBgraFrame.SaveFile(std::wstring(pathSaveItem.GetPath()), nOutputFormat);
|
|
}
|
|
|
|
CMediaInfo CMediaManager::GenerateImageID(CBgraFrame& punkData, double dWidth, double dHeight)
|
|
{
|
|
CMediaInfo oInfo;
|
|
|
|
LONG lWidth = (LONG)(dWidth * 96 / 25.4);
|
|
LONG lHeight = (LONG)(dHeight * 96 / 25.4);
|
|
|
|
BYTE* pBuffer = punkData.get_Data();
|
|
LONG lLen = 4 * punkData.get_Width() * punkData.get_Height();
|
|
|
|
DWORD dwSum = m_oCRC.Calc(pBuffer, lLen);
|
|
|
|
std::map<DWORD, CMediaInfo>::iterator pPair = m_mapMediaData.find(dwSum);
|
|
if (m_mapMediaData.end() == pPair)
|
|
{
|
|
// нужно добавить
|
|
++m_lNextIDImage;
|
|
|
|
oInfo.m_lID = m_lNextIDImage;
|
|
SaveImage(punkData, oInfo, lWidth, lHeight);
|
|
|
|
m_mapMediaData.insert(std::make_pair(dwSum, oInfo));
|
|
}
|
|
else
|
|
{
|
|
oInfo = pPair->second;
|
|
}
|
|
|
|
return oInfo;
|
|
}
|
|
CMediaInfo CMediaManager::GenerateImageID(std::string strFileName, const std::wstring & strUrl, double dWidth, double dHeight, const std::wstring& strAdditionalFile, int typeAdditionalFile)
|
|
{
|
|
if (0 == strFileName.find("data:base64,"))
|
|
{
|
|
int nHeaderSize = 12;
|
|
int nBase64DataSize = (int)strFileName.length() - nHeaderSize;
|
|
|
|
int dstLen = NSBase64::Base64DecodeGetRequiredLength(nBase64DataSize);
|
|
BYTE* pDstBuffer = new BYTE[dstLen];
|
|
NSBase64::Base64Decode(strFileName.c_str() + nHeaderSize, nBase64DataSize, pDstBuffer, &dstLen);
|
|
|
|
CImageFileFormatChecker checker;
|
|
std::wstring sImageExtension = checker.DetectFormatByData(pDstBuffer, dstLen);
|
|
std::wstring tempFilePath = m_strTempMedia + FILE_SEPARATOR_STR;
|
|
|
|
std::wstring strFileNameNew = NSFile::CFileBinary::CreateTempFileWithUniqueName(tempFilePath, L"img") + L"." + sImageExtension;
|
|
|
|
NSFile::CFileBinary oTempFile;
|
|
oTempFile.CreateFile(strFileNameNew);
|
|
oTempFile.WriteFile((void*)pDstBuffer, (DWORD)dstLen);
|
|
oTempFile.CloseFile();
|
|
|
|
RELEASEARRAYOBJECTS(pDstBuffer);
|
|
|
|
return GenerateImageID(strFileNameNew, strUrl, dWidth, dHeight, strAdditionalFile, typeAdditionalFile);
|
|
}
|
|
return CMediaInfo();
|
|
}
|
|
CMediaInfo CMediaManager::GenerateImageID(std::wstring strFileName, const std::wstring & strUrl, double dWidth, double dHeight, const std::wstring& strAdditionalFile, int typeAdditionalFile)
|
|
{
|
|
if (0 == strFileName.find(L"data:base64,"))
|
|
{
|
|
int nHeaderSize = 12;
|
|
int nBase64DataSize = (int)strFileName.length() - nHeaderSize;
|
|
|
|
int dstLen = NSBase64::Base64DecodeGetRequiredLength(nBase64DataSize);
|
|
BYTE* pDstBuffer = new BYTE[dstLen];
|
|
NSBase64::Base64Decode(strFileName.c_str() + nHeaderSize, nBase64DataSize, pDstBuffer, &dstLen);
|
|
|
|
CImageFileFormatChecker checker;
|
|
std::wstring sImageExtension = checker.DetectFormatByData(pDstBuffer, dstLen);
|
|
std::wstring tempFilePath = m_strTempMedia + FILE_SEPARATOR_STR;
|
|
|
|
strFileName = NSFile::CFileBinary::CreateTempFileWithUniqueName(tempFilePath, L"img") + L"." + sImageExtension;
|
|
|
|
NSFile::CFileBinary oTempFile;
|
|
oTempFile.CreateFile(strFileName);
|
|
oTempFile.WriteFile((void*)pDstBuffer, (DWORD)dstLen);
|
|
oTempFile.CloseFile();
|
|
|
|
RELEASEARRAYOBJECTS(pDstBuffer);
|
|
}
|
|
|
|
std::wstring sMapKey = strFileName;
|
|
|
|
if(!strUrl.empty()) sMapKey = strUrl;
|
|
if(!strAdditionalFile.empty()) sMapKey += strAdditionalFile;
|
|
|
|
CMediaInfo oInfo;
|
|
std::map<std::wstring, CMediaInfo>::iterator pPair = m_mapMediaFiles.find(sMapKey);
|
|
|
|
LONG lWidth = (LONG)(dWidth * 96 / 25.4);
|
|
LONG lHeight = (LONG)(dHeight * 96 / 25.4);
|
|
|
|
if (m_mapMediaFiles.end() == pPair)
|
|
{
|
|
++m_lNextIDImage;
|
|
oInfo.m_lID = m_lNextIDImage;
|
|
|
|
LONG lImageType = m_oImageExt.GetImageType(strFileName);
|
|
|
|
bool bVector = (1 == lImageType || 2 == lImageType);
|
|
|
|
bool bOle = !strAdditionalFile.empty() && (typeAdditionalFile == 1);
|
|
bool bMedia = !strAdditionalFile.empty() && (typeAdditionalFile == 2);
|
|
|
|
if (bVector)
|
|
oInfo.m_eType = (1 == lImageType) ? itWMF : itEMF;
|
|
|
|
oInfo.SetNameModificator(oInfo.m_eType, typeAdditionalFile);
|
|
|
|
std::wstring strSaveDir = m_strDstMedia + FILE_SEPARATOR_STR;
|
|
std::wstring strSaveItemWE = strSaveDir + oInfo.GetPathWithoutExtension();
|
|
|
|
// copy ole bin or media
|
|
if (bOle || bMedia)
|
|
{
|
|
std::wstring strExts;
|
|
int nIndexExt = (int)strAdditionalFile.rfind(wchar_t('.'));
|
|
if (-1 != nIndexExt)
|
|
strExts = strAdditionalFile.substr(nIndexExt);
|
|
|
|
if(bOle && strExts.empty()) strExts = L".bin";
|
|
|
|
std::wstring sCopyOlePath = strSaveItemWE + strExts;
|
|
CDirectory::CopyFile(strAdditionalFile, sCopyOlePath);
|
|
}
|
|
|
|
if (bVector)
|
|
{
|
|
//copy source vector image
|
|
OOX::CPath pathSaveItem = strSaveDir + oInfo.GetPath2();
|
|
CDirectory::CopyFile(strFileName, pathSaveItem.GetPath());
|
|
|
|
::MetaFile::IMetaFile* pMetafile = MetaFile::Create(m_pFontManager->GetApplication());
|
|
|
|
if (pMetafile->LoadFromFile(strFileName.c_str()))
|
|
{
|
|
// пробуем сохранить в svg напрямую из метафайлов
|
|
std::wstring sInternalSvg = pMetafile->ConvertToSvg(lWidth, lHeight);
|
|
|
|
if (!sInternalSvg.empty())
|
|
{
|
|
NSFile::CFileBinary::SaveToFile(strSaveItemWE + L".svg", sInternalSvg);
|
|
m_mapMediaFiles.insert(std::make_pair(sMapKey, oInfo));
|
|
|
|
RELEASEOBJECT(pMetafile);
|
|
return oInfo;
|
|
}
|
|
|
|
// не смогли сконвертировать в svg.
|
|
// пробуем в png
|
|
|
|
std::wstring strSaveItem = strSaveItemWE + L".png";
|
|
pMetafile->ConvertToRaster(strSaveItem.c_str(), 4 /*CXIMAGE_FORMAT_PNG*/, lWidth, lHeight);
|
|
|
|
if (NSFile::CFileBinary::Exists(strSaveItem))
|
|
{
|
|
oInfo.m_eType = itPNG;
|
|
|
|
m_mapMediaFiles.insert(std::make_pair(sMapKey, oInfo));
|
|
|
|
RELEASEOBJECT(pMetafile);
|
|
return oInfo;
|
|
}
|
|
}
|
|
RELEASEOBJECT(pMetafile);
|
|
}
|
|
|
|
SaveImage(strFileName, oInfo, lWidth, lHeight);
|
|
m_mapMediaFiles.insert(std::make_pair(sMapKey, oInfo));
|
|
}
|
|
else
|
|
{
|
|
oInfo = pPair->second;
|
|
}
|
|
|
|
return oInfo;
|
|
}
|
|
|
|
CMediaInfo CMediaManager::GenerateMediaID(const std::wstring& strFileName, const std::wstring& strUrl)
|
|
{
|
|
std::wstring sMapKey;
|
|
|
|
if(!strUrl.empty()) sMapKey = strUrl;
|
|
else sMapKey = strFileName;
|
|
|
|
CMediaInfo oInfo;
|
|
std::map<std::wstring, CMediaInfo>::iterator pFind = m_mapMediaFiles.find(sMapKey);
|
|
|
|
if (m_mapMediaFiles.end() == pFind)
|
|
{
|
|
++m_lNextIDImage;
|
|
oInfo.m_lID = m_lNextIDImage;
|
|
|
|
oInfo.m_eType = itMedia;
|
|
oInfo.m_sName = L"media";
|
|
|
|
std::wstring strSaveItemWE = m_strDstMedia + FILE_SEPARATOR_STR + oInfo.GetPath2();
|
|
|
|
int nIndexExt = (int)strFileName.rfind(wchar_t('.'));
|
|
if (-1 != nIndexExt)
|
|
oInfo.m_sExt = strFileName.substr(nIndexExt);
|
|
|
|
std::wstring strCopyMediaPath = strSaveItemWE + oInfo.m_sExt;
|
|
|
|
CDirectory::CopyFile(strFileName, strCopyMediaPath);
|
|
|
|
m_mapMediaFiles.insert(std::make_pair(sMapKey, oInfo));
|
|
}
|
|
else
|
|
{
|
|
oInfo = pFind->second;
|
|
}
|
|
|
|
return oInfo;
|
|
}
|
|
|
|
MediaType CMediaManager::GetImageType(CBgraFrame& pFrame)
|
|
{
|
|
if (2 == m_lDstFormat)
|
|
return itJPG;
|
|
|
|
LONG lWidth = pFrame.get_Width();
|
|
LONG lHeight = pFrame.get_Height();
|
|
BYTE* pBuffer = pFrame.get_Data();
|
|
|
|
BYTE* pBufferMem = pBuffer + 3;
|
|
LONG lCountPix = lWidth * lHeight;
|
|
|
|
for (LONG i = 0; i < lCountPix; ++i, pBufferMem += 4)
|
|
{
|
|
if (255 != *pBufferMem)
|
|
return itPNG;
|
|
}
|
|
return itJPG;
|
|
}
|
|
void CMediaManager::FlipY(CBgraFrame& punkImage)
|
|
{
|
|
BYTE* pBuffer = punkImage.get_Data();
|
|
LONG lWidth = punkImage.get_Width();
|
|
LONG lHeight = punkImage.get_Height();
|
|
LONG lStride = punkImage.get_Stride();
|
|
|
|
if (lStride < 0)
|
|
lStride = -lStride;
|
|
|
|
if ((lWidth * 4) != lStride)
|
|
return;
|
|
|
|
BYTE* pBufferMem = new BYTE[lStride];
|
|
|
|
BYTE* pBufferEnd = pBuffer + lStride * (lHeight - 1);
|
|
|
|
LONG lCountV = lHeight / 2;
|
|
|
|
for (LONG lIndexV = 0; lIndexV < lCountV; ++lIndexV)
|
|
{
|
|
memcpy(pBufferMem, pBuffer, lStride);
|
|
memcpy(pBuffer, pBufferEnd, lStride);
|
|
memcpy(pBufferEnd, pBufferMem, lStride);
|
|
|
|
pBuffer += lStride;
|
|
pBufferEnd -= lStride;
|
|
}
|
|
|
|
RELEASEARRAYOBJECTS(pBufferMem);
|
|
}
|
|
void CMediaManager::FlipX(CBgraFrame& punkImage)
|
|
{
|
|
BYTE* pBuffer = punkImage.get_Data();
|
|
LONG lWidth = punkImage.get_Width();
|
|
LONG lHeight = punkImage.get_Height();
|
|
LONG lStride = punkImage.get_Stride();
|
|
|
|
if (lStride < 0)
|
|
lStride = -lStride;
|
|
|
|
if ((lWidth * 4) != lStride)
|
|
{
|
|
return;
|
|
}
|
|
|
|
DWORD* pBufferDWORD = (DWORD*)pBuffer;
|
|
|
|
LONG lW2 = lWidth / 2;
|
|
for (LONG lIndexV = 0; lIndexV < lHeight; ++lIndexV)
|
|
{
|
|
DWORD* pMem1 = pBufferDWORD;
|
|
DWORD* pMem2 = pBufferDWORD + lWidth - 1;
|
|
|
|
LONG lI = 0;
|
|
while (lI < lW2)
|
|
{
|
|
DWORD dwMem = *pMem1;
|
|
*pMem1++ = *pMem2;
|
|
*pMem2-- = dwMem;
|
|
}
|
|
}
|
|
}
|
|
}
|