gdi32: Reimplement the 16-bit metafile functions on top of the 32-bit ones.

This commit is contained in:
Alexandre Julliard 2009-11-17 19:58:02 +01:00
parent 4990ca0ea3
commit d9700b6a77
3 changed files with 45 additions and 97 deletions

View File

@ -449,9 +449,6 @@ extern BOOL GDI_hdc_not_using_object(HGDIOBJ obj, HDC hdc) DECLSPEC_HIDDEN;
/* metafile.c */ /* metafile.c */
extern HMETAFILE MF_Create_HMETAFILE(METAHEADER *mh) DECLSPEC_HIDDEN; extern HMETAFILE MF_Create_HMETAFILE(METAHEADER *mh) DECLSPEC_HIDDEN;
extern METAHEADER *MF_CreateMetaHeaderDisk(METAHEADER *mr, LPCVOID filename, BOOL unicode ) DECLSPEC_HIDDEN; extern METAHEADER *MF_CreateMetaHeaderDisk(METAHEADER *mr, LPCVOID filename, BOOL unicode ) DECLSPEC_HIDDEN;
extern METAHEADER *MF_ReadMetaFile(HANDLE hfile) DECLSPEC_HIDDEN;
extern METAHEADER *MF_LoadDiskBasedMetaFile(METAHEADER *mh) DECLSPEC_HIDDEN;
extern BOOL MF_PlayMetaFile( HDC hdc, METAHEADER *mh) DECLSPEC_HIDDEN;
/* path.c */ /* path.c */

View File

