📄 scemf.h
字号:
/*
* This file is part of the EMFexplorer projet.
* Copyright (C) 2004 Smith Charles.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*
* Extension: for commercial use, apply the Equity Public License, which
* adds to the normal terms of the GLPL a condition of donation to the author.
* If you are interested in support for this source code,
* contact Smith Charles <smith.charles@free.fr> for more information.
*/
#ifndef _SCEMF_H_
#define _SCEMF_H_
#include <vector>
#define WMFMETA_PLACEABLEKEY 0x9AC6CDD7
// Aldus placable metafile header
// Article ID: Q66949
#pragma pack(2)
typedef struct
{
DWORD key;
WORD hmf;
SMALL_RECT bbox;
WORD inch;
DWORD reserved;
WORD checksum;
} APMFILEHEADER;
#pragma pack()
typedef std::vector<HENHMETAFILE, std::allocator<HENHMETAFILE> > HEMFVECTOR;
typedef BOOL (*fnSCPlayEnhMetaFile)(HDC hDC, HENHMETAFILE hemf, LPCRECT pRect);
BOOL SCGetEMFPlaySize(HENHMETAFILE hEMF, CSize& sizeEMF, HDC hDC=NULL, float* pfScale=NULL);
BOOL SCGetEMFElemsRect(HENHMETAFILE hEMF, CRect& rcElems, fnSCPlayEnhMetaFile fnPlayEMF=NULL);
void GetEMFDimension(HDC hDC, ENHMETAHEADER &emfh, int & width, int & height);
BOOL SCComputeEMFBlackBox(HENHMETAFILE hemf, CRect& ElemsRect, fnSCPlayEnhMetaFile fnPlayEMF=NULL);
BOOL SCGetEMFDPIs(HENHMETAFILE hEMF, long &lDPIX, long &lDPIY);
BOOL SCGetEMFInfos(HENHMETAFILE hEMF, long &lDPIX, long &lDPIY, long &lPaperCx, long &lPaperCy);
BOOL SCScaleImgSurface(HDC hDC, long lImgDPIX, long lImgDPIY, long &lImgCx, long &lImgCy);
HENHMETAFILE SCConvertWMFtoEMF(LPCTSTR lpszFname);
HENHMETAFILE SCConvertWMFtoEMF(DWORD dwSize, LPBYTE pBuffer);
HENHMETAFILE SCCloseEMF(HDC& hEMFDC);
void SCEMFDCDispose(HDC& hEMFDC);
void SCInitEMFDCForEnumeration(HDC hEMFDC, ENHMETAHEADER &hEmfHeader, HDC hDCRef);
BOOL SCPreFilterEMF(HENHMETAFILE& hEmf);
BOOL SCUpdateEMFheader(HENHMETAFILE& hemf, ENHMETAHEADER& rEmfHeader);
UINT SCConvertRTFtoEMF(LPCTSTR lpszFname, HEMFVECTOR& rVector, BOOL bRTF=TRUE);
UINT SCConvertRTFtoEMF(HANDLE hMem, HEMFVECTOR& rVector, BOOL bRTF=TRUE);
UINT SCConvertClipboardTextToEMF(HEMFVECTOR& rVector);
inline BOOL SCWriteEMFtoDisk(HENHMETAFILE hEmf, LPCTSTR szFileName)
{
HENHMETAFILE hEmfCopy = CopyEnhMetaFile(hEmf,(LPCTSTR)szFileName);
if (hEmfCopy)
DeleteEnhMetaFile(hEmfCopy);
return (hEmfCopy!=NULL);
}
void SCConvertEMFtoWMF(HENHMETAFILE hEMF, LPCTSTR lpszFileName);
void SCRectDPtoHIMETRIC(CDC* pDC, RECT* pRect);
void SCRectLPtoHIMETRIC(CDC* pDC, RECT* pRect);
void SCRectToTwips(RECT* pRect, int ilogx, int ilogy, CDC* pDC);
#endif //_SCEMF_H_
// ------------------------------------------------------------
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -