2020-09-30 16:53:55 +02:00

1024 lines
30 KiB
C

/****************************** Module Header ******************************\
* Module Name: DRAW.C
*
* PURPOSE: Contains all the drawing related routines
*
* Created: March 1991
*
* Copyright (c) 1990, 1991 Microsoft Corporation
*
* History:
* (03/21/91) Srinik Original
* (03/22/91) Srinik Added support for drawing metafile in a metafile
*
\***************************************************************************/
#include <windows.h>
#include "dll.h"
#include "pict.h"
#define RECORD_COUNT 16
int INTERNAL PaletteSize (int);
HANDLE INTERNAL DibMakeLogPalette(LPSTR, WORD, LPLOGPALETTE FAR *);
OLESTATUS FARINTERNAL wDibDraw (HANDLE, HDC, LPRECT, LPRECT, HDC, BOOL);
OLESTATUS INTERNAL wDrawBitmap (LPOBJECT_BM, HDC, HDC, LPRECT);
OLESTATUS INTERNAL wDrawBitmapUsingDib (LPOBJECT_BM, HDC, HDC, HDC, LPRECT, LPRECT);
void SetPictOrg (LPOBJECT_MF, HDC, int, int, BOOL);
void SetPictExt (LPOBJECT_MF, HDC, int, int);
void ScalePictExt (LPOBJECT_MF, HDC, int, int, int, int);
void ScaleRectExt (LPOBJECT_MF, HDC, int, int, int, int);
void CleanStack(LPOBJECT_MF, HANDLE);
BOOL PopDc (LPOBJECT_MF);
BOOL PushDc (LPOBJECT_MF);
#ifdef META_DEBUG
void PutMetaFuncName (WORD);
#endif
OLESTATUS FARINTERNAL BmDraw (lpobj, hdc, lprc, lpWrc, hdcTarget)
LPOBJECT_BM lpobj;
HDC hdc;
LPRECT lprc;
LPRECT lpWrc;
HDC hdcTarget;
{
HDC hMemDC, hScreenDC;
int iScreenDevCaps;
OLESTATUS ret = OLE_OK;
if (!lpobj->hBitmap)
return OLE_ERROR_BLANK;
hScreenDC = GetDC (NULL);
iScreenDevCaps = GetDeviceCaps (hScreenDC, TECHNOLOGY);
if (!OleIsDcMeta (hdc)
&& (iScreenDevCaps != GetDeviceCaps (hdc, TECHNOLOGY))) {
ret = wDrawBitmapUsingDib (lpobj, hdc, hScreenDC,
hdcTarget, lprc, lpWrc);
}
else {
hMemDC = CreateCompatibleDC (hdc);
ret = wDrawBitmap (lpobj, hdc, hMemDC, lprc);
DeleteDC (hMemDC);
}
ReleaseDC (NULL, hScreenDC);
return ret;
}
OLESTATUS INTERNAL wDrawBitmap (lpobj, hdc, hMemDC, lprc)
LPOBJECT_BM lpobj;
HDC hdc;
HDC hMemDC;
LPRECT lprc;
{
HBITMAP hOldBitmap;
OLESTATUS ret = OLE_OK;
if (!hMemDC)
return OLE_ERROR_MEMORY;
if (!(hOldBitmap = SelectObject(hMemDC, lpobj->hBitmap)))
return OLE_ERROR_DRAW;
if (!StretchBlt(hdc,
lprc->left, lprc->top,
(lprc->right - lprc->left), (lprc->bottom - lprc->top),
hMemDC, 0, 0, lpobj->xSize, lpobj->ySize, SRCCOPY)) {
ret = OLE_ERROR_DRAW;
}
SelectObject (hMemDC, hOldBitmap);
return ret;
}
OLESTATUS INTERNAL wDrawBitmapUsingDib (
LPOBJECT_BM lpobj,
HDC hdc,
HDC hScreenDC,
HDC hTargetDC,
LPRECT lprc,
LPRECT lpWrc)
{
BITMAP bm;
LPBITMAPINFOHEADER lpBmi;
HANDLE hBmi, hDib = NULL;
WORD wBmiSize;
OLESTATUS retVal = OLE_ERROR_MEMORY;
if (!GetObject(lpobj->hBitmap, sizeof(BITMAP), (LPSTR) &bm))
return OLE_ERROR_HANDLE;
wBmiSize = sizeof(BITMAPINFOHEADER)
+ PaletteSize(bm.bmPlanes * bm.bmBitsPixel);
if (!(hBmi = GlobalAlloc (GMEM_MOVEABLE|GMEM_ZEROINIT, (DWORD) wBmiSize)))
return OLE_ERROR_MEMORY;
if (!(lpBmi = (LPBITMAPINFOHEADER) GlobalLock (hBmi))) {
GlobalFree (hBmi);
return OLE_ERROR_MEMORY;
}
GlobalUnlock (hBmi);
lpBmi->biSize = (LONG) sizeof(BITMAPINFOHEADER);
lpBmi->biWidth = (LONG) bm.bmWidth;
lpBmi->biHeight = (LONG) bm.bmHeight;
lpBmi->biPlanes = 1;
lpBmi->biBitCount = bm.bmPlanes * bm.bmBitsPixel;
lpBmi->biCompression = BI_RGB;
lpBmi->biSizeImage = 0L;
lpBmi->biXPelsPerMeter = 0L;
lpBmi->biYPelsPerMeter = 0L;
lpBmi->biClrUsed = 0L;
lpBmi->biClrImportant = 0L;
// Call GetDIBits with a NULL lpBits parm, so that it will calculate
// the biSizeImage field for us
if (!GetDIBits(hScreenDC, lpobj->hBitmap, 0, bm.bmHeight, NULL,
(LPBITMAPINFO)lpBmi, DIB_RGB_COLORS))
return OLE_ERROR_HANDLE;
// Realloc the buffer to provide space for the bits
if (!(hDib = GlobalReAlloc (hBmi, (wBmiSize + lpBmi->biSizeImage),
GMEM_MOVEABLE))) {
GlobalFree (hBmi);
return OLE_ERROR_MEMORY;
}
// If reallocation gave a new handle then lock that handle and get the
// long pointer to it.
if (hDib != hBmi) {
if (!(lpBmi = (LPBITMAPINFOHEADER) GlobalLock (hDib)))
goto errRtn;
GlobalUnlock (hDib);
}
// Call GetDIBits with a NON-NULL lpBits parm, and get the actual bits
if (!GetDIBits(hScreenDC, lpobj->hBitmap, 0, (WORD) lpBmi->biHeight,
((LPSTR)lpBmi)+wBmiSize,
(LPBITMAPINFO) lpBmi,
DIB_RGB_COLORS)) {
retVal = OLE_ERROR_HANDLE;
goto errRtn;
}
retVal = wDibDraw (hDib, hdc, lprc, lpWrc, hTargetDC, FALSE);
errRtn:
if (hDib)
GlobalFree (hDib);
return retVal;
}
OLESTATUS FARINTERNAL DibDraw (lpobj, hdc, lprc, lpWrc, hdcTarget)
LPOBJECT_DIB lpobj;
HDC hdc;
LPRECT lprc;
LPRECT lpWrc;
HDC hdcTarget;
{
return wDibDraw (lpobj->hDIB, hdc, lprc, lpWrc, hdcTarget, FALSE);
}
OLESTATUS FARINTERNAL wDibDraw (hData, hdc, lprc, lpWrc, hdcTarget, bPbrushData)
HANDLE hData;
HDC hdc;
LPRECT lprc;
LPRECT lpWrc;
HDC hdcTarget;
BOOL bPbrushData;
{
// !!! current implementation is not using hdcTarget
OLESTATUS ret = OLE_ERROR_DRAW;
LPSTR lpData;
HANDLE hPalette = NULL;
HPALETTE hLogPalette = NULL, hOldPalette = NULL;
LPLOGPALETTE lpLogPalette;
WORD wPalSize;
int iOffBits;
if (!hData)
return OLE_ERROR_BLANK;
if (!(lpData = GlobalLock (hData)))
return OLE_ERROR_MEMORY;
if (bPbrushData)
lpData += sizeof(BITMAPFILEHEADER);
wPalSize = PaletteSize (((LPBITMAPINFOHEADER)lpData)->biBitCount);
iOffBits = sizeof(BITMAPINFOHEADER) + wPalSize;
// if color palette exits do the following
if (wPalSize) {
if (!(hLogPalette = DibMakeLogPalette(lpData+sizeof(BITMAPINFOHEADER),
wPalSize, &lpLogPalette))) {
ret = OLE_ERROR_MEMORY;
goto end;
}
if (!(hPalette = CreatePalette (lpLogPalette)))
goto end;
// select as a background palette
if (!(hOldPalette = SelectPalette (hdc, hPalette, TRUE)))
goto end;
RealizePalette(hdc);
}
if (!StretchDIBits(hdc,
lprc->left, lprc->top,
(lprc->right - lprc->left), (lprc->bottom - lprc->top),
0, 0,
(WORD) ((LPBITMAPINFOHEADER)lpData)->biWidth,
(WORD) ((LPBITMAPINFOHEADER)lpData)->biHeight,
lpData + iOffBits,
((LPBITMAPINFO) lpData),
DIB_RGB_COLORS,
SRCCOPY)) {
ret = OLE_ERROR_DRAW;
}
else
ret = OLE_OK;
end:
// if color palette exists do the following
if (wPalSize) {
hOldPalette = (OleIsDcMeta (hdc) ? GetStockObject(DEFAULT_PALETTE)
: hOldPalette);
if (hOldPalette) {
// select as a background palette
SelectPalette (hdc, hOldPalette, TRUE);
RealizePalette (hdc);
}
if (hPalette)
DeleteObject (hPalette);
if (hLogPalette)
GlobalFree (hLogPalette);
}
GlobalUnlock (hData);
return ret;
}
HANDLE INTERNAL DibMakeLogPalette (lpColorData, wDataSize, lplpLogPalette)
LPSTR lpColorData;
WORD wDataSize;
LPLOGPALETTE FAR * lplpLogPalette;
{
HANDLE hLogPalette=NULL;
LPLOGPALETTE lpLogPalette;
DWORD dwLogPalSize = wDataSize + 2 * sizeof(WORD);
LPPALETTEENTRY lpPE;
RGBQUAD FAR * lpQuad;
if (!(hLogPalette = GlobalAlloc(GMEM_MOVEABLE,dwLogPalSize)))
return NULL;
if (!(lpLogPalette = (LPLOGPALETTE) GlobalLock (hLogPalette))) {
GlobalFree (hLogPalette);
return NULL;
}
GlobalUnlock (hLogPalette);
*lplpLogPalette = lpLogPalette;
lpLogPalette->palVersion = 0x300;
lpLogPalette->palNumEntries = wDataSize / sizeof(PALETTEENTRY);
/* now convert RGBQUAD to PALETTEENTRY as we copy color info */
for (lpQuad = (RGBQUAD far *)lpColorData,
lpPE = (LPPALETTEENTRY)lpLogPalette->palPalEntry,
wDataSize /= sizeof(RGBQUAD);
wDataSize--;
++lpQuad,++lpPE) {
lpPE->peFlags=0;
lpPE->peRed = lpQuad->rgbRed;
lpPE->peBlue = lpQuad->rgbBlue;
lpPE->peGreen = lpQuad->rgbGreen;
}
return hLogPalette;
}
int INTERNAL PaletteSize (int iBitCount)
{
switch (iBitCount) {
case 1:
return (2*sizeof(RGBQUAD));
case 4:
return (16*sizeof(RGBQUAD));
case 8:
return (256*sizeof(RGBQUAD));
default:
return 0; /* A 24 bitcount DIB has no color table */
}
}
OLESTATUS FARINTERNAL GenDraw (lpobj, hdc, lprc, lpWrc, hdcTarget)
LPOBJECT_GEN lpobj;
HDC hdc;
LPRECT lprc;
LPRECT lpWrc;
HDC hdcTarget;
{
return OLE_ERROR_GENERIC;
}
//*** All the following routines are relevant for metafile drawing only
OLESTATUS FARINTERNAL MfDraw (lpobj, hdc, lprc, lpWrc, hdcTarget)
LPOBJECT_MF lpobj;
HDC hdc;
LPRECT lprc;
LPRECT lpWrc;
HDC hdcTarget;
{
HANDLE hInfo;
int iOldDc;
RECT rect;
LPRECT lpRrc = (LPRECT) &rect;
rect.left = lprc->left;
rect.right = lprc->right;
rect.top = lprc->top;
rect.bottom = lprc->bottom;
if (!lpobj->mfp.hMF)
return OLE_ERROR_BLANK;
lpobj->nRecord = RECORD_COUNT;
lpobj->fMetaDC = OleIsDcMeta (hdc);
if (!(iOldDc = SaveDC (hdc)))
return OLE_ERROR_MEMORY;
IntersectClipRect (hdc, lpRrc->left, lpRrc->top,
lpRrc->right, lpRrc->bottom);
if (!lpobj->fMetaDC) {
LPtoDP (hdc, (LPPOINT) lpRrc, 2);
SetMapMode (hdc, MM_ANISOTROPIC);
SetViewportOrg (hdc, lpRrc->left, lpRrc->top);
SetViewportExt (hdc, lpRrc->right - lpRrc->left,
lpRrc->bottom - lpRrc->top);
}
else {
iOldDc = -1;
if (!lpWrc) {
#ifdef FIREWALLS
ASSERT(0, "Pointer to rect is null")
#endif
return OLE_ERROR_DRAW;
}
if (!(hInfo = LocalAlloc (LMEM_MOVEABLE | LMEM_ZEROINIT,
sizeof(METAINFO))))
return OLE_ERROR_MEMORY;
if (!(lpobj->pMetaInfo = (PMETAINFO) LocalLock (hInfo))) {
LocalFree (hInfo);
return OLE_ERROR_MEMORY;
}
LocalUnlock (hInfo);
lpobj->pCurMdc = (PMETADC) (lpobj->pMetaInfo);
lpobj->pMetaInfo->xwo = lpWrc->left;
lpobj->pMetaInfo->ywo = lpWrc->top;
lpobj->pMetaInfo->xwe = lpWrc->right;
lpobj->pMetaInfo->ywe = lpWrc->bottom;
lpobj->pMetaInfo->xro = lpRrc->left - lpWrc->left;
lpobj->pMetaInfo->yro = lpRrc->top - lpWrc->top;
lpobj->pCurMdc->xre = lpRrc->right - lpRrc->left;
lpobj->pCurMdc->yre = lpRrc->bottom - lpRrc->top;
}
lpobj->error = OLE_OK;
MfInterruptiblePaint(lpobj, hdc);
if (lpobj->fMetaDC)
CleanStack (lpobj, hInfo);
RestoreDC (hdc, iOldDc);
return lpobj->error;
}
void INTERNAL MfInterruptiblePaint (lpobj, hdc)
LPOBJECT_MF lpobj;
HDC hdc;
{
FARPROC lpCallbackFunc;
if (!(lpCallbackFunc = MakeProcInstance (MfCallbackFunc, hInstDLL)))
PlayMetaFile (hdc, lpobj->mfp.hMF);
else {
EnumMetaFile (hdc,lpobj->mfp.hMF, lpCallbackFunc, (LPARAM) lpobj);
FreeProcInstance (lpCallbackFunc);
}
}
int FARINTERNAL MfCallbackFunc (hdc, lpHTable, lpMFR, nObj, lpobj)
HDC hdc;
LPHANDLETABLE lpHTable;
LPMETARECORD lpMFR;
int nObj;
BYTE FAR * lpobj;
{
LPOBJECT_MF lpobjMf;
lpobjMf = (LPOBJECT_MF) lpobj;
if (!--lpobjMf->nRecord) {
lpobjMf->nRecord = RECORD_COUNT;
if (!ContextCallBack ((lpobjMf->head.lpParent
? lpobjMf->head.lpParent
: (LPOLEOBJECT) lpobjMf),
OLE_QUERY_PAINT)) {
lpobjMf->error = OLE_ERROR_ABORT;
return FALSE;
}
}
if (lpobjMf->fMetaDC) {
#ifdef META_DEBUG
PutMetaFuncName (lpMFR->rdFunction);
#endif
switch (lpMFR->rdFunction) {
case META_SETWINDOWORG:
SetPictOrg (lpobjMf, hdc, lpMFR->rdParm[1],
lpMFR->rdParm[0], FALSE);
return TRUE;
case META_OFFSETWINDOWORG:
SetPictOrg (lpobjMf, hdc, lpMFR->rdParm[1],
lpMFR->rdParm[0], TRUE);
return TRUE;
case META_SETWINDOWEXT:
SetPictExt (lpobjMf, hdc, lpMFR->rdParm[1], lpMFR->rdParm[0]);
return TRUE;
case META_SCALEWINDOWEXT:
ScalePictExt (lpobjMf, hdc,
lpMFR->rdParm[3], lpMFR->rdParm[2],
lpMFR->rdParm[1], lpMFR->rdParm[0]);
return TRUE;
case META_SAVEDC:
if (!PushDc (lpobjMf))
return FALSE;
break;
case META_RESTOREDC:
PopDc (lpobjMf);
break;
case META_SCALEVIEWPORTEXT:
ScaleRectExt (lpobjMf, hdc,
lpMFR->rdParm[3], lpMFR->rdParm[2],
lpMFR->rdParm[1], lpMFR->rdParm[0]);
return TRUE;
case META_OFFSETVIEWPORTORG:
#ifdef FIREWALLS
ASSERT(0, "OffsetViewportOrg() in metafile");
#endif
return TRUE;
case META_SETVIEWPORTORG:
#ifdef FIREWALLS
ASSERT(0, "SetViewportOrg() in metafile");
#endif
return TRUE;
case META_SETVIEWPORTEXT:
#ifdef FIREWALLS
ASSERT(0, "SetViewportExt() in metafile");
#endif
return TRUE;
case META_SETMAPMODE:
#ifdef FIREWALLS
ASSERT(lpMFR->rdParm[0] == MM_ANISOTROPIC,
"SetmapMode() in metafile with invalid mapping mode");
#endif
return TRUE;
default:
break;
}
}
else {
switch (lpMFR->rdFunction) {
DWORD exts;
case META_SCALEWINDOWEXT:
exts = GetWindowExt (hdc);
SetWindowExt (hdc,
MulDiv(LOWORD(exts), lpMFR->rdParm[3], lpMFR->rdParm[2]),
MulDiv(HIWORD(exts), lpMFR->rdParm[1], lpMFR->rdParm[0]));
return TRUE;
case META_SCALEVIEWPORTEXT:
exts = GetViewportExt (hdc);
SetViewportExt (hdc,
MulDiv(LOWORD(exts), lpMFR->rdParm[3], lpMFR->rdParm[2]),
MulDiv(HIWORD(exts), lpMFR->rdParm[1], lpMFR->rdParm[0]));
return TRUE;
default:
break;
}
}
PlayMetaFileRecord (hdc, lpHTable, lpMFR, nObj);
return TRUE;
}
void SetPictOrg (lpobj, hdc, xOrg, yOrg, fOffset)
LPOBJECT_MF lpobj;
HDC hdc;
int xOrg;
int yOrg;
BOOL fOffset;
{
if (fOffset) {
// it's OffsetWindowOrg() call
lpobj->pCurMdc->xMwo += xOrg;
lpobj->pCurMdc->yMwo += yOrg;
}
else {
// it's SetWindowOrg()
lpobj->pCurMdc->xMwo = xOrg;
lpobj->pCurMdc->yMwo = yOrg;
}
if (lpobj->pCurMdc->xMwe && lpobj->pCurMdc->yMwe) {
SetWindowOrg (hdc,
(lpobj->pCurMdc->xMwo - MulDiv (lpobj->pMetaInfo->xro,
lpobj->pCurMdc->xMwe,
lpobj->pCurMdc->xre)),
(lpobj->pCurMdc->yMwo - MulDiv (lpobj->pMetaInfo->yro,
lpobj->pCurMdc->yMwe,
lpobj->pCurMdc->yre)));
}
}
void SetPictExt (lpobj, hdc, xExt, yExt)
LPOBJECT_MF lpobj;
HDC hdc;
int xExt;
int yExt;
{
lpobj->pCurMdc->xMwe = xExt;
lpobj->pCurMdc->yMwe = yExt;
SetWindowExt (hdc,
MulDiv (lpobj->pMetaInfo->xwe, xExt, lpobj->pCurMdc->xre),
MulDiv (lpobj->pMetaInfo->ywe, yExt, lpobj->pCurMdc->yre));
SetWindowOrg (hdc,
(lpobj->pCurMdc->xMwo
- MulDiv (lpobj->pMetaInfo->xro, xExt, lpobj->pCurMdc->xre)),
(lpobj->pCurMdc->yMwo
- MulDiv (lpobj->pMetaInfo->yro, yExt, lpobj->pCurMdc->yre)));
}
void ScalePictExt (lpobj, hdc, xNum, xDenom, yNum, yDenom)
LPOBJECT_MF lpobj;
HDC hdc;
int xNum;
int xDenom;
int yNum;
int yDenom;
{
SetPictExt (lpobj, hdc, MulDiv (lpobj->pCurMdc->xMwe, xNum, xDenom),
MulDiv (lpobj->pCurMdc->yMwe, yNum, yDenom));
}
void ScaleRectExt (lpobj, hdc, xNum, xDenom, yNum, yDenom)
LPOBJECT_MF lpobj;
HDC hdc;
int xNum;
int xDenom;
int yNum;
int yDenom;
{
lpobj->pCurMdc->xre = MulDiv (lpobj->pCurMdc->xre, xNum, xDenom);
lpobj->pCurMdc->yre = MulDiv (lpobj->pCurMdc->yre, yNum, yDenom);
SetPictExt (lpobj, hdc, lpobj->pCurMdc->xMwe, lpobj->pCurMdc->yMwe);
}
BOOL PushDc (lpobj)
LPOBJECT_MF lpobj;
{
HANDLE hNode = NULL;
PMETADC pNode = NULL;
if ((hNode = LocalAlloc (LMEM_MOVEABLE, sizeof (METADC)))
&& (pNode = (PMETADC) LocalLock (hNode))) {
*pNode = *lpobj->pCurMdc;
lpobj->pCurMdc->pNext = pNode;
pNode->pNext = NULL;
lpobj->pCurMdc = pNode;
LocalUnlock (hNode);
return TRUE;
}
if (pNode)
LocalFree (hNode);
lpobj->error = OLE_ERROR_MEMORY;
return FALSE;
}
BOOL PopDc (lpobj)
LPOBJECT_MF lpobj;
{
PMETADC pPrev = (PMETADC) (lpobj->pMetaInfo);
PMETADC pCur = ((PMETADC) (lpobj->pMetaInfo))->pNext;
HANDLE hCur;
if (!pCur)
// more Pops than Pushes
return FALSE;
while (pCur->pNext) {
pPrev = pCur;
pCur = pCur->pNext;
}
if (hCur = LocalHandle ((WORD) pCur))
LocalFree (hCur);
pPrev->pNext = NULL;
lpobj->pCurMdc = pPrev;
}
void CleanStack(lpobj, hMetaInfo)
LPOBJECT_MF lpobj;
HANDLE hMetaInfo;
{
PMETADC pCur = ((PMETADC) (lpobj->pMetaInfo))->pNext;
HANDLE hCur;
while (pCur) {
hCur = LocalHandle ((WORD) pCur);
((PMETADC) (lpobj->pMetaInfo))->pNext = pCur = pCur->pNext;
if (hCur)
LocalFree (hCur);
}
LocalFree (hMetaInfo);
lpobj->fMetaDC = FALSE;
lpobj->pCurMdc = NULL;
lpobj->pMetaInfo = NULL;
}
#ifdef META_DEBUG
void PutMetaFuncName (value)
WORD value;
{
switch (value) {
case META_SETBKCOLOR:
OutputDebugString ("SetBkColor ");
break;
case META_SETBKMODE:
OutputDebugString ("SetBkMode ");
break;
case META_SETMAPMODE:
OutputDebugString ("SetMapMode ");
break;
case META_SETROP2:
OutputDebugString ("SetRop2 ");
break;
case META_SETRELABS:
OutputDebugString ("SetRelabs ");
break;
case META_SETPOLYFILLMODE:
OutputDebugString ("SetPolyfillMode ");
break;
case META_SETSTRETCHBLTMODE:
OutputDebugString ("SetStretchBltMode ");
break;
case META_SETTEXTCHAREXTRA:
OutputDebugString ("SetTextCharExtra ");
break;
case META_SETTEXTCOLOR:
OutputDebugString ("SetTextColor ");
break;
case META_SETTEXTJUSTIFICATION:
OutputDebugString ("SetTextJustification ");
break;
case META_SETWINDOWORG:
OutputDebugString ("SetWindowOrg ");
break;
case META_SETWINDOWEXT:
OutputDebugString ("SetWindowExt ");
break;
case META_SETVIEWPORTORG:
OutputDebugString ("SetViewportOrg ");
break;
case META_SETVIEWPORTEXT:
OutputDebugString ("SetViewportExt ");
break;
case META_OFFSETWINDOWORG:
OutputDebugString ("OffsetWindowOrg ");
break;
case META_SCALEWINDOWEXT:
OutputDebugString ("ScaleWindowExt ");
break;
case META_OFFSETVIEWPORTORG:
OutputDebugString ("OffsetViewportOrg ");
break;
case META_SCALEVIEWPORTEXT:
OutputDebugString ("ScaleViewportExt ");
break;
case META_LINETO:
OutputDebugString ("LineTo ");
break;
case META_MOVETO:
OutputDebugString ("MoveTo ");
break;
case META_EXCLUDECLIPRECT:
OutputDebugString ("ExcludeCliprect ");
break;
case META_INTERSECTCLIPRECT:
OutputDebugString ("IntersectCliprect ");
break;
case META_ARC:
OutputDebugString ("Arc ");
break;
case META_ELLIPSE:
OutputDebugString ("Ellipse ");
break;
case META_FLOODFILL:
OutputDebugString ("FloodFill ");
break;
case META_PIE:
OutputDebugString ("Pie ");
break;
case META_RECTANGLE:
OutputDebugString ("Rectangle ");
break;
case META_ROUNDRECT:
OutputDebugString ("RoundRect ");
break;
case META_PATBLT:
OutputDebugString ("PatBlt ");
break;
case META_SAVEDC:
OutputDebugString ("SaveDC ");
break;
case META_SETPIXEL:
OutputDebugString ("SetPixel ");
break;
case META_OFFSETCLIPRGN:
OutputDebugString ("OffsetClipRegion ");
break;
case META_TEXTOUT:
OutputDebugString ("TextOut ");
break;
case META_BITBLT:
OutputDebugString ("BitBlt ");
break;
case META_STRETCHBLT:
OutputDebugString ("StrechBlt ");
break;
case META_POLYGON:
OutputDebugString ("Polygon ");
break;
case META_POLYLINE:
OutputDebugString ("PolyLine ");
break;
case META_ESCAPE:
OutputDebugString ("Escape ");
break;
case META_RESTOREDC:
OutputDebugString ("RestoreDC ");
break;
case META_FILLREGION:
OutputDebugString ("FillRegion ");
break;
case META_FRAMEREGION:
OutputDebugString ("FrameRegion ");
break;
case META_INVERTREGION:
OutputDebugString ("InvertRegion ");
break;
case META_PAINTREGION:
OutputDebugString ("PaintRegion ");
break;
case META_SELECTCLIPREGION:
OutputDebugString ("SelectClipRegion ");
break;
case META_SELECTOBJECT:
OutputDebugString ("SelectObject ");
break;
case META_SETTEXTALIGN:
OutputDebugString ("SetTextAlign ");
break;
case META_DRAWTEXT:
OutputDebugString ("DrawText");
break;
case META_CHORD:
OutputDebugString ("Chord ");
break;
case META_SETMAPPERFLAGS:
OutputDebugString ("SetMapperFlags ");
break;
case META_EXTTEXTOUT:
OutputDebugString ("ExtTextOut ");
break;
case META_SETDIBTODEV:
OutputDebugString ("SetDIBitsToDevice ");
break;
case META_SELECTPALETTE:
OutputDebugString ("SelectPalette ");
break;
case META_REALIZEPALETTE:
OutputDebugString ("RealizePalette ");
break;
case META_ANIMATEPALETTE:
OutputDebugString ("AnimatePalette ");
break;
case META_SETPALENTRIES:
OutputDebugString ("SetPaletteEntries ");
break;
case META_POLYPOLYGON:
OutputDebugString ("PolyPolygon ");
break;
case META_RESIZEPALETTE:
OutputDebugString ("ResizePalette ");
break;
case META_DIBBITBLT:
OutputDebugString ("DibBitBlt ");
break;
case META_DIBSTRETCHBLT:
OutputDebugString ("DibStrechBlt ");
break;
case META_DIBCREATEPATTERNBRUSH:
OutputDebugString ("DibCreatePatternBrush ");
break;
case META_STRETCHDIB:
OutputDebugString ("StretchDIBits ");
break;
case META_DELETEOBJECT:
OutputDebugString ("DeleteObject ");
break;
case META_CREATEPALETTE:
OutputDebugString ("CreatePalette ");
break;
case META_CREATEBRUSH:
OutputDebugString ("CreateBrush ");
break;
case META_CREATEPATTERNBRUSH:
OutputDebugString ("CreatePatternBrush ");
break;
case META_CREATEPENINDIRECT:
OutputDebugString ("CreatePenIndirect ");
break;
case META_CREATEFONTINDIRECT:
OutputDebugString ("CreateFontIndirect ");
break;
case META_CREATEBRUSHINDIRECT:
OutputDebugString ("CreateBrushIndirect ");
break;
case META_CREATEBITMAPINDIRECT:
OutputDebugString ("CreateBitmapIndirect ");
break;
case META_CREATEBITMAP:
OutputDebugString ("CreateBitmap ");
break;
case META_CREATEREGION:
OutputDebugString ("CreateRegion ");
break;
default:
OutputDebugString ("Invalid+Function+encountered ");
break;
}
}
#endif