@ -175,7 +175,7 @@ BOOL WINAPI DeleteMetaFile( HMETAFILE hmf )
* Returns a pointer to a memory based METAHEADER read in from file HFILE * Returns a pointer to a memory based METAHEADER read in from file HFILE
* *
*/ */
METAHEADER *MF_ReadMetaFile(HANDLE hfile) static METAHEADER *MF_ReadMetaFile(HANDLE hfile)
{ {
METAHEADER *mh; METAHEADER *mh;
DWORD BytesRead, size; DWORD BytesRead, size;
@ -266,7 +266,7 @@ HMETAFILE WINAPI GetMetaFileW( LPCWSTR lpFilename )
* *
* Creates a new memory-based metafile from a disk-based one. * Creates a new memory-based metafile from a disk-based one.
*/ */
METAHEADER *MF_LoadDiskBasedMetaFile(METAHEADER *mh) static METAHEADER *MF_LoadDiskBasedMetaFile(METAHEADER *mh)
{ {
METAHEADERDISK *mhd; METAHEADERDISK *mhd;
HANDLE hfile; HANDLE hfile;
@ -384,7 +384,7 @@ HMETAFILE WINAPI CopyMetaFileA( HMETAFILE hSrcMetaFile, LPCSTR lpFilename )
* *
* Helper for PlayMetaFile * Helper for PlayMetaFile
*/ */
BOOL MF_PlayMetaFile( HDC hdc, METAHEADER *mh) static BOOL MF_PlayMetaFile( HDC hdc, METAHEADER *mh)
{ {
METARECORD *mr; METARECORD *mr;

View File

@ -30,12 +30,15 @@
#include "wine/wingdi16.h" #include "wine/wingdi16.h"
#include "wownt32.h" #include "wownt32.h"
#include "winreg.h" #include "winreg.h"
#include "winternl.h"
#include "gdi_private.h"
#include "wine/debug.h" #include "wine/debug.h"
WINE_DEFAULT_DEBUG_CHANNEL(metafile); WINE_DEFAULT_DEBUG_CHANNEL(metafile);
#define METAFILE_MEMORY 1
#define METAFILE_DISK 2
#define MFHEADERSIZE (sizeof(METAHEADER))
#define MFVERSION 0x300
/****************************************************************** /******************************************************************
* MF_GetMetaHeader16 * MF_GetMetaHeader16
* *
@ -58,26 +61,38 @@ static BOOL16 MF_ReleaseMetaHeader16( HMETAFILE16 hmf )
} }
/****************************************************************** /******************************************************************
* MF_Create_HMETATFILE16 * create_metafile16
* *
* Creates a HMETAFILE16 object from a METAHEADER * Create a 16-bit metafile from a 32-bit one. The 32-bit one is deleted.
*
* HMETAFILE16s are Global memory handles.
*/ */
static HMETAFILE16 MF_Create_HMETAFILE16(METAHEADER *mh) static HMETAFILE16 create_metafile16( HMETAFILE hmf )
{ {
HMETAFILE16 hmf; UINT size;
DWORD size = mh->mtSize * sizeof(WORD); HMETAFILE16 hmf16;
hmf = GlobalAlloc16(GMEM_MOVEABLE, size); if (!hmf) return 0;
if(hmf) size = GetMetaFileBitsEx( hmf, 0, NULL );
hmf16 = GlobalAlloc16( GMEM_MOVEABLE, size );
if (hmf16)
{ {
METAHEADER *mh_dest = GlobalLock16(hmf); void *buffer = GlobalLock16( hmf16 );
memcpy(mh_dest, mh, size); GetMetaFileBitsEx( hmf, size, buffer );
GlobalUnlock16(hmf); GlobalUnlock16( hmf16 );
} }
HeapFree(GetProcessHeap(), 0, mh); DeleteMetaFile( hmf );
return hmf; return hmf16;
}
/******************************************************************
* create_metafile32
*
* Create a 32-bit metafile from a 16-bit one.
*/
static HMETAFILE create_metafile32( HMETAFILE16 hmf16 )
{
METAHEADER *mh = MF_GetMetaHeader16( hmf16 );
if (!mh) return 0;
return SetMetaFileBitsEx( mh->mtSize * 2, (BYTE *)mh );
} }
/********************************************************************** /**********************************************************************
@ -93,23 +108,7 @@ HDC16 WINAPI CreateMetaFile16( LPCSTR filename )
*/ */
HMETAFILE16 WINAPI CloseMetaFile16(HDC16 hdc) HMETAFILE16 WINAPI CloseMetaFile16(HDC16 hdc)
{ {
HMETAFILE16 hmf16 = 0; return create_metafile16( CloseMetaFile( HDC_32(hdc) ));
HMETAFILE hmf = CloseMetaFile( HDC_32(hdc) );
if (hmf)
{
UINT size = GetMetaFileBitsEx( hmf, 0, NULL );
hmf16 = GlobalAlloc16( GMEM_MOVEABLE, size );
if (hmf16)
{
void *buffer = GlobalLock16( hmf16 );
GetMetaFileBitsEx( hmf, size, buffer );
GlobalUnlock16( hmf16 );
}
DeleteMetaFile( hmf );
}
return hmf16;
} }
/****************************************************************** /******************************************************************
@ -125,22 +124,7 @@ BOOL16 WINAPI DeleteMetaFile16( HMETAFILE16 hmf )
*/ */
HMETAFILE16 WINAPI GetMetaFile16( LPCSTR lpFilename ) HMETAFILE16 WINAPI GetMetaFile16( LPCSTR lpFilename )
{ {
METAHEADER *mh; return create_metafile16( GetMetaFileA( lpFilename ));
HANDLE hFile;
TRACE("%s\n", lpFilename);
if(!lpFilename)
return 0;
if((hFile = CreateFileA(lpFilename, GENERIC_READ, FILE_SHARE_READ, NULL,
OPEN_EXISTING, 0, 0)) == INVALID_HANDLE_VALUE)
return 0;
mh = MF_ReadMetaFile(hFile);
CloseHandle(hFile);
if(!mh) return 0;
return MF_Create_HMETAFILE16( mh );
} }
/****************************************************************** /******************************************************************
@ -148,35 +132,10 @@ HMETAFILE16 WINAPI GetMetaFile16( LPCSTR lpFilename )
*/ */
HMETAFILE16 WINAPI CopyMetaFile16( HMETAFILE16 hSrcMetaFile, LPCSTR lpFilename) HMETAFILE16 WINAPI CopyMetaFile16( HMETAFILE16 hSrcMetaFile, LPCSTR lpFilename)
{ {
METAHEADER *mh = MF_GetMetaHeader16( hSrcMetaFile ); HMETAFILE hmf = create_metafile32( hSrcMetaFile );
METAHEADER *mh2 = NULL; HMETAFILE hmf2 = CopyMetaFileA( hmf, lpFilename );
HANDLE hFile; DeleteMetaFile( hmf );
return create_metafile16( hmf2 );
TRACE("(%08x,%s)\n", hSrcMetaFile, lpFilename);
if(!mh) return 0;
if(mh->mtType == METAFILE_DISK)
mh2 = MF_LoadDiskBasedMetaFile(mh);
else {
mh2 = HeapAlloc( GetProcessHeap(), 0, mh->mtSize * 2 );
memcpy( mh2, mh, mh->mtSize * 2 );
}
MF_ReleaseMetaHeader16( hSrcMetaFile );
if(lpFilename) { /* disk based metafile */
DWORD w;
if((hFile = CreateFileA(lpFilename, GENERIC_WRITE, 0, NULL,
CREATE_ALWAYS, 0, 0)) == INVALID_HANDLE_VALUE) {
HeapFree( GetProcessHeap(), 0, mh2 );
return 0;
}
WriteFile(hFile, mh2, mh2->mtSize * 2, &w, NULL);
CloseHandle(hFile);
mh2 = MF_CreateMetaHeaderDisk(mh2, lpFilename, FALSE);
}
return MF_Create_HMETAFILE16( mh2 );
} }
/****************************************************************** /******************************************************************
@ -212,12 +171,11 @@ BOOL16 WINAPI IsValidMetaFile16(HMETAFILE16 hmf)
* PlayMetaFile (GDI.123) * PlayMetaFile (GDI.123)
* *
*/ */
BOOL16 WINAPI PlayMetaFile16( HDC16 hdc, HMETAFILE16 hmf ) BOOL16 WINAPI PlayMetaFile16( HDC16 hdc, HMETAFILE16 hmf16 )
{ {
BOOL16 ret; HMETAFILE hmf = create_metafile32( hmf16 );
METAHEADER *mh = MF_GetMetaHeader16( hmf ); BOOL ret = PlayMetaFile( HDC_32(hdc), hmf );
ret = MF_PlayMetaFile( HDC_32(hdc), mh ); DeleteMetaFile( hmf );
MF_ReleaseMetaHeader16( hmf );
return ret; return ret;
} }
@ -241,16 +199,11 @@ BOOL16 WINAPI EnumMetaFile16( HDC16 hdc16, HMETAFILE16 hmf,
HBRUSH hBrush; HBRUSH hBrush;
HFONT hFont; HFONT hFont;
WORD args[8]; WORD args[8];
BOOL16 result = TRUE, loaded = FALSE; BOOL16 result = TRUE;
TRACE("(%p, %04x, %p, %08lx)\n", hdc, hmf, lpEnumFunc, lpData); TRACE("(%p, %04x, %p, %08lx)\n", hdc, hmf, lpEnumFunc, lpData);
if(!mh) return FALSE; if(!mh) return FALSE;
if(mh->mtType == METAFILE_DISK) { /* Create a memory-based copy */
mh = MF_LoadDiskBasedMetaFile(mh);
if(!mh) return FALSE;
loaded = TRUE;
}
/* save the current pen, brush and font */ /* save the current pen, brush and font */
hPen = GetCurrentObject(hdc, OBJ_PEN); hPen = GetCurrentObject(hdc, OBJ_PEN);
@ -308,8 +261,6 @@ BOOL16 WINAPI EnumMetaFile16( HDC16 hdc16, HMETAFILE16 hmf,
/* free handle table */ /* free handle table */
GlobalFree16(hHT); GlobalFree16(hHT);
if(loaded)
HeapFree( GetProcessHeap(), 0, mh );
MF_ReleaseMetaHeader16(hmf); MF_ReleaseMetaHeader16(hmf);
return result; return result;
} }