⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 scemf.h

📁 Source code for EMFexplorer 1.0
💻 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 + -