Descent3/lib/win/DirectX/ddraw.h

4735 lines
171 KiB
C

/*
* Descent 3
* Copyright (C) 2024 Parallax Software
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/*==========================================================================;
*
* Copyright (C) 1994-1997 Microsoft Corporation. All Rights Reserved.
*
* File: ddraw.h
* Content: DirectDraw include file
*
***************************************************************************/
#ifndef __DDRAW_INCLUDED__
#define __DDRAW_INCLUDED__
/*
* If you wish an application built against the newest version of DirectDraw
* to run against an older DirectDraw run time then define DIRECTDRAW_VERSION
* to be the earlies version of DirectDraw you wish to run against. For,
* example if you wish an application to run against a DX 3 runtime define
* DIRECTDRAW_VERSION to be 0x0300.
*/
#ifndef DIRECTDRAW_VERSION
#define DIRECTDRAW_VERSION 0x0600
#endif /* DIRECTDRAW_VERSION */
#if defined(_WIN32) && !defined(_NO_COM)
#define COM_NO_WINDOWS_H
#include <objbase.h>
#else
#define IUnknown void
#if !defined(NT_BUILD_ENVIRONMENT) && !defined(WINNT)
#define CO_E_NOTINITIALIZED 0x800401F0L
#endif
#endif
#define _FACDD 0x876
#define MAKE_DDHRESULT(code) MAKE_HRESULT(1, _FACDD, code)
#ifdef __cplusplus
extern "C" {
#endif
//
// For compilers that don't support nameless unions, do a
//
// #define NONAMELESSUNION
//
// before #include <ddraw.h>
//
#ifndef DUMMYUNIONNAMEN
#if defined(__cplusplus) || !defined(NONAMELESSUNION)
#define DUMMYUNIONNAMEN(n)
#else
#define DUMMYUNIONNAMEN(n) u##n
#endif
#endif
#ifndef MAKEFOURCC
#define MAKEFOURCC(ch0, ch1, ch2, ch3) \
((DWORD)(BYTE)(ch0) | ((DWORD)(BYTE)(ch1) << 8) | ((DWORD)(BYTE)(ch2) << 16) | ((DWORD)(BYTE)(ch3) << 24))
#endif // defined(MAKEFOURCC)
/*
* FOURCC codes for DX compressed-texture pixel formats
*/
#define FOURCC_DXT1 (MAKEFOURCC('D', 'X', 'T', '1'))
#define FOURCC_DXT2 (MAKEFOURCC('D', 'X', 'T', '2'))
#define FOURCC_DXT3 (MAKEFOURCC('D', 'X', 'T', '3'))
#define FOURCC_DXT4 (MAKEFOURCC('D', 'X', 'T', '4'))
#define FOURCC_DXT5 (MAKEFOURCC('D', 'X', 'T', '5'))
/*
* GUIDS used by DirectDraw objects
*/
#if defined(_WIN32) && !defined(_NO_COM)
DEFINE_GUID(CLSID_DirectDraw, 0xD7B70EE0, 0x4340, 0x11CF, 0xB0, 0x63, 0x00, 0x20, 0xAF, 0xC2, 0xCD, 0x35);
DEFINE_GUID(CLSID_DirectDrawClipper, 0x593817A0, 0x7DB3, 0x11CF, 0xA2, 0xDE, 0x00, 0xAA, 0x00, 0xb9, 0x33, 0x56);
DEFINE_GUID(IID_IDirectDraw, 0x6C14DB80, 0xA733, 0x11CE, 0xA5, 0x21, 0x00, 0x20, 0xAF, 0x0B, 0xE5, 0x60);
DEFINE_GUID(IID_IDirectDraw2, 0xB3A6F3E0, 0x2B43, 0x11CF, 0xA2, 0xDE, 0x00, 0xAA, 0x00, 0xB9, 0x33, 0x56);
DEFINE_GUID(IID_IDirectDraw4, 0x9c59509a, 0x39bd, 0x11d1, 0x8c, 0x4a, 0x00, 0xc0, 0x4f, 0xd9, 0x30, 0xc5);
DEFINE_GUID(IID_IDirectDrawSurface, 0x6C14DB81, 0xA733, 0x11CE, 0xA5, 0x21, 0x00, 0x20, 0xAF, 0x0B, 0xE5, 0x60);
DEFINE_GUID(IID_IDirectDrawSurface2, 0x57805885, 0x6eec, 0x11cf, 0x94, 0x41, 0xa8, 0x23, 0x03, 0xc1, 0x0e, 0x27);
DEFINE_GUID(IID_IDirectDrawSurface3, 0xDA044E00, 0x69B2, 0x11D0, 0xA1, 0xD5, 0x00, 0xAA, 0x00, 0xB8, 0xDF, 0xBB);
DEFINE_GUID(IID_IDirectDrawSurface4, 0x0B2B8630, 0xAD35, 0x11D0, 0x8E, 0xA6, 0x00, 0x60, 0x97, 0x97, 0xEA, 0x5B);
DEFINE_GUID(IID_IDirectDrawPalette, 0x6C14DB84, 0xA733, 0x11CE, 0xA5, 0x21, 0x00, 0x20, 0xAF, 0x0B, 0xE5, 0x60);
DEFINE_GUID(IID_IDirectDrawClipper, 0x6C14DB85, 0xA733, 0x11CE, 0xA5, 0x21, 0x00, 0x20, 0xAF, 0x0B, 0xE5, 0x60);
DEFINE_GUID(IID_IDirectDrawColorControl, 0x4B9F0EE0, 0x0D7E, 0x11D0, 0x9B, 0x06, 0x00, 0xA0, 0xC9, 0x03, 0xA3, 0xB8);
DEFINE_GUID(IID_IDirectDrawGammaControl, 0x69C11C3E, 0xB46B, 0x11D1, 0xAD, 0x7A, 0x00, 0xC0, 0x4F, 0xC2, 0x9B, 0x4E);
#endif
/*============================================================================
*
* DirectDraw Structures
*
* Various structures used to invoke DirectDraw.
*
*==========================================================================*/
struct IDirectDraw;
struct IDirectDrawSurface;
struct IDirectDrawPalette;
struct IDirectDrawClipper;
typedef struct IDirectDraw FAR *LPDIRECTDRAW;
typedef struct IDirectDraw2 FAR *LPDIRECTDRAW2;
typedef struct IDirectDraw4 FAR *LPDIRECTDRAW4;
typedef struct IDirectDrawSurface FAR *LPDIRECTDRAWSURFACE;
typedef struct IDirectDrawSurface2 FAR *LPDIRECTDRAWSURFACE2;
typedef struct IDirectDrawSurface3 FAR *LPDIRECTDRAWSURFACE3;
typedef struct IDirectDrawSurface4 FAR *LPDIRECTDRAWSURFACE4;
typedef struct IDirectDrawPalette FAR *LPDIRECTDRAWPALETTE;
typedef struct IDirectDrawClipper FAR *LPDIRECTDRAWCLIPPER;
typedef struct IDirectDrawColorControl FAR *LPDIRECTDRAWCOLORCONTROL;
typedef struct IDirectDrawGammaControl FAR *LPDIRECTDRAWGAMMACONTROL;
typedef struct _DDFXROP FAR *LPDDFXROP;
typedef struct _DDSURFACEDESC FAR *LPDDSURFACEDESC;
typedef struct _DDSURFACEDESC2 FAR *LPDDSURFACEDESC2;
typedef struct _DDCOLORCONTROL FAR *LPDDCOLORCONTROL;
/*
* API's
*/
#if (defined(WIN32) || defined(_WIN32)) && !defined(_NO_COM)
// #if defined( _WIN32 ) && !defined( _NO_ENUM )
typedef BOOL(FAR PASCAL *LPDDENUMCALLBACKA)(GUID FAR *, LPSTR, LPSTR, LPVOID);
typedef BOOL(FAR PASCAL *LPDDENUMCALLBACKW)(GUID FAR *, LPWSTR, LPWSTR, LPVOID);
extern HRESULT WINAPI DirectDrawEnumerateW(LPDDENUMCALLBACKW lpCallback, LPVOID lpContext);
extern HRESULT WINAPI DirectDrawEnumerateA(LPDDENUMCALLBACKA lpCallback, LPVOID lpContext);
/*
* Protect against old SDKs
*/
#ifndef SM_CMONITORS
#define HMONITOR HANDLE
#endif
typedef BOOL(FAR PASCAL *LPDDENUMCALLBACKEXA)(GUID FAR *, LPSTR, LPSTR, LPVOID, HMONITOR);
typedef BOOL(FAR PASCAL *LPDDENUMCALLBACKEXW)(GUID FAR *, LPWSTR, LPWSTR, LPVOID, HMONITOR);
extern HRESULT WINAPI DirectDrawEnumerateExW(LPDDENUMCALLBACKEXW lpCallback, LPVOID lpContext, DWORD dwFlags);
extern HRESULT WINAPI DirectDrawEnumerateExA(LPDDENUMCALLBACKEXA lpCallback, LPVOID lpContext, DWORD dwFlags);
typedef HRESULT(WINAPI *LPDIRECTDRAWENUMERATEEXA)(LPDDENUMCALLBACKEXA lpCallback, LPVOID lpContext, DWORD dwFlags);
typedef HRESULT(WINAPI *LPDIRECTDRAWENUMERATEEXW)(LPDDENUMCALLBACKEXW lpCallback, LPVOID lpContext, DWORD dwFlags);
#ifdef UNICODE
typedef LPDDENUMCALLBACKW LPDDENUMCALLBACK;
#define DirectDrawEnumerate DirectDrawEnumerateW
typedef LPDDENUMCALLBACKEXW LPDDENUMCALLBACKEX;
typedef LPDIRECTDRAWENUMERATEEXW LPDIRECTDRAWENUMERATEEX;
#define DirectDrawEnumerateEx DirectDrawEnumerateExW
#else
typedef LPDDENUMCALLBACKA LPDDENUMCALLBACK;
#define DirectDrawEnumerate DirectDrawEnumerateA
typedef LPDDENUMCALLBACKEXA LPDDENUMCALLBACKEX;
typedef LPDIRECTDRAWENUMERATEEXA LPDIRECTDRAWENUMERATEEX;
#define DirectDrawEnumerateEx DirectDrawEnumerateExA
#endif
extern HRESULT WINAPI DirectDrawCreate(GUID FAR *lpGUID, LPDIRECTDRAW FAR *lplpDD, IUnknown FAR *pUnkOuter);
extern HRESULT WINAPI DirectDrawCreateClipper(DWORD dwFlags, LPDIRECTDRAWCLIPPER FAR *lplpDDClipper,
IUnknown FAR *pUnkOuter);
#endif
/*
* Flags for DirectDrawEnumerateEx
* DirectDrawEnumerateEx supercedes DirectDrawEnumerate. You must use GetProcAddress to
* obtain a function pointer (of type LPDIRECTDRAWENUMERATEEX) to DirectDrawEnumerateEx.
* By default, only the primary display device is enumerated.
* DirectDrawEnumerate is equivalent to DirectDrawEnumerate(,,DDENUM_NONDISPLAYDEVICES)
*/
/*
* This flag causes enumeration of any GDI display devices which are part of
* the Windows Desktop
*/
#define DDENUM_ATTACHEDSECONDARYDEVICES 0x00000001L
/*
* This flag causes enumeration of any GDI display devices which are not
* part of the Windows Desktop
*/
#define DDENUM_DETACHEDSECONDARYDEVICES 0x00000002L
/*
* This flag causes enumeration of non-display devices
*/
#define DDENUM_NONDISPLAYDEVICES 0x00000004L
#define REGSTR_KEY_DDHW_DESCRIPTION "Description"
#define REGSTR_KEY_DDHW_DRIVERNAME "DriverName"
#define REGSTR_PATH_DDHW "Hardware\\DirectDrawDrivers"
#define DDCREATE_HARDWAREONLY 0x00000001l
#define DDCREATE_EMULATIONONLY 0x00000002l
#if defined(WINNT) || !defined(WIN32)
typedef long HRESULT;
#endif
// #ifndef WINNT
typedef HRESULT(FAR PASCAL *LPDDENUMMODESCALLBACK)(LPDDSURFACEDESC, LPVOID);
typedef HRESULT(FAR PASCAL *LPDDENUMMODESCALLBACK2)(LPDDSURFACEDESC2, LPVOID);
typedef HRESULT(FAR PASCAL *LPDDENUMSURFACESCALLBACK)(LPDIRECTDRAWSURFACE, LPDDSURFACEDESC, LPVOID);
typedef HRESULT(FAR PASCAL *LPDDENUMSURFACESCALLBACK2)(LPDIRECTDRAWSURFACE4, LPDDSURFACEDESC2, LPVOID);
// #endif
/*
* Generic pixel format with 8-bit RGB and alpha components
*/
typedef struct _DDRGBA {
BYTE red;
BYTE green;
BYTE blue;
BYTE alpha;
} DDRGBA;
typedef DDRGBA FAR *LPDDRGBA;
/*
* DDCOLORKEY
*/
typedef struct _DDCOLORKEY {
DWORD dwColorSpaceLowValue; // low boundary of color space that is to
// be treated as Color Key, inclusive
DWORD dwColorSpaceHighValue; // high boundary of color space that is
// to be treated as Color Key, inclusive
} DDCOLORKEY;
typedef DDCOLORKEY FAR *LPDDCOLORKEY;
/*
* DDBLTFX
* Used to pass override information to the DIRECTDRAWSURFACE callback Blt.
*/
typedef struct _DDBLTFX {
DWORD dwSize; // size of structure
DWORD dwDDFX; // FX operations
DWORD dwROP; // Win32 raster operations
DWORD dwDDROP; // Raster operations new for DirectDraw
DWORD dwRotationAngle; // Rotation angle for blt
DWORD dwZBufferOpCode; // ZBuffer compares
DWORD dwZBufferLow; // Low limit of Z buffer
DWORD dwZBufferHigh; // High limit of Z buffer
DWORD dwZBufferBaseDest; // Destination base value
DWORD dwZDestConstBitDepth; // Bit depth used to specify Z constant for destination
union {
DWORD dwZDestConst; // Constant to use as Z buffer for dest
LPDIRECTDRAWSURFACE lpDDSZBufferDest; // Surface to use as Z buffer for dest
} DUMMYUNIONNAMEN(1);
DWORD dwZSrcConstBitDepth; // Bit depth used to specify Z constant for source
union {
DWORD dwZSrcConst; // Constant to use as Z buffer for src
LPDIRECTDRAWSURFACE lpDDSZBufferSrc; // Surface to use as Z buffer for src
} DUMMYUNIONNAMEN(2);
DWORD dwAlphaEdgeBlendBitDepth; // Bit depth used to specify constant for alpha edge blend
DWORD dwAlphaEdgeBlend; // Alpha for edge blending
DWORD dwReserved;
DWORD dwAlphaDestConstBitDepth; // Bit depth used to specify alpha constant for destination
union {
DWORD dwAlphaDestConst; // Constant to use as Alpha Channel
LPDIRECTDRAWSURFACE lpDDSAlphaDest; // Surface to use as Alpha Channel
} DUMMYUNIONNAMEN(3);
DWORD dwAlphaSrcConstBitDepth; // Bit depth used to specify alpha constant for source
union {
DWORD dwAlphaSrcConst; // Constant to use as Alpha Channel
LPDIRECTDRAWSURFACE lpDDSAlphaSrc; // Surface to use as Alpha Channel
} DUMMYUNIONNAMEN(4);
union {
DWORD dwFillColor; // color in RGB or Palettized
DWORD dwFillDepth; // depth value for z-buffer
DWORD dwFillPixel; // pixel value for RGBA or RGBZ
LPDIRECTDRAWSURFACE lpDDSPattern; // Surface to use as pattern
} DUMMYUNIONNAMEN(5);
DDCOLORKEY ddckDestColorkey; // DestColorkey override
DDCOLORKEY ddckSrcColorkey; // SrcColorkey override
} DDBLTFX;
typedef DDBLTFX FAR *LPDDBLTFX;
/*
* DDSCAPS
*/
typedef struct _DDSCAPS {
DWORD dwCaps; // capabilities of surface wanted
} DDSCAPS;
typedef DDSCAPS FAR *LPDDSCAPS;
/*
* DDOSCAPS
*/
typedef struct _DDOSCAPS {
DWORD dwCaps; // capabilities of surface wanted
} DDOSCAPS;
typedef DDOSCAPS FAR *LPDDOSCAPS;
/*
* This structure is used internally by DirectDraw.
*/
typedef struct _DDSCAPSEX {
DWORD dwCaps2;
DWORD dwCaps3;
DWORD dwCaps4;
} DDSCAPSEX, FAR *LPDDSCAPSEX;
/*
* DDSCAPS2
*/
typedef struct _DDSCAPS2 {
DWORD dwCaps; // capabilities of surface wanted
DWORD dwCaps2;
DWORD dwCaps3;
DWORD dwCaps4;
} DDSCAPS2;
typedef DDSCAPS2 FAR *LPDDSCAPS2;
/*
* DDCAPS
*/
#define DD_ROP_SPACE (256 / 32) // space required to store ROP array
/*
* This structure is the DDCAPS structure as it was in version 2 and 3 of Direct X.
* It is present for back compatability.
*/
typedef struct _DDCAPS_DX3 {
DWORD dwSize; // size of the DDDRIVERCAPS structure
DWORD dwCaps; // driver specific capabilities
DWORD dwCaps2; // more driver specific capabilites
DWORD dwCKeyCaps; // color key capabilities of the surface
DWORD dwFXCaps; // driver specific stretching and effects capabilites
DWORD dwFXAlphaCaps; // alpha driver specific capabilities
DWORD dwPalCaps; // palette capabilities
DWORD dwSVCaps; // stereo vision capabilities
DWORD dwAlphaBltConstBitDepths; // DDBD_2,4,8
DWORD dwAlphaBltPixelBitDepths; // DDBD_1,2,4,8
DWORD dwAlphaBltSurfaceBitDepths; // DDBD_1,2,4,8
DWORD dwAlphaOverlayConstBitDepths; // DDBD_2,4,8
DWORD dwAlphaOverlayPixelBitDepths; // DDBD_1,2,4,8
DWORD dwAlphaOverlaySurfaceBitDepths; // DDBD_1,2,4,8
DWORD dwZBufferBitDepths; // DDBD_8,16,24,32
DWORD dwVidMemTotal; // total amount of video memory
DWORD dwVidMemFree; // amount of free video memory
DWORD dwMaxVisibleOverlays; // maximum number of visible overlays
DWORD dwCurrVisibleOverlays; // current number of visible overlays
DWORD dwNumFourCCCodes; // number of four cc codes
DWORD dwAlignBoundarySrc; // source rectangle alignment
DWORD dwAlignSizeSrc; // source rectangle byte size
DWORD dwAlignBoundaryDest; // dest rectangle alignment
DWORD dwAlignSizeDest; // dest rectangle byte size
DWORD dwAlignStrideAlign; // stride alignment
DWORD dwRops[DD_ROP_SPACE]; // ROPS supported
DDSCAPS ddsCaps; // DDSCAPS structure has all the general capabilities
DWORD dwMinOverlayStretch; // minimum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwMaxOverlayStretch; // maximum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwMinLiveVideoStretch; // minimum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwMaxLiveVideoStretch; // maximum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwMinHwCodecStretch; // minimum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwMaxHwCodecStretch; // maximum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
DWORD dwReserved1; // reserved
DWORD dwReserved2; // reserved
DWORD dwReserved3; // reserved
DWORD dwSVBCaps; // driver specific capabilities for System->Vmem blts
DWORD dwSVBCKeyCaps; // driver color key capabilities for System->Vmem blts
DWORD dwSVBFXCaps; // driver FX capabilities for System->Vmem blts
DWORD dwSVBRops[DD_ROP_SPACE]; // ROPS supported for System->Vmem blts
DWORD dwVSBCaps; // driver specific capabilities for Vmem->System blts
DWORD dwVSBCKeyCaps; // driver color key capabilities for Vmem->System blts
DWORD dwVSBFXCaps; // driver FX capabilities for Vmem->System blts
DWORD dwVSBRops[DD_ROP_SPACE]; // ROPS supported for Vmem->System blts
DWORD dwSSBCaps; // driver specific capabilities for System->System blts
DWORD dwSSBCKeyCaps; // driver color key capabilities for System->System blts
DWORD dwSSBFXCaps; // driver FX capabilities for System->System blts
DWORD dwSSBRops[DD_ROP_SPACE]; // ROPS supported for System->System blts
DWORD dwReserved4; // reserved
DWORD dwReserved5; // reserved
DWORD dwReserved6; // reserved
} DDCAPS_DX3;
typedef DDCAPS_DX3 FAR *LPDDCAPS_DX3;
/*
* This structure is the DDCAPS structure as it was in version 5 of Direct X.
* It is present for back compatability.
*/
typedef struct _DDCAPS_DX5 {
/* 0*/ DWORD dwSize; // size of the DDDRIVERCAPS structure
/* 4*/ DWORD dwCaps; // driver specific capabilities
/* 8*/ DWORD dwCaps2; // more driver specific capabilites
/* c*/ DWORD dwCKeyCaps; // color key capabilities of the surface
/* 10*/ DWORD dwFXCaps; // driver specific stretching and effects capabilites
/* 14*/ DWORD dwFXAlphaCaps; // alpha driver specific capabilities
/* 18*/ DWORD dwPalCaps; // palette capabilities
/* 1c*/ DWORD dwSVCaps; // stereo vision capabilities
/* 20*/ DWORD dwAlphaBltConstBitDepths; // DDBD_2,4,8
/* 24*/ DWORD dwAlphaBltPixelBitDepths; // DDBD_1,2,4,8
/* 28*/ DWORD dwAlphaBltSurfaceBitDepths; // DDBD_1,2,4,8
/* 2c*/ DWORD dwAlphaOverlayConstBitDepths; // DDBD_2,4,8
/* 30*/ DWORD dwAlphaOverlayPixelBitDepths; // DDBD_1,2,4,8
/* 34*/ DWORD dwAlphaOverlaySurfaceBitDepths; // DDBD_1,2,4,8
/* 38*/ DWORD dwZBufferBitDepths; // DDBD_8,16,24,32
/* 3c*/ DWORD dwVidMemTotal; // total amount of video memory
/* 40*/ DWORD dwVidMemFree; // amount of free video memory
/* 44*/ DWORD dwMaxVisibleOverlays; // maximum number of visible overlays
/* 48*/ DWORD dwCurrVisibleOverlays; // current number of visible overlays
/* 4c*/ DWORD dwNumFourCCCodes; // number of four cc codes
/* 50*/ DWORD dwAlignBoundarySrc; // source rectangle alignment
/* 54*/ DWORD dwAlignSizeSrc; // source rectangle byte size
/* 58*/ DWORD dwAlignBoundaryDest; // dest rectangle alignment
/* 5c*/ DWORD dwAlignSizeDest; // dest rectangle byte size
/* 60*/ DWORD dwAlignStrideAlign; // stride alignment
/* 64*/ DWORD dwRops[DD_ROP_SPACE]; // ROPS supported
/* 84*/ DDSCAPS ddsCaps; // DDSCAPS structure has all the general capabilities
/* 88*/ DWORD dwMinOverlayStretch; // minimum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 8c*/ DWORD dwMaxOverlayStretch; // maximum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 90*/ DWORD
dwMinLiveVideoStretch; // minimum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 94*/ DWORD
dwMaxLiveVideoStretch; // maximum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 98*/ DWORD
dwMinHwCodecStretch; // minimum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 9c*/ DWORD
dwMaxHwCodecStretch; // maximum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* a0*/ DWORD dwReserved1; // reserved
/* a4*/ DWORD dwReserved2; // reserved
/* a8*/ DWORD dwReserved3; // reserved
/* ac*/ DWORD dwSVBCaps; // driver specific capabilities for System->Vmem blts
/* b0*/ DWORD dwSVBCKeyCaps; // driver color key capabilities for System->Vmem blts
/* b4*/ DWORD dwSVBFXCaps; // driver FX capabilities for System->Vmem blts
/* b8*/ DWORD dwSVBRops[DD_ROP_SPACE]; // ROPS supported for System->Vmem blts
/* d8*/ DWORD dwVSBCaps; // driver specific capabilities for Vmem->System blts
/* dc*/ DWORD dwVSBCKeyCaps; // driver color key capabilities for Vmem->System blts
/* e0*/ DWORD dwVSBFXCaps; // driver FX capabilities for Vmem->System blts
/* e4*/ DWORD dwVSBRops[DD_ROP_SPACE]; // ROPS supported for Vmem->System blts
/*104*/ DWORD dwSSBCaps; // driver specific capabilities for System->System blts
/*108*/ DWORD dwSSBCKeyCaps; // driver color key capabilities for System->System blts
/*10c*/ DWORD dwSSBFXCaps; // driver FX capabilities for System->System blts
/*110*/ DWORD dwSSBRops[DD_ROP_SPACE]; // ROPS supported for System->System blts
// Members added for DX5:
/*130*/ DWORD dwMaxVideoPorts; // maximum number of usable video ports
/*134*/ DWORD dwCurrVideoPorts; // current number of video ports used
/*138*/ DWORD dwSVBCaps2; // more driver specific capabilities for System->Vmem blts
/*13c*/ DWORD dwNLVBCaps; // driver specific capabilities for non-local->local vidmem blts
/*140*/ DWORD dwNLVBCaps2; // more driver specific capabilities non-local->local vidmem blts
/*144*/ DWORD dwNLVBCKeyCaps; // driver color key capabilities for non-local->local vidmem blts
/*148*/ DWORD dwNLVBFXCaps; // driver FX capabilities for non-local->local blts
/*14c*/ DWORD dwNLVBRops[DD_ROP_SPACE]; // ROPS supported for non-local->local blts
} DDCAPS_DX5;
typedef DDCAPS_DX5 FAR *LPDDCAPS_DX5;
typedef struct _DDCAPS_DX6 {
/* 0*/ DWORD dwSize; // size of the DDDRIVERCAPS structure
/* 4*/ DWORD dwCaps; // driver specific capabilities
/* 8*/ DWORD dwCaps2; // more driver specific capabilites
/* c*/ DWORD dwCKeyCaps; // color key capabilities of the surface
/* 10*/ DWORD dwFXCaps; // driver specific stretching and effects capabilites
/* 14*/ DWORD dwFXAlphaCaps; // alpha caps
/* 18*/ DWORD dwPalCaps; // palette capabilities
/* 1c*/ DWORD dwSVCaps; // stereo vision capabilities
/* 20*/ DWORD dwAlphaBltConstBitDepths; // DDBD_2,4,8
/* 24*/ DWORD dwAlphaBltPixelBitDepths; // DDBD_1,2,4,8
/* 28*/ DWORD dwAlphaBltSurfaceBitDepths; // DDBD_1,2,4,8
/* 2c*/ DWORD dwAlphaOverlayConstBitDepths; // DDBD_2,4,8
/* 30*/ DWORD dwAlphaOverlayPixelBitDepths; // DDBD_1,2,4,8
/* 34*/ DWORD dwAlphaOverlaySurfaceBitDepths; // DDBD_1,2,4,8
/* 38*/ DWORD dwZBufferBitDepths; // DDBD_8,16,24,32
/* 3c*/ DWORD dwVidMemTotal; // total amount of video memory
/* 40*/ DWORD dwVidMemFree; // amount of free video memory
/* 44*/ DWORD dwMaxVisibleOverlays; // maximum number of visible overlays
/* 48*/ DWORD dwCurrVisibleOverlays; // current number of visible overlays
/* 4c*/ DWORD dwNumFourCCCodes; // number of four cc codes
/* 50*/ DWORD dwAlignBoundarySrc; // source rectangle alignment
/* 54*/ DWORD dwAlignSizeSrc; // source rectangle byte size
/* 58*/ DWORD dwAlignBoundaryDest; // dest rectangle alignment
/* 5c*/ DWORD dwAlignSizeDest; // dest rectangle byte size
/* 60*/ DWORD dwAlignStrideAlign; // stride alignment
/* 64*/ DWORD dwRops[DD_ROP_SPACE]; // ROPS supported
/* 84*/ DDSCAPS ddsOldCaps; // Was DDSCAPS ddsCaps. ddsCaps is of type DDSCAPS2 for DX6
/* 88*/ DWORD dwMinOverlayStretch; // minimum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 8c*/ DWORD dwMaxOverlayStretch; // maximum overlay stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 90*/ DWORD
dwMinLiveVideoStretch; // minimum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 94*/ DWORD
dwMaxLiveVideoStretch; // maximum live video stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 98*/ DWORD
dwMinHwCodecStretch; // minimum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* 9c*/ DWORD
dwMaxHwCodecStretch; // maximum hardware codec stretch factor multiplied by 1000, eg 1000 == 1.0, 1300 == 1.3
/* a0*/ DWORD dwReserved1; // reserved
/* a4*/ DWORD dwReserved2; // reserved
/* a8*/ DWORD dwReserved3; // reserved
/* ac*/ DWORD dwSVBCaps; // driver specific capabilities for System->Vmem blts
/* b0*/ DWORD dwSVBCKeyCaps; // driver color key capabilities for System->Vmem blts
/* b4*/ DWORD dwSVBFXCaps; // driver FX capabilities for System->Vmem blts
/* b8*/ DWORD dwSVBRops[DD_ROP_SPACE]; // ROPS supported for System->Vmem blts
/* d8*/ DWORD dwVSBCaps; // driver specific capabilities for Vmem->System blts
/* dc*/ DWORD dwVSBCKeyCaps; // driver color key capabilities for Vmem->System blts
/* e0*/ DWORD dwVSBFXCaps; // driver FX capabilities for Vmem->System blts
/* e4*/ DWORD dwVSBRops[DD_ROP_SPACE]; // ROPS supported for Vmem->System blts
/*104*/ DWORD dwSSBCaps; // driver specific capabilities for System->System blts
/*108*/ DWORD dwSSBCKeyCaps; // driver color key capabilities for System->System blts
/*10c*/ DWORD dwSSBFXCaps; // driver FX capabilities for System->System blts
/*110*/ DWORD dwSSBRops[DD_ROP_SPACE]; // ROPS supported for System->System blts
/*130*/ DWORD dwMaxVideoPorts; // maximum number of usable video ports
/*134*/ DWORD dwCurrVideoPorts; // current number of video ports used
/*138*/ DWORD dwSVBCaps2; // more driver specific capabilities for System->Vmem blts
/*13c*/ DWORD dwNLVBCaps; // driver specific capabilities for non-local->local vidmem blts
/*140*/ DWORD dwNLVBCaps2; // more driver specific capabilities non-local->local vidmem blts
/*144*/ DWORD dwNLVBCKeyCaps; // driver color key capabilities for non-local->local vidmem blts
/*148*/ DWORD dwNLVBFXCaps; // driver FX capabilities for non-local->local blts
/*14c*/ DWORD dwNLVBRops[DD_ROP_SPACE]; // ROPS supported for non-local->local blts
// Members added for DX6 release
/*16c*/ DDSCAPS2 ddsCaps; // Surface Caps
} DDCAPS_DX6;
typedef DDCAPS_DX6 FAR *LPDDCAPS_DX6;
#if DIRECTDRAW_VERSION <= 0x300
typedef DDCAPS_DX3 DDCAPS;
#elif DIRECTDRAW_VERSION <= 0x500
typedef DDCAPS_DX5 DDCAPS;
#else
typedef DDCAPS_DX6 DDCAPS;
#endif
typedef DDCAPS FAR *LPDDCAPS;
/*
* DDPIXELFORMAT
*/
typedef struct _DDPIXELFORMAT {
DWORD dwSize; // size of structure
DWORD dwFlags; // pixel format flags
DWORD dwFourCC; // (FOURCC code)
union {
DWORD dwRGBBitCount; // how many bits per pixel
DWORD dwYUVBitCount; // how many bits per pixel
DWORD dwZBufferBitDepth; // how many total bits/pixel in z buffer (including any stencil bits)
DWORD dwAlphaBitDepth; // how many bits for alpha channels
DWORD dwLuminanceBitCount; // how many bits per pixel
DWORD dwBumpBitCount; // how many bits per "buxel", total
} DUMMYUNIONNAMEN(1);
union {
DWORD dwRBitMask; // mask for red bit
DWORD dwYBitMask; // mask for Y bits
DWORD dwStencilBitDepth; // how many stencil bits (note: dwZBufferBitDepth-dwStencilBitDepth is total Z-only bits)
DWORD dwLuminanceBitMask; // mask for luminance bits
DWORD dwBumpDuBitMask; // mask for bump map U delta bits
} DUMMYUNIONNAMEN(2);
union {
DWORD dwGBitMask; // mask for green bits
DWORD dwUBitMask; // mask for U bits
DWORD dwZBitMask; // mask for Z bits
DWORD dwBumpDvBitMask; // mask for bump map V delta bits
} DUMMYUNIONNAMEN(3);
union {
DWORD dwBBitMask; // mask for blue bits
DWORD dwVBitMask; // mask for V bits
DWORD dwStencilBitMask; // mask for stencil bits
DWORD dwBumpLuminanceBitMask; // mask for luminance in bump map
} DUMMYUNIONNAMEN(4);
union {
DWORD dwRGBAlphaBitMask; // mask for alpha channel
DWORD dwYUVAlphaBitMask; // mask for alpha channel
DWORD dwLuminanceAlphaBitMask; // mask for alpha channel
DWORD dwRGBZBitMask; // mask for Z channel
DWORD dwYUVZBitMask; // mask for Z channel
} DUMMYUNIONNAMEN(5);
} DDPIXELFORMAT;
typedef DDPIXELFORMAT FAR *LPDDPIXELFORMAT;
/*
* DDOVERLAYFX
*/
typedef struct _DDOVERLAYFX {
DWORD dwSize; // size of structure
DWORD dwAlphaEdgeBlendBitDepth; // Bit depth used to specify constant for alpha edge blend
DWORD dwAlphaEdgeBlend; // Constant to use as alpha for edge blend
DWORD dwReserved;
DWORD dwAlphaDestConstBitDepth; // Bit depth used to specify alpha constant for destination
union {
DWORD dwAlphaDestConst; // Constant to use as alpha channel for dest
LPDIRECTDRAWSURFACE lpDDSAlphaDest; // Surface to use as alpha channel for dest
} DUMMYUNIONNAMEN(1);
DWORD dwAlphaSrcConstBitDepth; // Bit depth used to specify alpha constant for source
union {
DWORD dwAlphaSrcConst; // Constant to use as alpha channel for src
LPDIRECTDRAWSURFACE lpDDSAlphaSrc; // Surface to use as alpha channel for src
} DUMMYUNIONNAMEN(2);
DDCOLORKEY dckDestColorkey; // DestColorkey override
DDCOLORKEY dckSrcColorkey; // DestColorkey override
DWORD dwDDFX; // Overlay FX
DWORD dwFlags; // flags
} DDOVERLAYFX;
typedef DDOVERLAYFX FAR *LPDDOVERLAYFX;
/*
* DDBLTBATCH: BltBatch entry structure
*/
typedef struct _DDBLTBATCH {
LPRECT lprDest;
LPDIRECTDRAWSURFACE lpDDSSrc;
LPRECT lprSrc;
DWORD dwFlags;
LPDDBLTFX lpDDBltFx;
} DDBLTBATCH;
typedef DDBLTBATCH FAR *LPDDBLTBATCH;
/*
* DDGAMMARAMP
*/
typedef struct _DDGAMMARAMP {
WORD red[256];
WORD green[256];
WORD blue[256];
} DDGAMMARAMP;
typedef DDGAMMARAMP FAR *LPDDGAMMARAMP;
/*
* This is the structure within which DirectDraw returns data about the current graphics driver and chipset
*/
#define MAX_DDDEVICEID_STRING 512
typedef struct tagDDDEVICEIDENTIFIER {
/*
* These elements are for presentation to the user only. They should not be used to identify particular
* drivers, since this is unreliable and many different strings may be associated with the same
* device, and the same driver from different vendors.
*/
char szDriver[MAX_DDDEVICEID_STRING];
char szDescription[MAX_DDDEVICEID_STRING];
/*
* This element is the version of the DirectDraw/3D driver. It is legal to do <, > comparisons
* on the whole 64 bits. Caution should be exercised if you use this element to identify problematic
* drivers. It is recommended that guidDeviceIdentifier is used for this purpose.
*
* This version has the form:
* wProduct = HIWORD(liDriverVersion.HighPart)
* wVersion = LOWORD(liDriverVersion.HighPart)
* wSubVersion = HIWORD(liDriverVersion.LowPart)
* wBuild = LOWORD(liDriverVersion.LowPart)
*/
#ifdef _WIN32
LARGE_INTEGER liDriverVersion; /* Defined for applications and other 32 bit components */
#else
DWORD dwDriverVersionLowPart; /* Defined for 16 bit driver components */
DWORD dwDriverVersionHighPart;
#endif
/*
* These elements can be used to identify particular chipsets. Use with extreme caution.
* dwVendorId Identifies the manufacturer. May be zero if unknown.
* dwDeviceId Identifies the type of chipset. May be zero if unknown.
* dwSubSysId Identifies the subsystem, typically this means the particular board. May be zero if unknown.
* dwRevision Identifies the revision level of the chipset. May be zero if unknown.
*/
DWORD dwVendorId;
DWORD dwDeviceId;
DWORD dwSubSysId;
DWORD dwRevision;
/*
* This element can be used to check changes in driver/chipset. This GUID is a unique identifier for the
* driver/chipset pair. Use this element if you wish to track changes to the driver/chipset in order to
* reprofile the graphics subsystem.
* This element can also be used to identify particular problematic drivers.
*/
GUID guidDeviceIdentifier;
} DDDEVICEIDENTIFIER, *LPDDDEVICEIDENTIFIER;
/*
* Flags for the IDirectDraw4::GetDeviceIdentifier method
*/
/*
* This flag causes GetDeviceIdentifier to return information about the host (typically 2D) adapter in a system equipped
* with a stacked secondary 3D adapter. Such an adapter appears to the application as if it were part of the
* host adapter, but is typically physcially located on a separate card. The stacked secondary's information is
* returned when GetDeviceIdentifier's dwFlags field is zero, since this most accurately reflects the qualities
* of the DirectDraw object involved.
*/
#define DDGDI_GETHOSTIDENTIFIER 0x00000001L
/*
* callbacks
*/
typedef DWORD(FAR PASCAL *LPCLIPPERCALLBACK)(LPDIRECTDRAWCLIPPER lpDDClipper, HWND hWnd, DWORD code, LPVOID lpContext);
#ifdef STREAMING
typedef DWORD(FAR PASCAL *LPSURFACESTREAMINGCALLBACK)(DWORD);
#endif
/*
* INTERACES FOLLOW:
* IDirectDraw
* IDirectDrawClipper
* IDirectDrawPalette
* IDirectDrawSurface
*/
/*
* IDirectDraw
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDraw
DECLARE_INTERFACE_(IDirectDraw, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDraw methods ***/
STDMETHOD(Compact)(THIS) PURE;
STDMETHOD(CreateClipper)(THIS_ DWORD, LPDIRECTDRAWCLIPPER FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreatePalette)(THIS_ DWORD, LPPALETTEENTRY, LPDIRECTDRAWPALETTE FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreateSurface)(THIS_ LPDDSURFACEDESC, LPDIRECTDRAWSURFACE FAR *, IUnknown FAR *) PURE;
STDMETHOD(DuplicateSurface)(THIS_ LPDIRECTDRAWSURFACE, LPDIRECTDRAWSURFACE FAR *) PURE;
STDMETHOD(EnumDisplayModes)(THIS_ DWORD, LPDDSURFACEDESC, LPVOID, LPDDENUMMODESCALLBACK) PURE;
STDMETHOD(EnumSurfaces)(THIS_ DWORD, LPDDSURFACEDESC, LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(FlipToGDISurface)(THIS) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDCAPS, LPDDCAPS) PURE;
STDMETHOD(GetDisplayMode)(THIS_ LPDDSURFACEDESC) PURE;
STDMETHOD(GetFourCCCodes)(THIS_ LPDWORD, LPDWORD) PURE;
STDMETHOD(GetGDISurface)(THIS_ LPDIRECTDRAWSURFACE FAR *) PURE;
STDMETHOD(GetMonitorFrequency)(THIS_ LPDWORD) PURE;
STDMETHOD(GetScanLine)(THIS_ LPDWORD) PURE;
STDMETHOD(GetVerticalBlankStatus)(THIS_ LPBOOL) PURE;
STDMETHOD(Initialize)(THIS_ GUID FAR *) PURE;
STDMETHOD(RestoreDisplayMode)(THIS) PURE;
STDMETHOD(SetCooperativeLevel)(THIS_ HWND, DWORD) PURE;
STDMETHOD(SetDisplayMode)(THIS_ DWORD, DWORD, DWORD) PURE;
STDMETHOD(WaitForVerticalBlank)(THIS_ DWORD, HANDLE) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDraw_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDraw_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDraw_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDraw_Compact(p) (p)->lpVtbl->Compact(p)
#define IDirectDraw_CreateClipper(p, a, b, c) (p)->lpVtbl->CreateClipper(p, a, b, c)
#define IDirectDraw_CreatePalette(p, a, b, c, d) (p)->lpVtbl->CreatePalette(p, a, b, c, d)
#define IDirectDraw_CreateSurface(p, a, b, c) (p)->lpVtbl->CreateSurface(p, a, b, c)
#define IDirectDraw_DuplicateSurface(p, a, b) (p)->lpVtbl->DuplicateSurface(p, a, b)
#define IDirectDraw_EnumDisplayModes(p, a, b, c, d) (p)->lpVtbl->EnumDisplayModes(p, a, b, c, d)
#define IDirectDraw_EnumSurfaces(p, a, b, c, d) (p)->lpVtbl->EnumSurfaces(p, a, b, c, d)
#define IDirectDraw_FlipToGDISurface(p) (p)->lpVtbl->FlipToGDISurface(p)
#define IDirectDraw_GetCaps(p, a, b) (p)->lpVtbl->GetCaps(p, a, b)
#define IDirectDraw_GetDisplayMode(p, a) (p)->lpVtbl->GetDisplayMode(p, a)
#define IDirectDraw_GetFourCCCodes(p, a, b) (p)->lpVtbl->GetFourCCCodes(p, a, b)
#define IDirectDraw_GetGDISurface(p, a) (p)->lpVtbl->GetGDISurface(p, a)
#define IDirectDraw_GetMonitorFrequency(p, a) (p)->lpVtbl->GetMonitorFrequency(p, a)
#define IDirectDraw_GetScanLine(p, a) (p)->lpVtbl->GetScanLine(p, a)
#define IDirectDraw_GetVerticalBlankStatus(p, a) (p)->lpVtbl->GetVerticalBlankStatus(p, a)
#define IDirectDraw_Initialize(p, a) (p)->lpVtbl->Initialize(p, a)
#define IDirectDraw_RestoreDisplayMode(p) (p)->lpVtbl->RestoreDisplayMode(p)
#define IDirectDraw_SetCooperativeLevel(p, a, b) (p)->lpVtbl->SetCooperativeLevel(p, a, b)
#define IDirectDraw_SetDisplayMode(p, a, b, c) (p)->lpVtbl->SetDisplayMode(p, a, b, c)
#define IDirectDraw_WaitForVerticalBlank(p, a, b) (p)->lpVtbl->WaitForVerticalBlank(p, a, b)
#else
#define IDirectDraw_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDraw_AddRef(p) (p)->AddRef()
#define IDirectDraw_Release(p) (p)->Release()
#define IDirectDraw_Compact(p) (p)->Compact()
#define IDirectDraw_CreateClipper(p, a, b, c) (p)->CreateClipper(a, b, c)
#define IDirectDraw_CreatePalette(p, a, b, c, d) (p)->CreatePalette(a, b, c, d)
#define IDirectDraw_CreateSurface(p, a, b, c) (p)->CreateSurface(a, b, c)
#define IDirectDraw_DuplicateSurface(p, a, b) (p)->DuplicateSurface(a, b)
#define IDirectDraw_EnumDisplayModes(p, a, b, c, d) (p)->EnumDisplayModes(a, b, c, d)
#define IDirectDraw_EnumSurfaces(p, a, b, c, d) (p)->EnumSurfaces(a, b, c, d)
#define IDirectDraw_FlipToGDISurface(p) (p)->FlipToGDISurface()
#define IDirectDraw_GetCaps(p, a, b) (p)->GetCaps(a, b)
#define IDirectDraw_GetDisplayMode(p, a) (p)->GetDisplayMode(a)
#define IDirectDraw_GetFourCCCodes(p, a, b) (p)->GetFourCCCodes(a, b)
#define IDirectDraw_GetGDISurface(p, a) (p)->GetGDISurface(a)
#define IDirectDraw_GetMonitorFrequency(p, a) (p)->GetMonitorFrequency(a)
#define IDirectDraw_GetScanLine(p, a) (p)->GetScanLine(a)
#define IDirectDraw_GetVerticalBlankStatus(p, a) (p)->GetVerticalBlankStatus(a)
#define IDirectDraw_Initialize(p, a) (p)->Initialize(a)
#define IDirectDraw_RestoreDisplayMode(p) (p)->RestoreDisplayMode()
#define IDirectDraw_SetCooperativeLevel(p, a, b) (p)->SetCooperativeLevel(a, b)
#define IDirectDraw_SetDisplayMode(p, a, b, c) (p)->SetDisplayMode(a, b, c)
#define IDirectDraw_WaitForVerticalBlank(p, a, b) (p)->WaitForVerticalBlank(a, b)
#endif
#endif
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDraw2
DECLARE_INTERFACE_(IDirectDraw2, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDraw methods ***/
STDMETHOD(Compact)(THIS) PURE;
STDMETHOD(CreateClipper)(THIS_ DWORD, LPDIRECTDRAWCLIPPER FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreatePalette)(THIS_ DWORD, LPPALETTEENTRY, LPDIRECTDRAWPALETTE FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreateSurface)(THIS_ LPDDSURFACEDESC, LPDIRECTDRAWSURFACE FAR *, IUnknown FAR *) PURE;
STDMETHOD(DuplicateSurface)(THIS_ LPDIRECTDRAWSURFACE, LPDIRECTDRAWSURFACE FAR *) PURE;
STDMETHOD(EnumDisplayModes)(THIS_ DWORD, LPDDSURFACEDESC, LPVOID, LPDDENUMMODESCALLBACK) PURE;
STDMETHOD(EnumSurfaces)(THIS_ DWORD, LPDDSURFACEDESC, LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(FlipToGDISurface)(THIS) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDCAPS, LPDDCAPS) PURE;
STDMETHOD(GetDisplayMode)(THIS_ LPDDSURFACEDESC) PURE;
STDMETHOD(GetFourCCCodes)(THIS_ LPDWORD, LPDWORD) PURE;
STDMETHOD(GetGDISurface)(THIS_ LPDIRECTDRAWSURFACE FAR *) PURE;
STDMETHOD(GetMonitorFrequency)(THIS_ LPDWORD) PURE;
STDMETHOD(GetScanLine)(THIS_ LPDWORD) PURE;
STDMETHOD(GetVerticalBlankStatus)(THIS_ LPBOOL) PURE;
STDMETHOD(Initialize)(THIS_ GUID FAR *) PURE;
STDMETHOD(RestoreDisplayMode)(THIS) PURE;
STDMETHOD(SetCooperativeLevel)(THIS_ HWND, DWORD) PURE;
STDMETHOD(SetDisplayMode)(THIS_ DWORD, DWORD, DWORD, DWORD, DWORD) PURE;
STDMETHOD(WaitForVerticalBlank)(THIS_ DWORD, HANDLE) PURE;
/*** Added in the v2 interface ***/
STDMETHOD(GetAvailableVidMem)(THIS_ LPDDSCAPS, LPDWORD, LPDWORD) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDraw2_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDraw2_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDraw2_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDraw2_Compact(p) (p)->lpVtbl->Compact(p)
#define IDirectDraw2_CreateClipper(p, a, b, c) (p)->lpVtbl->CreateClipper(p, a, b, c)
#define IDirectDraw2_CreatePalette(p, a, b, c, d) (p)->lpVtbl->CreatePalette(p, a, b, c, d)
#define IDirectDraw2_CreateSurface(p, a, b, c) (p)->lpVtbl->CreateSurface(p, a, b, c)
#define IDirectDraw2_DuplicateSurface(p, a, b) (p)->lpVtbl->DuplicateSurface(p, a, b)
#define IDirectDraw2_EnumDisplayModes(p, a, b, c, d) (p)->lpVtbl->EnumDisplayModes(p, a, b, c, d)
#define IDirectDraw2_EnumSurfaces(p, a, b, c, d) (p)->lpVtbl->EnumSurfaces(p, a, b, c, d)
#define IDirectDraw2_FlipToGDISurface(p) (p)->lpVtbl->FlipToGDISurface(p)
#define IDirectDraw2_GetCaps(p, a, b) (p)->lpVtbl->GetCaps(p, a, b)
#define IDirectDraw2_GetDisplayMode(p, a) (p)->lpVtbl->GetDisplayMode(p, a)
#define IDirectDraw2_GetFourCCCodes(p, a, b) (p)->lpVtbl->GetFourCCCodes(p, a, b)
#define IDirectDraw2_GetGDISurface(p, a) (p)->lpVtbl->GetGDISurface(p, a)
#define IDirectDraw2_GetMonitorFrequency(p, a) (p)->lpVtbl->GetMonitorFrequency(p, a)
#define IDirectDraw2_GetScanLine(p, a) (p)->lpVtbl->GetScanLine(p, a)
#define IDirectDraw2_GetVerticalBlankStatus(p, a) (p)->lpVtbl->GetVerticalBlankStatus(p, a)
#define IDirectDraw2_Initialize(p, a) (p)->lpVtbl->Initialize(p, a)
#define IDirectDraw2_RestoreDisplayMode(p) (p)->lpVtbl->RestoreDisplayMode(p)
#define IDirectDraw2_SetCooperativeLevel(p, a, b) (p)->lpVtbl->SetCooperativeLevel(p, a, b)
#define IDirectDraw2_SetDisplayMode(p, a, b, c, d, e) (p)->lpVtbl->SetDisplayMode(p, a, b, c, d, e)
#define IDirectDraw2_WaitForVerticalBlank(p, a, b) (p)->lpVtbl->WaitForVerticalBlank(p, a, b)
#define IDirectDraw2_GetAvailableVidMem(p, a, b, c) (p)->lpVtbl->GetAvailableVidMem(p, a, b, c)
#else
#define IDirectDraw2_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDraw2_AddRef(p) (p)->AddRef()
#define IDirectDraw2_Release(p) (p)->Release()
#define IDirectDraw2_Compact(p) (p)->Compact()
#define IDirectDraw2_CreateClipper(p, a, b, c) (p)->CreateClipper(a, b, c)
#define IDirectDraw2_CreatePalette(p, a, b, c, d) (p)->CreatePalette(a, b, c, d)
#define IDirectDraw2_CreateSurface(p, a, b, c) (p)->CreateSurface(a, b, c)
#define IDirectDraw2_DuplicateSurface(p, a, b) (p)->DuplicateSurface(a, b)
#define IDirectDraw2_EnumDisplayModes(p, a, b, c, d) (p)->EnumDisplayModes(a, b, c, d)
#define IDirectDraw2_EnumSurfaces(p, a, b, c, d) (p)->EnumSurfaces(a, b, c, d)
#define IDirectDraw2_FlipToGDISurface(p) (p)->FlipToGDISurface()
#define IDirectDraw2_GetCaps(p, a, b) (p)->GetCaps(a, b)
#define IDirectDraw2_GetDisplayMode(p, a) (p)->GetDisplayMode(a)
#define IDirectDraw2_GetFourCCCodes(p, a, b) (p)->GetFourCCCodes(a, b)
#define IDirectDraw2_GetGDISurface(p, a) (p)->GetGDISurface(a)
#define IDirectDraw2_GetMonitorFrequency(p, a) (p)->GetMonitorFrequency(a)
#define IDirectDraw2_GetScanLine(p, a) (p)->GetScanLine(a)
#define IDirectDraw2_GetVerticalBlankStatus(p, a) (p)->GetVerticalBlankStatus(a)
#define IDirectDraw2_Initialize(p, a) (p)->Initialize(a)
#define IDirectDraw2_RestoreDisplayMode(p) (p)->RestoreDisplayMode()
#define IDirectDraw2_SetCooperativeLevel(p, a, b) (p)->SetCooperativeLevel(a, b)
#define IDirectDraw2_SetDisplayMode(p, a, b, c, d, e) (p)->SetDisplayMode(a, b, c, d, e)
#define IDirectDraw2_WaitForVerticalBlank(p, a, b) (p)->WaitForVerticalBlank(a, b)
#define IDirectDraw2_GetAvailableVidMem(p, a, b, c) (p)->GetAvailableVidMem(a, b, c)
#endif
#endif
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDraw4
DECLARE_INTERFACE_(IDirectDraw4, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDraw methods ***/
STDMETHOD(Compact)(THIS) PURE;
STDMETHOD(CreateClipper)(THIS_ DWORD, LPDIRECTDRAWCLIPPER FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreatePalette)(THIS_ DWORD, LPPALETTEENTRY, LPDIRECTDRAWPALETTE FAR *, IUnknown FAR *) PURE;
STDMETHOD(CreateSurface)(THIS_ LPDDSURFACEDESC2, LPDIRECTDRAWSURFACE4 FAR *, IUnknown FAR *) PURE;
STDMETHOD(DuplicateSurface)(THIS_ LPDIRECTDRAWSURFACE4, LPDIRECTDRAWSURFACE4 FAR *) PURE;
STDMETHOD(EnumDisplayModes)(THIS_ DWORD, LPDDSURFACEDESC2, LPVOID, LPDDENUMMODESCALLBACK2) PURE;
STDMETHOD(EnumSurfaces)(THIS_ DWORD, LPDDSURFACEDESC2, LPVOID, LPDDENUMSURFACESCALLBACK2) PURE;
STDMETHOD(FlipToGDISurface)(THIS) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDCAPS, LPDDCAPS) PURE;
STDMETHOD(GetDisplayMode)(THIS_ LPDDSURFACEDESC2) PURE;
STDMETHOD(GetFourCCCodes)(THIS_ LPDWORD, LPDWORD) PURE;
STDMETHOD(GetGDISurface)(THIS_ LPDIRECTDRAWSURFACE4 FAR *) PURE;
STDMETHOD(GetMonitorFrequency)(THIS_ LPDWORD) PURE;
STDMETHOD(GetScanLine)(THIS_ LPDWORD) PURE;
STDMETHOD(GetVerticalBlankStatus)(THIS_ LPBOOL) PURE;
STDMETHOD(Initialize)(THIS_ GUID FAR *) PURE;
STDMETHOD(RestoreDisplayMode)(THIS) PURE;
STDMETHOD(SetCooperativeLevel)(THIS_ HWND, DWORD) PURE;
STDMETHOD(SetDisplayMode)(THIS_ DWORD, DWORD, DWORD, DWORD, DWORD) PURE;
STDMETHOD(WaitForVerticalBlank)(THIS_ DWORD, HANDLE) PURE;
/*** Added in the v2 interface ***/
STDMETHOD(GetAvailableVidMem)(THIS_ LPDDSCAPS2, LPDWORD, LPDWORD) PURE;
/*** Added in the V4 Interface ***/
STDMETHOD(GetSurfaceFromDC)(THIS_ HDC, LPDIRECTDRAWSURFACE4 *) PURE;
STDMETHOD(RestoreAllSurfaces)(THIS) PURE;
STDMETHOD(TestCooperativeLevel)(THIS) PURE;
STDMETHOD(GetDeviceIdentifier)(THIS_ LPDDDEVICEIDENTIFIER, DWORD) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDraw4_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDraw4_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDraw4_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDraw4_Compact(p) (p)->lpVtbl->Compact(p)
#define IDirectDraw4_CreateClipper(p, a, b, c) (p)->lpVtbl->CreateClipper(p, a, b, c)
#define IDirectDraw4_CreatePalette(p, a, b, c, d) (p)->lpVtbl->CreatePalette(p, a, b, c, d)
#define IDirectDraw4_CreateSurface(p, a, b, c) (p)->lpVtbl->CreateSurface(p, a, b, c)
#define IDirectDraw4_DuplicateSurface(p, a, b) (p)->lpVtbl->DuplicateSurface(p, a, b)
#define IDirectDraw4_EnumDisplayModes(p, a, b, c, d) (p)->lpVtbl->EnumDisplayModes(p, a, b, c, d)
#define IDirectDraw4_EnumSurfaces(p, a, b, c, d) (p)->lpVtbl->EnumSurfaces(p, a, b, c, d)
#define IDirectDraw4_FlipToGDISurface(p) (p)->lpVtbl->FlipToGDISurface(p)
#define IDirectDraw4_GetCaps(p, a, b) (p)->lpVtbl->GetCaps(p, a, b)
#define IDirectDraw4_GetDisplayMode(p, a) (p)->lpVtbl->GetDisplayMode(p, a)
#define IDirectDraw4_GetFourCCCodes(p, a, b) (p)->lpVtbl->GetFourCCCodes(p, a, b)
#define IDirectDraw4_GetGDISurface(p, a) (p)->lpVtbl->GetGDISurface(p, a)
#define IDirectDraw4_GetMonitorFrequency(p, a) (p)->lpVtbl->GetMonitorFrequency(p, a)
#define IDirectDraw4_GetScanLine(p, a) (p)->lpVtbl->GetScanLine(p, a)
#define IDirectDraw4_GetVerticalBlankStatus(p, a) (p)->lpVtbl->GetVerticalBlankStatus(p, a)
#define IDirectDraw4_Initialize(p, a) (p)->lpVtbl->Initialize(p, a)
#define IDirectDraw4_RestoreDisplayMode(p) (p)->lpVtbl->RestoreDisplayMode(p)
#define IDirectDraw4_SetCooperativeLevel(p, a, b) (p)->lpVtbl->SetCooperativeLevel(p, a, b)
#define IDirectDraw4_SetDisplayMode(p, a, b, c, d, e) (p)->lpVtbl->SetDisplayMode(p, a, b, c, d, e)
#define IDirectDraw4_WaitForVerticalBlank(p, a, b) (p)->lpVtbl->WaitForVerticalBlank(p, a, b)
#define IDirectDraw4_GetAvailableVidMem(p, a, b, c) (p)->lpVtbl->GetAvailableVidMem(p, a, b, c)
#define IDirectDraw4_GetSurfaceFromDC(p, a, b) (p)->lpVtbl->GetSurfaceFromDC(p, a, b)
#define IDirectDraw4_RestoreAllSurfaces(p) (p)->lpVtbl->RestoreAllSurfaces(p)
#define IDirectDraw4_TestCooperativeLevel(p) (p)->lpVtbl->TestCooperativeLevel(p)
#define IDirectDraw4_GetDeviceIdentifier(p, a, b) (p)->lpVtbl->GetDeviceIdentifier(p, a, b)
#else
#define IDirectDraw4_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDraw4_AddRef(p) (p)->AddRef()
#define IDirectDraw4_Release(p) (p)->Release()
#define IDirectDraw4_Compact(p) (p)->Compact()
#define IDirectDraw4_CreateClipper(p, a, b, c) (p)->CreateClipper(a, b, c)
#define IDirectDraw4_CreatePalette(p, a, b, c, d) (p)->CreatePalette(a, b, c, d)
#define IDirectDraw4_CreateSurface(p, a, b, c) (p)->CreateSurface(a, b, c)
#define IDirectDraw4_DuplicateSurface(p, a, b) (p)->DuplicateSurface(a, b)
#define IDirectDraw4_EnumDisplayModes(p, a, b, c, d) (p)->EnumDisplayModes(a, b, c, d)
#define IDirectDraw4_EnumSurfaces(p, a, b, c, d) (p)->EnumSurfaces(a, b, c, d)
#define IDirectDraw4_FlipToGDISurface(p) (p)->FlipToGDISurface()
#define IDirectDraw4_GetCaps(p, a, b) (p)->GetCaps(a, b)
#define IDirectDraw4_GetDisplayMode(p, a) (p)->GetDisplayMode(a)
#define IDirectDraw4_GetFourCCCodes(p, a, b) (p)->GetFourCCCodes(a, b)
#define IDirectDraw4_GetGDISurface(p, a) (p)->GetGDISurface(a)
#define IDirectDraw4_GetMonitorFrequency(p, a) (p)->GetMonitorFrequency(a)
#define IDirectDraw4_GetScanLine(p, a) (p)->GetScanLine(a)
#define IDirectDraw4_GetVerticalBlankStatus(p, a) (p)->GetVerticalBlankStatus(a)
#define IDirectDraw4_Initialize(p, a) (p)->Initialize(a)
#define IDirectDraw4_RestoreDisplayMode(p) (p)->RestoreDisplayMode()
#define IDirectDraw4_SetCooperativeLevel(p, a, b) (p)->SetCooperativeLevel(a, b)
#define IDirectDraw4_SetDisplayMode(p, a, b, c, d, e) (p)->SetDisplayMode(a, b, c, d, e)
#define IDirectDraw4_WaitForVerticalBlank(p, a, b) (p)->WaitForVerticalBlank(a, b)
#define IDirectDraw4_GetAvailableVidMem(p, a, b, c) (p)->GetAvailableVidMem(a, b, c)
#define IDirectDraw4_GetSurfaceFromDC(p, a, b) (p)->GetSurfaceFromDC(a, b)
#define IDirectDraw4_RestoreAllSurfaces(p) (p)->RestoreAllSurfaces()
#define IDirectDraw4_TestCooperativeLevel(p) (p)->TestCooperativeLevel()
#define IDirectDraw4_GetDeviceIdentifier(p, a, b) (p)->GetDeviceIdentifier(a, b)
#endif
#endif
/*
* IDirectDrawPalette
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDrawPalette
DECLARE_INTERFACE_(IDirectDrawPalette, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawPalette methods ***/
STDMETHOD(GetCaps)(THIS_ LPDWORD) PURE;
STDMETHOD(GetEntries)(THIS_ DWORD, DWORD, DWORD, LPPALETTEENTRY) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, DWORD, LPPALETTEENTRY) PURE;
STDMETHOD(SetEntries)(THIS_ DWORD, DWORD, DWORD, LPPALETTEENTRY) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawPalette_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawPalette_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawPalette_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawPalette_GetCaps(p, a) (p)->lpVtbl->GetCaps(p, a)
#define IDirectDrawPalette_GetEntries(p, a, b, c, d) (p)->lpVtbl->GetEntries(p, a, b, c, d)
#define IDirectDrawPalette_Initialize(p, a, b, c) (p)->lpVtbl->Initialize(p, a, b, c)
#define IDirectDrawPalette_SetEntries(p, a, b, c, d) (p)->lpVtbl->SetEntries(p, a, b, c, d)
#else
#define IDirectDrawPalette_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawPalette_AddRef(p) (p)->AddRef()
#define IDirectDrawPalette_Release(p) (p)->Release()
#define IDirectDrawPalette_GetCaps(p, a) (p)->GetCaps(a)
#define IDirectDrawPalette_GetEntries(p, a, b, c, d) (p)->GetEntries(a, b, c, d)
#define IDirectDrawPalette_Initialize(p, a, b, c) (p)->Initialize(a, b, c)
#define IDirectDrawPalette_SetEntries(p, a, b, c, d) (p)->SetEntries(a, b, c, d)
#endif
#endif
/*
* IDirectDrawClipper
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDrawClipper
DECLARE_INTERFACE_(IDirectDrawClipper, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawClipper methods ***/
STDMETHOD(GetClipList)(THIS_ LPRECT, LPRGNDATA, LPDWORD) PURE;
STDMETHOD(GetHWnd)(THIS_ HWND FAR *) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, DWORD) PURE;
STDMETHOD(IsClipListChanged)(THIS_ BOOL FAR *) PURE;
STDMETHOD(SetClipList)(THIS_ LPRGNDATA, DWORD) PURE;
STDMETHOD(SetHWnd)(THIS_ DWORD, HWND) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawClipper_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawClipper_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawClipper_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawClipper_GetClipList(p, a, b, c) (p)->lpVtbl->GetClipList(p, a, b, c)
#define IDirectDrawClipper_GetHWnd(p, a) (p)->lpVtbl->GetHWnd(p, a)
#define IDirectDrawClipper_Initialize(p, a, b) (p)->lpVtbl->Initialize(p, a, b)
#define IDirectDrawClipper_IsClipListChanged(p, a) (p)->lpVtbl->IsClipListChanged(p, a)
#define IDirectDrawClipper_SetClipList(p, a, b) (p)->lpVtbl->SetClipList(p, a, b)
#define IDirectDrawClipper_SetHWnd(p, a, b) (p)->lpVtbl->SetHWnd(p, a, b)
#else
#define IDirectDrawClipper_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawClipper_AddRef(p) (p)->AddRef()
#define IDirectDrawClipper_Release(p) (p)->Release()
#define IDirectDrawClipper_GetClipList(p, a, b, c) (p)->GetClipList(a, b, c)
#define IDirectDrawClipper_GetHWnd(p, a) (p)->GetHWnd(a)
#define IDirectDrawClipper_Initialize(p, a, b) (p)->Initialize(a, b)
#define IDirectDrawClipper_IsClipListChanged(p, a) (p)->IsClipListChanged(a)
#define IDirectDrawClipper_SetClipList(p, a, b) (p)->SetClipList(a, b)
#define IDirectDrawClipper_SetHWnd(p, a, b) (p)->SetHWnd(a, b)
#endif
#endif
/*
* IDirectDrawSurface and related interfaces
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDrawSurface
DECLARE_INTERFACE_(IDirectDrawSurface, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawSurface methods ***/
STDMETHOD(AddAttachedSurface)(THIS_ LPDIRECTDRAWSURFACE) PURE;
STDMETHOD(AddOverlayDirtyRect)(THIS_ LPRECT) PURE;
STDMETHOD(Blt)(THIS_ LPRECT, LPDIRECTDRAWSURFACE, LPRECT, DWORD, LPDDBLTFX) PURE;
STDMETHOD(BltBatch)(THIS_ LPDDBLTBATCH, DWORD, DWORD) PURE;
STDMETHOD(BltFast)(THIS_ DWORD, DWORD, LPDIRECTDRAWSURFACE, LPRECT, DWORD) PURE;
STDMETHOD(DeleteAttachedSurface)(THIS_ DWORD, LPDIRECTDRAWSURFACE) PURE;
STDMETHOD(EnumAttachedSurfaces)(THIS_ LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(EnumOverlayZOrders)(THIS_ DWORD, LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(Flip)(THIS_ LPDIRECTDRAWSURFACE, DWORD) PURE;
STDMETHOD(GetAttachedSurface)(THIS_ LPDDSCAPS, LPDIRECTDRAWSURFACE FAR *) PURE;
STDMETHOD(GetBltStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDSCAPS) PURE;
STDMETHOD(GetClipper)(THIS_ LPDIRECTDRAWCLIPPER FAR *) PURE;
STDMETHOD(GetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(GetDC)(THIS_ HDC FAR *) PURE;
STDMETHOD(GetFlipStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetOverlayPosition)(THIS_ LPLONG, LPLONG) PURE;
STDMETHOD(GetPalette)(THIS_ LPDIRECTDRAWPALETTE FAR *) PURE;
STDMETHOD(GetPixelFormat)(THIS_ LPDDPIXELFORMAT) PURE;
STDMETHOD(GetSurfaceDesc)(THIS_ LPDDSURFACEDESC) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, LPDDSURFACEDESC) PURE;
STDMETHOD(IsLost)(THIS) PURE;
STDMETHOD(Lock)(THIS_ LPRECT, LPDDSURFACEDESC, DWORD, HANDLE) PURE;
STDMETHOD(ReleaseDC)(THIS_ HDC) PURE;
STDMETHOD(Restore)(THIS) PURE;
STDMETHOD(SetClipper)(THIS_ LPDIRECTDRAWCLIPPER) PURE;
STDMETHOD(SetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(SetOverlayPosition)(THIS_ LONG, LONG) PURE;
STDMETHOD(SetPalette)(THIS_ LPDIRECTDRAWPALETTE) PURE;
STDMETHOD(Unlock)(THIS_ LPVOID) PURE;
STDMETHOD(UpdateOverlay)(THIS_ LPRECT, LPDIRECTDRAWSURFACE, LPRECT, DWORD, LPDDOVERLAYFX) PURE;
STDMETHOD(UpdateOverlayDisplay)(THIS_ DWORD) PURE;
STDMETHOD(UpdateOverlayZOrder)(THIS_ DWORD, LPDIRECTDRAWSURFACE) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawSurface_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawSurface_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawSurface_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawSurface_AddAttachedSurface(p, a) (p)->lpVtbl->AddAttachedSurface(p, a)
#define IDirectDrawSurface_AddOverlayDirtyRect(p, a) (p)->lpVtbl->AddOverlayDirtyRect(p, a)
#define IDirectDrawSurface_Blt(p, a, b, c, d, e) (p)->lpVtbl->Blt(p, a, b, c, d, e)
#define IDirectDrawSurface_BltBatch(p, a, b, c) (p)->lpVtbl->BltBatch(p, a, b, c)
#define IDirectDrawSurface_BltFast(p, a, b, c, d, e) (p)->lpVtbl->BltFast(p, a, b, c, d, e)
#define IDirectDrawSurface_DeleteAttachedSurface(p, a, b) (p)->lpVtbl->DeleteAttachedSurface(p, a, b)
#define IDirectDrawSurface_EnumAttachedSurfaces(p, a, b) (p)->lpVtbl->EnumAttachedSurfaces(p, a, b)
#define IDirectDrawSurface_EnumOverlayZOrders(p, a, b, c) (p)->lpVtbl->EnumOverlayZOrders(p, a, b, c)
#define IDirectDrawSurface_Flip(p, a, b) (p)->lpVtbl->Flip(p, a, b)
#define IDirectDrawSurface_GetAttachedSurface(p, a, b) (p)->lpVtbl->GetAttachedSurface(p, a, b)
#define IDirectDrawSurface_GetBltStatus(p, a) (p)->lpVtbl->GetBltStatus(p, a)
#define IDirectDrawSurface_GetCaps(p, b) (p)->lpVtbl->GetCaps(p, b)
#define IDirectDrawSurface_GetClipper(p, a) (p)->lpVtbl->GetClipper(p, a)
#define IDirectDrawSurface_GetColorKey(p, a, b) (p)->lpVtbl->GetColorKey(p, a, b)
#define IDirectDrawSurface_GetDC(p, a) (p)->lpVtbl->GetDC(p, a)
#define IDirectDrawSurface_GetFlipStatus(p, a) (p)->lpVtbl->GetFlipStatus(p, a)
#define IDirectDrawSurface_GetOverlayPosition(p, a, b) (p)->lpVtbl->GetOverlayPosition(p, a, b)
#define IDirectDrawSurface_GetPalette(p, a) (p)->lpVtbl->GetPalette(p, a)
#define IDirectDrawSurface_GetPixelFormat(p, a) (p)->lpVtbl->GetPixelFormat(p, a)
#define IDirectDrawSurface_GetSurfaceDesc(p, a) (p)->lpVtbl->GetSurfaceDesc(p, a)
#define IDirectDrawSurface_Initialize(p, a, b) (p)->lpVtbl->Initialize(p, a, b)
#define IDirectDrawSurface_IsLost(p) (p)->lpVtbl->IsLost(p)
#define IDirectDrawSurface_Lock(p, a, b, c, d) (p)->lpVtbl->Lock(p, a, b, c, d)
#define IDirectDrawSurface_ReleaseDC(p, a) (p)->lpVtbl->ReleaseDC(p, a)
#define IDirectDrawSurface_Restore(p) (p)->lpVtbl->Restore(p)
#define IDirectDrawSurface_SetClipper(p, a) (p)->lpVtbl->SetClipper(p, a)
#define IDirectDrawSurface_SetColorKey(p, a, b) (p)->lpVtbl->SetColorKey(p, a, b)
#define IDirectDrawSurface_SetOverlayPosition(p, a, b) (p)->lpVtbl->SetOverlayPosition(p, a, b)
#define IDirectDrawSurface_SetPalette(p, a) (p)->lpVtbl->SetPalette(p, a)
#define IDirectDrawSurface_Unlock(p, b) (p)->lpVtbl->Unlock(p, b)
#define IDirectDrawSurface_UpdateOverlay(p, a, b, c, d, e) (p)->lpVtbl->UpdateOverlay(p, a, b, c, d, e)
#define IDirectDrawSurface_UpdateOverlayDisplay(p, a) (p)->lpVtbl->UpdateOverlayDisplay(p, a)
#define IDirectDrawSurface_UpdateOverlayZOrder(p, a, b) (p)->lpVtbl->UpdateOverlayZOrder(p, a, b)
#else
#define IDirectDrawSurface_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawSurface_AddRef(p) (p)->AddRef()
#define IDirectDrawSurface_Release(p) (p)->Release()
#define IDirectDrawSurface_AddAttachedSurface(p, a) (p)->AddAttachedSurface(a)
#define IDirectDrawSurface_AddOverlayDirtyRect(p, a) (p)->AddOverlayDirtyRect(a)
#define IDirectDrawSurface_Blt(p, a, b, c, d, e) (p)->Blt(a, b, c, d, e)
#define IDirectDrawSurface_BltBatch(p, a, b, c) (p)->BltBatch(a, b, c)
#define IDirectDrawSurface_BltFast(p, a, b, c, d, e) (p)->BltFast(a, b, c, d, e)
#define IDirectDrawSurface_DeleteAttachedSurface(p, a, b) (p)->DeleteAttachedSurface(a, b)
#define IDirectDrawSurface_EnumAttachedSurfaces(p, a, b) (p)->EnumAttachedSurfaces(a, b)
#define IDirectDrawSurface_EnumOverlayZOrders(p, a, b, c) (p)->EnumOverlayZOrders(a, b, c)
#define IDirectDrawSurface_Flip(p, a, b) (p)->Flip(a, b)
#define IDirectDrawSurface_GetAttachedSurface(p, a, b) (p)->GetAttachedSurface(a, b)
#define IDirectDrawSurface_GetBltStatus(p, a) (p)->GetBltStatus(a)
#define IDirectDrawSurface_GetCaps(p, b) (p)->GetCaps(b)
#define IDirectDrawSurface_GetClipper(p, a) (p)->GetClipper(a)
#define IDirectDrawSurface_GetColorKey(p, a, b) (p)->GetColorKey(a, b)
#define IDirectDrawSurface_GetDC(p, a) (p)->GetDC(a)
#define IDirectDrawSurface_GetFlipStatus(p, a) (p)->GetFlipStatus(a)
#define IDirectDrawSurface_GetOverlayPosition(p, a, b) (p)->GetOverlayPosition(a, b)
#define IDirectDrawSurface_GetPalette(p, a) (p)->GetPalette(a)
#define IDirectDrawSurface_GetPixelFormat(p, a) (p)->GetPixelFormat(a)
#define IDirectDrawSurface_GetSurfaceDesc(p, a) (p)->GetSurfaceDesc(a)
#define IDirectDrawSurface_Initialize(p, a, b) (p)->Initialize(a, b)
#define IDirectDrawSurface_IsLost(p) (p)->IsLost()
#define IDirectDrawSurface_Lock(p, a, b, c, d) (p)->Lock(a, b, c, d)
#define IDirectDrawSurface_ReleaseDC(p, a) (p)->ReleaseDC(a)
#define IDirectDrawSurface_Restore(p) (p)->Restore()
#define IDirectDrawSurface_SetClipper(p, a) (p)->SetClipper(a)
#define IDirectDrawSurface_SetColorKey(p, a, b) (p)->SetColorKey(a, b)
#define IDirectDrawSurface_SetOverlayPosition(p, a, b) (p)->SetOverlayPosition(a, b)
#define IDirectDrawSurface_SetPalette(p, a) (p)->SetPalette(a)
#define IDirectDrawSurface_Unlock(p, b) (p)->Unlock(b)
#define IDirectDrawSurface_UpdateOverlay(p, a, b, c, d, e) (p)->UpdateOverlay(a, b, c, d, e)
#define IDirectDrawSurface_UpdateOverlayDisplay(p, a) (p)->UpdateOverlayDisplay(a)
#define IDirectDrawSurface_UpdateOverlayZOrder(p, a, b) (p)->UpdateOverlayZOrder(a, b)
#endif
/*
* IDirectDrawSurface2 and related interfaces
*/
#undef INTERFACE
#define INTERFACE IDirectDrawSurface2
DECLARE_INTERFACE_(IDirectDrawSurface2, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawSurface methods ***/
STDMETHOD(AddAttachedSurface)(THIS_ LPDIRECTDRAWSURFACE2) PURE;
STDMETHOD(AddOverlayDirtyRect)(THIS_ LPRECT) PURE;
STDMETHOD(Blt)(THIS_ LPRECT, LPDIRECTDRAWSURFACE2, LPRECT, DWORD, LPDDBLTFX) PURE;
STDMETHOD(BltBatch)(THIS_ LPDDBLTBATCH, DWORD, DWORD) PURE;
STDMETHOD(BltFast)(THIS_ DWORD, DWORD, LPDIRECTDRAWSURFACE2, LPRECT, DWORD) PURE;
STDMETHOD(DeleteAttachedSurface)(THIS_ DWORD, LPDIRECTDRAWSURFACE2) PURE;
STDMETHOD(EnumAttachedSurfaces)(THIS_ LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(EnumOverlayZOrders)(THIS_ DWORD, LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(Flip)(THIS_ LPDIRECTDRAWSURFACE2, DWORD) PURE;
STDMETHOD(GetAttachedSurface)(THIS_ LPDDSCAPS, LPDIRECTDRAWSURFACE2 FAR *) PURE;
STDMETHOD(GetBltStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDSCAPS) PURE;
STDMETHOD(GetClipper)(THIS_ LPDIRECTDRAWCLIPPER FAR *) PURE;
STDMETHOD(GetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(GetDC)(THIS_ HDC FAR *) PURE;
STDMETHOD(GetFlipStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetOverlayPosition)(THIS_ LPLONG, LPLONG) PURE;
STDMETHOD(GetPalette)(THIS_ LPDIRECTDRAWPALETTE FAR *) PURE;
STDMETHOD(GetPixelFormat)(THIS_ LPDDPIXELFORMAT) PURE;
STDMETHOD(GetSurfaceDesc)(THIS_ LPDDSURFACEDESC) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, LPDDSURFACEDESC) PURE;
STDMETHOD(IsLost)(THIS) PURE;
STDMETHOD(Lock)(THIS_ LPRECT, LPDDSURFACEDESC, DWORD, HANDLE) PURE;
STDMETHOD(ReleaseDC)(THIS_ HDC) PURE;
STDMETHOD(Restore)(THIS) PURE;
STDMETHOD(SetClipper)(THIS_ LPDIRECTDRAWCLIPPER) PURE;
STDMETHOD(SetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(SetOverlayPosition)(THIS_ LONG, LONG) PURE;
STDMETHOD(SetPalette)(THIS_ LPDIRECTDRAWPALETTE) PURE;
STDMETHOD(Unlock)(THIS_ LPVOID) PURE;
STDMETHOD(UpdateOverlay)(THIS_ LPRECT, LPDIRECTDRAWSURFACE2, LPRECT, DWORD, LPDDOVERLAYFX) PURE;
STDMETHOD(UpdateOverlayDisplay)(THIS_ DWORD) PURE;
STDMETHOD(UpdateOverlayZOrder)(THIS_ DWORD, LPDIRECTDRAWSURFACE2) PURE;
/*** Added in the v2 interface ***/
STDMETHOD(GetDDInterface)(THIS_ LPVOID FAR *) PURE;
STDMETHOD(PageLock)(THIS_ DWORD) PURE;
STDMETHOD(PageUnlock)(THIS_ DWORD) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawSurface2_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawSurface2_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawSurface2_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawSurface2_AddAttachedSurface(p, a) (p)->lpVtbl->AddAttachedSurface(p, a)
#define IDirectDrawSurface2_AddOverlayDirtyRect(p, a) (p)->lpVtbl->AddOverlayDirtyRect(p, a)
#define IDirectDrawSurface2_Blt(p, a, b, c, d, e) (p)->lpVtbl->Blt(p, a, b, c, d, e)
#define IDirectDrawSurface2_BltBatch(p, a, b, c) (p)->lpVtbl->BltBatch(p, a, b, c)
#define IDirectDrawSurface2_BltFast(p, a, b, c, d, e) (p)->lpVtbl->BltFast(p, a, b, c, d, e)
#define IDirectDrawSurface2_DeleteAttachedSurface(p, a, b) (p)->lpVtbl->DeleteAttachedSurface(p, a, b)
#define IDirectDrawSurface2_EnumAttachedSurfaces(p, a, b) (p)->lpVtbl->EnumAttachedSurfaces(p, a, b)
#define IDirectDrawSurface2_EnumOverlayZOrders(p, a, b, c) (p)->lpVtbl->EnumOverlayZOrders(p, a, b, c)
#define IDirectDrawSurface2_Flip(p, a, b) (p)->lpVtbl->Flip(p, a, b)
#define IDirectDrawSurface2_GetAttachedSurface(p, a, b) (p)->lpVtbl->GetAttachedSurface(p, a, b)
#define IDirectDrawSurface2_GetBltStatus(p, a) (p)->lpVtbl->GetBltStatus(p, a)
#define IDirectDrawSurface2_GetCaps(p, b) (p)->lpVtbl->GetCaps(p, b)
#define IDirectDrawSurface2_GetClipper(p, a) (p)->lpVtbl->GetClipper(p, a)
#define IDirectDrawSurface2_GetColorKey(p, a, b) (p)->lpVtbl->GetColorKey(p, a, b)
#define IDirectDrawSurface2_GetDC(p, a) (p)->lpVtbl->GetDC(p, a)
#define IDirectDrawSurface2_GetFlipStatus(p, a) (p)->lpVtbl->GetFlipStatus(p, a)
#define IDirectDrawSurface2_GetOverlayPosition(p, a, b) (p)->lpVtbl->GetOverlayPosition(p, a, b)
#define IDirectDrawSurface2_GetPalette(p, a) (p)->lpVtbl->GetPalette(p, a)
#define IDirectDrawSurface2_GetPixelFormat(p, a) (p)->lpVtbl->GetPixelFormat(p, a)
#define IDirectDrawSurface2_GetSurfaceDesc(p, a) (p)->lpVtbl->GetSurfaceDesc(p, a)
#define IDirectDrawSurface2_Initialize(p, a, b) (p)->lpVtbl->Initialize(p, a, b)
#define IDirectDrawSurface2_IsLost(p) (p)->lpVtbl->IsLost(p)
#define IDirectDrawSurface2_Lock(p, a, b, c, d) (p)->lpVtbl->Lock(p, a, b, c, d)
#define IDirectDrawSurface2_ReleaseDC(p, a) (p)->lpVtbl->ReleaseDC(p, a)
#define IDirectDrawSurface2_Restore(p) (p)->lpVtbl->Restore(p)
#define IDirectDrawSurface2_SetClipper(p, a) (p)->lpVtbl->SetClipper(p, a)
#define IDirectDrawSurface2_SetColorKey(p, a, b) (p)->lpVtbl->SetColorKey(p, a, b)
#define IDirectDrawSurface2_SetOverlayPosition(p, a, b) (p)->lpVtbl->SetOverlayPosition(p, a, b)
#define IDirectDrawSurface2_SetPalette(p, a) (p)->lpVtbl->SetPalette(p, a)
#define IDirectDrawSurface2_Unlock(p, b) (p)->lpVtbl->Unlock(p, b)
#define IDirectDrawSurface2_UpdateOverlay(p, a, b, c, d, e) (p)->lpVtbl->UpdateOverlay(p, a, b, c, d, e)
#define IDirectDrawSurface2_UpdateOverlayDisplay(p, a) (p)->lpVtbl->UpdateOverlayDisplay(p, a)
#define IDirectDrawSurface2_UpdateOverlayZOrder(p, a, b) (p)->lpVtbl->UpdateOverlayZOrder(p, a, b)
#define IDirectDrawSurface2_GetDDInterface(p, a) (p)->lpVtbl->GetDDInterface(p, a)
#define IDirectDrawSurface2_PageLock(p, a) (p)->lpVtbl->PageLock(p, a)
#define IDirectDrawSurface2_PageUnlock(p, a) (p)->lpVtbl->PageUnlock(p, a)
#else
#define IDirectDrawSurface2_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawSurface2_AddRef(p) (p)->AddRef()
#define IDirectDrawSurface2_Release(p) (p)->Release()
#define IDirectDrawSurface2_AddAttachedSurface(p, a) (p)->AddAttachedSurface(a)
#define IDirectDrawSurface2_AddOverlayDirtyRect(p, a) (p)->AddOverlayDirtyRect(a)
#define IDirectDrawSurface2_Blt(p, a, b, c, d, e) (p)->Blt(a, b, c, d, e)
#define IDirectDrawSurface2_BltBatch(p, a, b, c) (p)->BltBatch(a, b, c)
#define IDirectDrawSurface2_BltFast(p, a, b, c, d, e) (p)->BltFast(a, b, c, d, e)
#define IDirectDrawSurface2_DeleteAttachedSurface(p, a, b) (p)->DeleteAttachedSurface(a, b)
#define IDirectDrawSurface2_EnumAttachedSurfaces(p, a, b) (p)->EnumAttachedSurfaces(a, b)
#define IDirectDrawSurface2_EnumOverlayZOrders(p, a, b, c) (p)->EnumOverlayZOrders(a, b, c)
#define IDirectDrawSurface2_Flip(p, a, b) (p)->Flip(a, b)
#define IDirectDrawSurface2_GetAttachedSurface(p, a, b) (p)->GetAttachedSurface(a, b)
#define IDirectDrawSurface2_GetBltStatus(p, a) (p)->GetBltStatus(a)
#define IDirectDrawSurface2_GetCaps(p, b) (p)->GetCaps(b)
#define IDirectDrawSurface2_GetClipper(p, a) (p)->GetClipper(a)
#define IDirectDrawSurface2_GetColorKey(p, a, b) (p)->GetColorKey(a, b)
#define IDirectDrawSurface2_GetDC(p, a) (p)->GetDC(a)
#define IDirectDrawSurface2_GetFlipStatus(p, a) (p)->GetFlipStatus(a)
#define IDirectDrawSurface2_GetOverlayPosition(p, a, b) (p)->GetOverlayPosition(a, b)
#define IDirectDrawSurface2_GetPalette(p, a) (p)->GetPalette(a)
#define IDirectDrawSurface2_GetPixelFormat(p, a) (p)->GetPixelFormat(a)
#define IDirectDrawSurface2_GetSurfaceDesc(p, a) (p)->GetSurfaceDesc(a)
#define IDirectDrawSurface2_Initialize(p, a, b) (p)->Initialize(a, b)
#define IDirectDrawSurface2_IsLost(p) (p)->IsLost()
#define IDirectDrawSurface2_Lock(p, a, b, c, d) (p)->Lock(a, b, c, d)
#define IDirectDrawSurface2_ReleaseDC(p, a) (p)->ReleaseDC(a)
#define IDirectDrawSurface2_Restore(p) (p)->Restore()
#define IDirectDrawSurface2_SetClipper(p, a) (p)->SetClipper(a)
#define IDirectDrawSurface2_SetColorKey(p, a, b) (p)->SetColorKey(a, b)
#define IDirectDrawSurface2_SetOverlayPosition(p, a, b) (p)->SetOverlayPosition(a, b)
#define IDirectDrawSurface2_SetPalette(p, a) (p)->SetPalette(a)
#define IDirectDrawSurface2_Unlock(p, b) (p)->Unlock(b)
#define IDirectDrawSurface2_UpdateOverlay(p, a, b, c, d, e) (p)->UpdateOverlay(a, b, c, d, e)
#define IDirectDrawSurface2_UpdateOverlayDisplay(p, a) (p)->UpdateOverlayDisplay(a)
#define IDirectDrawSurface2_UpdateOverlayZOrder(p, a, b) (p)->UpdateOverlayZOrder(a, b)
#define IDirectDrawSurface2_GetDDInterface(p, a) (p)->GetDDInterface(a)
#define IDirectDrawSurface2_PageLock(p, a) (p)->PageLock(a)
#define IDirectDrawSurface2_PageUnlock(p, a) (p)->PageUnlock(a)
#endif
/*
* IDirectDrawSurface3 and related interfaces
*/
#undef INTERFACE
#define INTERFACE IDirectDrawSurface3
DECLARE_INTERFACE_(IDirectDrawSurface3, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawSurface methods ***/
STDMETHOD(AddAttachedSurface)(THIS_ LPDIRECTDRAWSURFACE3) PURE;
STDMETHOD(AddOverlayDirtyRect)(THIS_ LPRECT) PURE;
STDMETHOD(Blt)(THIS_ LPRECT, LPDIRECTDRAWSURFACE3, LPRECT, DWORD, LPDDBLTFX) PURE;
STDMETHOD(BltBatch)(THIS_ LPDDBLTBATCH, DWORD, DWORD) PURE;
STDMETHOD(BltFast)(THIS_ DWORD, DWORD, LPDIRECTDRAWSURFACE3, LPRECT, DWORD) PURE;
STDMETHOD(DeleteAttachedSurface)(THIS_ DWORD, LPDIRECTDRAWSURFACE3) PURE;
STDMETHOD(EnumAttachedSurfaces)(THIS_ LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(EnumOverlayZOrders)(THIS_ DWORD, LPVOID, LPDDENUMSURFACESCALLBACK) PURE;
STDMETHOD(Flip)(THIS_ LPDIRECTDRAWSURFACE3, DWORD) PURE;
STDMETHOD(GetAttachedSurface)(THIS_ LPDDSCAPS, LPDIRECTDRAWSURFACE3 FAR *) PURE;
STDMETHOD(GetBltStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDSCAPS) PURE;
STDMETHOD(GetClipper)(THIS_ LPDIRECTDRAWCLIPPER FAR *) PURE;
STDMETHOD(GetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(GetDC)(THIS_ HDC FAR *) PURE;
STDMETHOD(GetFlipStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetOverlayPosition)(THIS_ LPLONG, LPLONG) PURE;
STDMETHOD(GetPalette)(THIS_ LPDIRECTDRAWPALETTE FAR *) PURE;
STDMETHOD(GetPixelFormat)(THIS_ LPDDPIXELFORMAT) PURE;
STDMETHOD(GetSurfaceDesc)(THIS_ LPDDSURFACEDESC) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, LPDDSURFACEDESC) PURE;
STDMETHOD(IsLost)(THIS) PURE;
STDMETHOD(Lock)(THIS_ LPRECT, LPDDSURFACEDESC, DWORD, HANDLE) PURE;
STDMETHOD(ReleaseDC)(THIS_ HDC) PURE;
STDMETHOD(Restore)(THIS) PURE;
STDMETHOD(SetClipper)(THIS_ LPDIRECTDRAWCLIPPER) PURE;
STDMETHOD(SetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(SetOverlayPosition)(THIS_ LONG, LONG) PURE;
STDMETHOD(SetPalette)(THIS_ LPDIRECTDRAWPALETTE) PURE;
STDMETHOD(Unlock)(THIS_ LPVOID) PURE;
STDMETHOD(UpdateOverlay)(THIS_ LPRECT, LPDIRECTDRAWSURFACE3, LPRECT, DWORD, LPDDOVERLAYFX) PURE;
STDMETHOD(UpdateOverlayDisplay)(THIS_ DWORD) PURE;
STDMETHOD(UpdateOverlayZOrder)(THIS_ DWORD, LPDIRECTDRAWSURFACE3) PURE;
/*** Added in the v2 interface ***/
STDMETHOD(GetDDInterface)(THIS_ LPVOID FAR *) PURE;
STDMETHOD(PageLock)(THIS_ DWORD) PURE;
STDMETHOD(PageUnlock)(THIS_ DWORD) PURE;
/*** Added in the V3 interface ***/
STDMETHOD(SetSurfaceDesc)(THIS_ LPDDSURFACEDESC, DWORD) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawSurface3_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawSurface3_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawSurface3_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawSurface3_AddAttachedSurface(p, a) (p)->lpVtbl->AddAttachedSurface(p, a)
#define IDirectDrawSurface3_AddOverlayDirtyRect(p, a) (p)->lpVtbl->AddOverlayDirtyRect(p, a)
#define IDirectDrawSurface3_Blt(p, a, b, c, d, e) (p)->lpVtbl->Blt(p, a, b, c, d, e)
#define IDirectDrawSurface3_BltBatch(p, a, b, c) (p)->lpVtbl->BltBatch(p, a, b, c)
#define IDirectDrawSurface3_BltFast(p, a, b, c, d, e) (p)->lpVtbl->BltFast(p, a, b, c, d, e)
#define IDirectDrawSurface3_DeleteAttachedSurface(p, a, b) (p)->lpVtbl->DeleteAttachedSurface(p, a, b)
#define IDirectDrawSurface3_EnumAttachedSurfaces(p, a, b) (p)->lpVtbl->EnumAttachedSurfaces(p, a, b)
#define IDirectDrawSurface3_EnumOverlayZOrders(p, a, b, c) (p)->lpVtbl->EnumOverlayZOrders(p, a, b, c)
#define IDirectDrawSurface3_Flip(p, a, b) (p)->lpVtbl->Flip(p, a, b)
#define IDirectDrawSurface3_GetAttachedSurface(p, a, b) (p)->lpVtbl->GetAttachedSurface(p, a, b)
#define IDirectDrawSurface3_GetBltStatus(p, a) (p)->lpVtbl->GetBltStatus(p, a)
#define IDirectDrawSurface3_GetCaps(p, b) (p)->lpVtbl->GetCaps(p, b)
#define IDirectDrawSurface3_GetClipper(p, a) (p)->lpVtbl->GetClipper(p, a)
#define IDirectDrawSurface3_GetColorKey(p, a, b) (p)->lpVtbl->GetColorKey(p, a, b)
#define IDirectDrawSurface3_GetDC(p, a) (p)->lpVtbl->GetDC(p, a)
#define IDirectDrawSurface3_GetFlipStatus(p, a) (p)->lpVtbl->GetFlipStatus(p, a)
#define IDirectDrawSurface3_GetOverlayPosition(p, a, b) (p)->lpVtbl->GetOverlayPosition(p, a, b)
#define IDirectDrawSurface3_GetPalette(p, a) (p)->lpVtbl->GetPalette(p, a)
#define IDirectDrawSurface3_GetPixelFormat(p, a) (p)->lpVtbl->GetPixelFormat(p, a)
#define IDirectDrawSurface3_GetSurfaceDesc(p, a) (p)->lpVtbl->GetSurfaceDesc(p, a)
#define IDirectDrawSurface3_Initialize(p, a, b) (p)->lpVtbl->Initialize(p, a, b)
#define IDirectDrawSurface3_IsLost(p) (p)->lpVtbl->IsLost(p)
#define IDirectDrawSurface3_Lock(p, a, b, c, d) (p)->lpVtbl->Lock(p, a, b, c, d)
#define IDirectDrawSurface3_ReleaseDC(p, a) (p)->lpVtbl->ReleaseDC(p, a)
#define IDirectDrawSurface3_Restore(p) (p)->lpVtbl->Restore(p)
#define IDirectDrawSurface3_SetClipper(p, a) (p)->lpVtbl->SetClipper(p, a)
#define IDirectDrawSurface3_SetColorKey(p, a, b) (p)->lpVtbl->SetColorKey(p, a, b)
#define IDirectDrawSurface3_SetOverlayPosition(p, a, b) (p)->lpVtbl->SetOverlayPosition(p, a, b)
#define IDirectDrawSurface3_SetPalette(p, a) (p)->lpVtbl->SetPalette(p, a)
#define IDirectDrawSurface3_Unlock(p, b) (p)->lpVtbl->Unlock(p, b)
#define IDirectDrawSurface3_UpdateOverlay(p, a, b, c, d, e) (p)->lpVtbl->UpdateOverlay(p, a, b, c, d, e)
#define IDirectDrawSurface3_UpdateOverlayDisplay(p, a) (p)->lpVtbl->UpdateOverlayDisplay(p, a)
#define IDirectDrawSurface3_UpdateOverlayZOrder(p, a, b) (p)->lpVtbl->UpdateOverlayZOrder(p, a, b)
#define IDirectDrawSurface3_GetDDInterface(p, a) (p)->lpVtbl->GetDDInterface(p, a)
#define IDirectDrawSurface3_PageLock(p, a) (p)->lpVtbl->PageLock(p, a)
#define IDirectDrawSurface3_PageUnlock(p, a) (p)->lpVtbl->PageUnlock(p, a)
#define IDirectDrawSurface3_SetSurfaceDesc(p, a, b) (p)->lpVtbl->SetSurfaceDesc(p, a, b)
#else
#define IDirectDrawSurface3_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawSurface3_AddRef(p) (p)->AddRef()
#define IDirectDrawSurface3_Release(p) (p)->Release()
#define IDirectDrawSurface3_AddAttachedSurface(p, a) (p)->AddAttachedSurface(a)
#define IDirectDrawSurface3_AddOverlayDirtyRect(p, a) (p)->AddOverlayDirtyRect(a)
#define IDirectDrawSurface3_Blt(p, a, b, c, d, e) (p)->Blt(a, b, c, d, e)
#define IDirectDrawSurface3_BltBatch(p, a, b, c) (p)->BltBatch(a, b, c)
#define IDirectDrawSurface3_BltFast(p, a, b, c, d, e) (p)->BltFast(a, b, c, d, e)
#define IDirectDrawSurface3_DeleteAttachedSurface(p, a, b) (p)->DeleteAttachedSurface(a, b)
#define IDirectDrawSurface3_EnumAttachedSurfaces(p, a, b) (p)->EnumAttachedSurfaces(a, b)
#define IDirectDrawSurface3_EnumOverlayZOrders(p, a, b, c) (p)->EnumOverlayZOrders(a, b, c)
#define IDirectDrawSurface3_Flip(p, a, b) (p)->Flip(a, b)
#define IDirectDrawSurface3_GetAttachedSurface(p, a, b) (p)->GetAttachedSurface(a, b)
#define IDirectDrawSurface3_GetBltStatus(p, a) (p)->GetBltStatus(a)
#define IDirectDrawSurface3_GetCaps(p, b) (p)->GetCaps(b)
#define IDirectDrawSurface3_GetClipper(p, a) (p)->GetClipper(a)
#define IDirectDrawSurface3_GetColorKey(p, a, b) (p)->GetColorKey(a, b)
#define IDirectDrawSurface3_GetDC(p, a) (p)->GetDC(a)
#define IDirectDrawSurface3_GetFlipStatus(p, a) (p)->GetFlipStatus(a)
#define IDirectDrawSurface3_GetOverlayPosition(p, a, b) (p)->GetOverlayPosition(a, b)
#define IDirectDrawSurface3_GetPalette(p, a) (p)->GetPalette(a)
#define IDirectDrawSurface3_GetPixelFormat(p, a) (p)->GetPixelFormat(a)
#define IDirectDrawSurface3_GetSurfaceDesc(p, a) (p)->GetSurfaceDesc(a)
#define IDirectDrawSurface3_Initialize(p, a, b) (p)->Initialize(a, b)
#define IDirectDrawSurface3_IsLost(p) (p)->IsLost()
#define IDirectDrawSurface3_Lock(p, a, b, c, d) (p)->Lock(a, b, c, d)
#define IDirectDrawSurface3_ReleaseDC(p, a) (p)->ReleaseDC(a)
#define IDirectDrawSurface3_Restore(p) (p)->Restore()
#define IDirectDrawSurface3_SetClipper(p, a) (p)->SetClipper(a)
#define IDirectDrawSurface3_SetColorKey(p, a, b) (p)->SetColorKey(a, b)
#define IDirectDrawSurface3_SetOverlayPosition(p, a, b) (p)->SetOverlayPosition(a, b)
#define IDirectDrawSurface3_SetPalette(p, a) (p)->SetPalette(a)
#define IDirectDrawSurface3_Unlock(p, b) (p)->Unlock(b)
#define IDirectDrawSurface3_UpdateOverlay(p, a, b, c, d, e) (p)->UpdateOverlay(a, b, c, d, e)
#define IDirectDrawSurface3_UpdateOverlayDisplay(p, a) (p)->UpdateOverlayDisplay(a)
#define IDirectDrawSurface3_UpdateOverlayZOrder(p, a, b) (p)->UpdateOverlayZOrder(a, b)
#define IDirectDrawSurface3_GetDDInterface(p, a) (p)->GetDDInterface(a)
#define IDirectDrawSurface3_PageLock(p, a) (p)->PageLock(a)
#define IDirectDrawSurface3_PageUnlock(p, a) (p)->PageUnlock(a)
#define IDirectDrawSurface3_SetSurfaceDesc(p, a, b) (p)->SetSurfaceDesc(a, b)
#endif
/*
* IDirectDrawSurface4 and related interfaces
*/
#undef INTERFACE
#define INTERFACE IDirectDrawSurface4
DECLARE_INTERFACE_(IDirectDrawSurface4, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawSurface methods ***/
STDMETHOD(AddAttachedSurface)(THIS_ LPDIRECTDRAWSURFACE4) PURE;
STDMETHOD(AddOverlayDirtyRect)(THIS_ LPRECT) PURE;
STDMETHOD(Blt)(THIS_ LPRECT, LPDIRECTDRAWSURFACE4, LPRECT, DWORD, LPDDBLTFX) PURE;
STDMETHOD(BltBatch)(THIS_ LPDDBLTBATCH, DWORD, DWORD) PURE;
STDMETHOD(BltFast)(THIS_ DWORD, DWORD, LPDIRECTDRAWSURFACE4, LPRECT, DWORD) PURE;
STDMETHOD(DeleteAttachedSurface)(THIS_ DWORD, LPDIRECTDRAWSURFACE4) PURE;
STDMETHOD(EnumAttachedSurfaces)(THIS_ LPVOID, LPDDENUMSURFACESCALLBACK2) PURE;
STDMETHOD(EnumOverlayZOrders)(THIS_ DWORD, LPVOID, LPDDENUMSURFACESCALLBACK2) PURE;
STDMETHOD(Flip)(THIS_ LPDIRECTDRAWSURFACE4, DWORD) PURE;
STDMETHOD(GetAttachedSurface)(THIS_ LPDDSCAPS2, LPDIRECTDRAWSURFACE4 FAR *) PURE;
STDMETHOD(GetBltStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetCaps)(THIS_ LPDDSCAPS2) PURE;
STDMETHOD(GetClipper)(THIS_ LPDIRECTDRAWCLIPPER FAR *) PURE;
STDMETHOD(GetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(GetDC)(THIS_ HDC FAR *) PURE;
STDMETHOD(GetFlipStatus)(THIS_ DWORD) PURE;
STDMETHOD(GetOverlayPosition)(THIS_ LPLONG, LPLONG) PURE;
STDMETHOD(GetPalette)(THIS_ LPDIRECTDRAWPALETTE FAR *) PURE;
STDMETHOD(GetPixelFormat)(THIS_ LPDDPIXELFORMAT) PURE;
STDMETHOD(GetSurfaceDesc)(THIS_ LPDDSURFACEDESC2) PURE;
STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, LPDDSURFACEDESC2) PURE;
STDMETHOD(IsLost)(THIS) PURE;
STDMETHOD(Lock)(THIS_ LPRECT, LPDDSURFACEDESC2, DWORD, HANDLE) PURE;
STDMETHOD(ReleaseDC)(THIS_ HDC) PURE;
STDMETHOD(Restore)(THIS) PURE;
STDMETHOD(SetClipper)(THIS_ LPDIRECTDRAWCLIPPER) PURE;
STDMETHOD(SetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE;
STDMETHOD(SetOverlayPosition)(THIS_ LONG, LONG) PURE;
STDMETHOD(SetPalette)(THIS_ LPDIRECTDRAWPALETTE) PURE;
STDMETHOD(Unlock)(THIS_ LPRECT) PURE;
STDMETHOD(UpdateOverlay)(THIS_ LPRECT, LPDIRECTDRAWSURFACE4, LPRECT, DWORD, LPDDOVERLAYFX) PURE;
STDMETHOD(UpdateOverlayDisplay)(THIS_ DWORD) PURE;
STDMETHOD(UpdateOverlayZOrder)(THIS_ DWORD, LPDIRECTDRAWSURFACE4) PURE;
/*** Added in the v2 interface ***/
STDMETHOD(GetDDInterface)(THIS_ LPVOID FAR *) PURE;
STDMETHOD(PageLock)(THIS_ DWORD) PURE;
STDMETHOD(PageUnlock)(THIS_ DWORD) PURE;
/*** Added in the v3 interface ***/
STDMETHOD(SetSurfaceDesc)(THIS_ LPDDSURFACEDESC2, DWORD) PURE;
/*** Added in the v4 interface ***/
STDMETHOD(SetPrivateData)(THIS_ REFGUID, LPVOID, DWORD, DWORD) PURE;
STDMETHOD(GetPrivateData)(THIS_ REFGUID, LPVOID, LPDWORD) PURE;
STDMETHOD(FreePrivateData)(THIS_ REFGUID) PURE;
STDMETHOD(GetUniquenessValue)(THIS_ LPDWORD) PURE;
STDMETHOD(ChangeUniquenessValue)(THIS) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawSurface4_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawSurface4_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawSurface4_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawSurface4_AddAttachedSurface(p, a) (p)->lpVtbl->AddAttachedSurface(p, a)
#define IDirectDrawSurface4_AddOverlayDirtyRect(p, a) (p)->lpVtbl->AddOverlayDirtyRect(p, a)
#define IDirectDrawSurface4_Blt(p, a, b, c, d, e) (p)->lpVtbl->Blt(p, a, b, c, d, e)
#define IDirectDrawSurface4_BltBatch(p, a, b, c) (p)->lpVtbl->BltBatch(p, a, b, c)
#define IDirectDrawSurface4_BltFast(p, a, b, c, d, e) (p)->lpVtbl->BltFast(p, a, b, c, d, e)
#define IDirectDrawSurface4_DeleteAttachedSurface(p, a, b) (p)->lpVtbl->DeleteAttachedSurface(p, a, b)
#define IDirectDrawSurface4_EnumAttachedSurfaces(p, a, b) (p)->lpVtbl->EnumAttachedSurfaces(p, a, b)
#define IDirectDrawSurface4_EnumOverlayZOrders(p, a, b, c) (p)->lpVtbl->EnumOverlayZOrders(p, a, b, c)
#define IDirectDrawSurface4_Flip(p, a, b) (p)->lpVtbl->Flip(p, a, b)
#define IDirectDrawSurface4_GetAttachedSurface(p, a, b) (p)->lpVtbl->GetAttachedSurface(p, a, b)
#define IDirectDrawSurface4_GetBltStatus(p, a) (p)->lpVtbl->GetBltStatus(p, a)
#define IDirectDrawSurface4_GetCaps(p, b) (p)->lpVtbl->GetCaps(p, b)
#define IDirectDrawSurface4_GetClipper(p, a) (p)->lpVtbl->GetClipper(p, a)
#define IDirectDrawSurface4_GetColorKey(p, a, b) (p)->lpVtbl->GetColorKey(p, a, b)
#define IDirectDrawSurface4_GetDC(p, a) (p)->lpVtbl->GetDC(p, a)
#define IDirectDrawSurface4_GetFlipStatus(p, a) (p)->lpVtbl->GetFlipStatus(p, a)
#define IDirectDrawSurface4_GetOverlayPosition(p, a, b) (p)->lpVtbl->GetOverlayPosition(p, a, b)
#define IDirectDrawSurface4_GetPalette(p, a) (p)->lpVtbl->GetPalette(p, a)
#define IDirectDrawSurface4_GetPixelFormat(p, a) (p)->lpVtbl->GetPixelFormat(p, a)
#define IDirectDrawSurface4_GetSurfaceDesc(p, a) (p)->lpVtbl->GetSurfaceDesc(p, a)
#define IDirectDrawSurface4_Initialize(p, a, b) (p)->lpVtbl->Initialize(p, a, b)
#define IDirectDrawSurface4_IsLost(p) (p)->lpVtbl->IsLost(p)
#define IDirectDrawSurface4_Lock(p, a, b, c, d) (p)->lpVtbl->Lock(p, a, b, c, d)
#define IDirectDrawSurface4_ReleaseDC(p, a) (p)->lpVtbl->ReleaseDC(p, a)
#define IDirectDrawSurface4_Restore(p) (p)->lpVtbl->Restore(p)
#define IDirectDrawSurface4_SetClipper(p, a) (p)->lpVtbl->SetClipper(p, a)
#define IDirectDrawSurface4_SetColorKey(p, a, b) (p)->lpVtbl->SetColorKey(p, a, b)
#define IDirectDrawSurface4_SetOverlayPosition(p, a, b) (p)->lpVtbl->SetOverlayPosition(p, a, b)
#define IDirectDrawSurface4_SetPalette(p, a) (p)->lpVtbl->SetPalette(p, a)
#define IDirectDrawSurface4_Unlock(p, b) (p)->lpVtbl->Unlock(p, b)
#define IDirectDrawSurface4_UpdateOverlay(p, a, b, c, d, e) (p)->lpVtbl->UpdateOverlay(p, a, b, c, d, e)
#define IDirectDrawSurface4_UpdateOverlayDisplay(p, a) (p)->lpVtbl->UpdateOverlayDisplay(p, a)
#define IDirectDrawSurface4_UpdateOverlayZOrder(p, a, b) (p)->lpVtbl->UpdateOverlayZOrder(p, a, b)
#define IDirectDrawSurface4_GetDDInterface(p, a) (p)->lpVtbl->GetDDInterface(p, a)
#define IDirectDrawSurface4_PageLock(p, a) (p)->lpVtbl->PageLock(p, a)
#define IDirectDrawSurface4_PageUnlock(p, a) (p)->lpVtbl->PageUnlock(p, a)
#define IDirectDrawSurface4_SetSurfaceDesc(p, a, b) (p)->lpVtbl->SetSurfaceDesc(p, a, b)
#define IDirectDrawSurface4_SetPrivateData(p, a, b, c, d) (p)->lpVtbl->SetPrivateData(p, a, b, c, d)
#define IDirectDrawSurface4_GetPrivateData(p, a, b, c) (p)->lpVtbl->GetPrivateData(p, a, b, c)
#define IDirectDrawSurface4_FreePrivateData(p, a) (p)->lpVtbl->FreePrivateData(p, a)
#define IDirectDrawSurface4_GetUniquenessValue(p, a) (p)->lpVtbl->GetUniquenessValue(p, a)
#define IDirectDrawSurface4_ChangeUniquenessValue(p) (p)->lpVtbl->ChangeUniquenessValue(p)
#else
#define IDirectDrawSurface4_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawSurface4_AddRef(p) (p)->AddRef()
#define IDirectDrawSurface4_Release(p) (p)->Release()
#define IDirectDrawSurface4_AddAttachedSurface(p, a) (p)->AddAttachedSurface(a)
#define IDirectDrawSurface4_AddOverlayDirtyRect(p, a) (p)->AddOverlayDirtyRect(a)
#define IDirectDrawSurface4_Blt(p, a, b, c, d, e) (p)->Blt(a, b, c, d, e)
#define IDirectDrawSurface4_BltBatch(p, a, b, c) (p)->BltBatch(a, b, c)
#define IDirectDrawSurface4_BltFast(p, a, b, c, d, e) (p)->BltFast(a, b, c, d, e)
#define IDirectDrawSurface4_DeleteAttachedSurface(p, a, b) (p)->DeleteAttachedSurface(a, b)
#define IDirectDrawSurface4_EnumAttachedSurfaces(p, a, b) (p)->EnumAttachedSurfaces(a, b)
#define IDirectDrawSurface4_EnumOverlayZOrders(p, a, b, c) (p)->EnumOverlayZOrders(a, b, c)
#define IDirectDrawSurface4_Flip(p, a, b) (p)->Flip(a, b)
#define IDirectDrawSurface4_GetAttachedSurface(p, a, b) (p)->GetAttachedSurface(a, b)
#define IDirectDrawSurface4_GetBltStatus(p, a) (p)->GetBltStatus(a)
#define IDirectDrawSurface4_GetCaps(p, b) (p)->GetCaps(b)
#define IDirectDrawSurface4_GetClipper(p, a) (p)->GetClipper(a)
#define IDirectDrawSurface4_GetColorKey(p, a, b) (p)->GetColorKey(a, b)
#define IDirectDrawSurface4_GetDC(p, a) (p)->GetDC(a)
#define IDirectDrawSurface4_GetFlipStatus(p, a) (p)->GetFlipStatus(a)
#define IDirectDrawSurface4_GetOverlayPosition(p, a, b) (p)->GetOverlayPosition(a, b)
#define IDirectDrawSurface4_GetPalette(p, a) (p)->GetPalette(a)
#define IDirectDrawSurface4_GetPixelFormat(p, a) (p)->GetPixelFormat(a)
#define IDirectDrawSurface4_GetSurfaceDesc(p, a) (p)->GetSurfaceDesc(a)
#define IDirectDrawSurface4_Initialize(p, a, b) (p)->Initialize(a, b)
#define IDirectDrawSurface4_IsLost(p) (p)->IsLost()
#define IDirectDrawSurface4_Lock(p, a, b, c, d) (p)->Lock(a, b, c, d)
#define IDirectDrawSurface4_ReleaseDC(p, a) (p)->ReleaseDC(a)
#define IDirectDrawSurface4_Restore(p) (p)->Restore()
#define IDirectDrawSurface4_SetClipper(p, a) (p)->SetClipper(a)
#define IDirectDrawSurface4_SetColorKey(p, a, b) (p)->SetColorKey(a, b)
#define IDirectDrawSurface4_SetOverlayPosition(p, a, b) (p)->SetOverlayPosition(a, b)
#define IDirectDrawSurface4_SetPalette(p, a) (p)->SetPalette(a)
#define IDirectDrawSurface4_Unlock(p, b) (p)->Unlock(b)
#define IDirectDrawSurface4_UpdateOverlay(p, a, b, c, d, e) (p)->UpdateOverlay(a, b, c, d, e)
#define IDirectDrawSurface4_UpdateOverlayDisplay(p, a) (p)->UpdateOverlayDisplay(a)
#define IDirectDrawSurface4_UpdateOverlayZOrder(p, a, b) (p)->UpdateOverlayZOrder(a, b)
#define IDirectDrawSurface4_GetDDInterface(p, a) (p)->GetDDInterface(a)
#define IDirectDrawSurface4_PageLock(p, a) (p)->PageLock(a)
#define IDirectDrawSurface4_PageUnlock(p, a) (p)->PageUnlock(a)
#define IDirectDrawSurface4_SetSurfaceDesc(p, a, b) (p)->SetSurfaceDesc(a, b)
#define IDirectDrawSurface4_SetPrivateData(p, a, b, c, d) (p)->SetPrivateData(a, b, c, d)
#define IDirectDrawSurface4_GetPrivateData(p, a, b, c) (p)->GetPrivateData(a, b, c)
#define IDirectDrawSurface4_FreePrivateData(p, a) (p)->FreePrivateData(a)
#define IDirectDrawSurface4_GetUniquenessValue(p, a) (p)->GetUniquenessValue(a)
#define IDirectDrawSurface4_ChangeUniquenessValue(p) (p)->ChangeUniquenessValue()
#endif
/*
* IDirectDrawColorControl
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDrawColorControl
DECLARE_INTERFACE_(IDirectDrawColorControl, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawColorControl methods ***/
STDMETHOD(GetColorControls)(THIS_ LPDDCOLORCONTROL) PURE;
STDMETHOD(SetColorControls)(THIS_ LPDDCOLORCONTROL) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawColorControl_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawColorControl_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawColorControl_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawColorControl_GetColorControls(p, a) (p)->lpVtbl->GetColorControls(p, a)
#define IDirectDrawColorControl_SetColorControls(p, a) (p)->lpVtbl->SetColorControls(p, a)
#else
#define IDirectDrawColorControl_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawColorControl_AddRef(p) (p)->AddRef()
#define IDirectDrawColorControl_Release(p) (p)->Release()
#define IDirectDrawColorControl_GetColorControls(p, a) (p)->GetColorControls(a)
#define IDirectDrawColorControl_SetColorControls(p, a) (p)->SetColorControls(a)
#endif
#endif
/*
* IDirectDrawGammaControl
*/
#if defined(_WIN32) && !defined(_NO_COM)
#undef INTERFACE
#define INTERFACE IDirectDrawGammaControl
DECLARE_INTERFACE_(IDirectDrawGammaControl, IUnknown) {
/*** IUnknown methods ***/
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
STDMETHOD_(ULONG, AddRef)(THIS) PURE;
STDMETHOD_(ULONG, Release)(THIS) PURE;
/*** IDirectDrawColorControl methods ***/
STDMETHOD(GetGammaRamp)(THIS_ DWORD, LPDDGAMMARAMP) PURE;
STDMETHOD(SetGammaRamp)(THIS_ DWORD, LPDDGAMMARAMP) PURE;
};
#if !defined(__cplusplus) || defined(CINTERFACE)
#define IDirectDrawGammaControl_QueryInterface(p, a, b) (p)->lpVtbl->QueryInterface(p, a, b)
#define IDirectDrawGammaControl_AddRef(p) (p)->lpVtbl->AddRef(p)
#define IDirectDrawGammaControl_Release(p) (p)->lpVtbl->Release(p)
#define IDirectDrawGammaControl_GetGammaRamp(p, a, b) (p)->lpVtbl->GetGammaRamp(p, a, b)
#define IDirectDrawGammaControl_SetGammaRamp(p, a, b) (p)->lpVtbl->SetGammaRamp(p, a, b)
#else
#define IDirectDrawGammaControl_QueryInterface(p, a, b) (p)->QueryInterface(a, b)
#define IDirectDrawGammaControl_AddRef(p) (p)->AddRef()
#define IDirectDrawGammaControl_Release(p) (p)->Release()
#define IDirectDrawGammaControl_GetGammaRamp(p, a, b) (p)->GetGammaRamp(a, b)
#define IDirectDrawGammaControl_SetGammaRamp(p, a, b) (p)->SetGammaRamp(a, b)
#endif
#endif
#endif
/*
* DDSURFACEDESC
*/
typedef struct _DDSURFACEDESC {
DWORD dwSize; // size of the DDSURFACEDESC structure
DWORD dwFlags; // determines what fields are valid
DWORD dwHeight; // height of surface to be created
DWORD dwWidth; // width of input surface
union {
LONG lPitch; // distance to start of next line (return value only)
DWORD dwLinearSize; // Formless late-allocated optimized surface size
} DUMMYUNIONNAMEN(1);
DWORD dwBackBufferCount; // number of back buffers requested
union {
DWORD dwMipMapCount; // number of mip-map levels requested
DWORD dwZBufferBitDepth; // depth of Z buffer requested
DWORD dwRefreshRate; // refresh rate (used when display mode is described)
} DUMMYUNIONNAMEN(2);
DWORD dwAlphaBitDepth; // depth of alpha buffer requested
DWORD dwReserved; // reserved
LPVOID lpSurface; // pointer to the associated surface memory
DDCOLORKEY ddckCKDestOverlay; // color key for destination overlay use
DDCOLORKEY ddckCKDestBlt; // color key for destination blt use
DDCOLORKEY ddckCKSrcOverlay; // color key for source overlay use
DDCOLORKEY ddckCKSrcBlt; // color key for source blt use
DDPIXELFORMAT ddpfPixelFormat; // pixel format description of the surface
DDSCAPS ddsCaps; // direct draw surface capabilities
} DDSURFACEDESC;
/*
* DDSURFACEDESC2
*/
typedef struct _DDSURFACEDESC2 {
DWORD dwSize; // size of the DDSURFACEDESC structure
DWORD dwFlags; // determines what fields are valid
DWORD dwHeight; // height of surface to be created
DWORD dwWidth; // width of input surface
union {
LONG lPitch; // distance to start of next line (return value only)
DWORD dwLinearSize; // Formless late-allocated optimized surface size
} DUMMYUNIONNAMEN(1);
DWORD dwBackBufferCount; // number of back buffers requested
union {
DWORD dwMipMapCount; // number of mip-map levels requestde
// dwZBufferBitDepth removed, use ddpfPixelFormat one instead
DWORD dwRefreshRate; // refresh rate (used when display mode is described)
} DUMMYUNIONNAMEN(2);
DWORD dwAlphaBitDepth; // depth of alpha buffer requested
DWORD dwReserved; // reserved
LPVOID lpSurface; // pointer to the associated surface memory
DDCOLORKEY ddckCKDestOverlay; // color key for destination overlay use
DDCOLORKEY ddckCKDestBlt; // color key for destination blt use
DDCOLORKEY ddckCKSrcOverlay; // color key for source overlay use
DDCOLORKEY ddckCKSrcBlt; // color key for source blt use
DDPIXELFORMAT ddpfPixelFormat; // pixel format description of the surface
DDSCAPS2 ddsCaps; // direct draw surface capabilities
DWORD dwTextureStage; // stage in multitexture cascade
} DDSURFACEDESC2;
/*
* ddsCaps field is valid.
*/
#define DDSD_CAPS 0x00000001l // default
/*
* dwHeight field is valid.
*/
#define DDSD_HEIGHT 0x00000002l
/*
* dwWidth field is valid.
*/
#define DDSD_WIDTH 0x00000004l
/*
* lPitch is valid.
*/
#define DDSD_PITCH 0x00000008l
/*
* dwBackBufferCount is valid.
*/
#define DDSD_BACKBUFFERCOUNT 0x00000020l
/*
* dwZBufferBitDepth is valid. (shouldnt be used in DDSURFACEDESC2)
*/
#define DDSD_ZBUFFERBITDEPTH 0x00000040l
/*
* dwAlphaBitDepth is valid.
*/
#define DDSD_ALPHABITDEPTH 0x00000080l
/*
* lpSurface is valid.
*/
#define DDSD_LPSURFACE 0x00000800l
/*
* ddpfPixelFormat is valid.
*/
#define DDSD_PIXELFORMAT 0x00001000l
/*
* ddckCKDestOverlay is valid.
*/
#define DDSD_CKDESTOVERLAY 0x00002000l
/*
* ddckCKDestBlt is valid.
*/
#define DDSD_CKDESTBLT 0x00004000l
/*
* ddckCKSrcOverlay is valid.
*/
#define DDSD_CKSRCOVERLAY 0x00008000l
/*
* ddckCKSrcBlt is valid.
*/
#define DDSD_CKSRCBLT 0x00010000l
/*
* dwMipMapCount is valid.
*/
#define DDSD_MIPMAPCOUNT 0x00020000l
/*
* dwRefreshRate is valid
*/
#define DDSD_REFRESHRATE 0x00040000l
/*
* dwLinearSize is valid
*/
#define DDSD_LINEARSIZE 0x00080000l
/*
* dwTextureStage is valid
*/
#define DDSD_TEXTURESTAGE 0x00100000l
/*
* All input fields are valid.
*/
#define DDSD_ALL 0x001ff9eel
/*
* DDOPTSURFACEDESC
*/
typedef struct _DDOPTSURFACEDESC {
DWORD dwSize; // size of the DDOPTSURFACEDESC structure
DWORD dwFlags; // determines what fields are valid
DDSCAPS2 ddSCaps; // Common caps like: Memory type
DDOSCAPS ddOSCaps; // Common caps like: Memory type
GUID guid; // Compression technique GUID
DWORD dwCompressionRatio; // Compression ratio
} DDOPTSURFACEDESC;
/*
* guid field is valid.
*/
#define DDOSD_GUID 0x00000001l
/*
* dwCompressionRatio field is valid.
*/
#define DDOSD_COMPRESSION_RATIO 0x00000002l
/*
* ddSCaps field is valid.
*/
#define DDOSD_SCAPS 0x00000004l
/*
* ddOSCaps field is valid.
*/
#define DDOSD_OSCAPS 0x00000008l
/*
* All input fields are valid.
*/
#define DDOSD_ALL 0x0000000fl
/*
* The surface's optimized pixelformat is compressed
*/
#define DDOSDCAPS_OPTCOMPRESSED 0x00000001l
/*
* The surface's optimized pixelformat is reordered
*/
#define DDOSDCAPS_OPTREORDERED 0x00000002l
/*
* The opt surface is a monolithic mipmap
*/
#define DDOSDCAPS_MONOLITHICMIPMAP 0x00000004l
/*
* The valid Surf caps:
* #define DDSCAPS_SYSTEMMEMORY 0x00000800l
* #define DDSCAPS_VIDEOMEMORY 0x00004000l
* #define DDSCAPS_LOCALVIDMEM 0x10000000l
* #define DDSCAPS_NONLOCALVIDMEM 0x20000000l
*/
#define DDOSDCAPS_VALIDSCAPS 0x30004800l
/*
* The valid OptSurf caps
*/
#define DDOSDCAPS_VALIDOSCAPS 0x00000007l
/*
* DDCOLORCONTROL
*/
typedef struct _DDCOLORCONTROL {
DWORD dwSize;
DWORD dwFlags;
LONG lBrightness;
LONG lContrast;
LONG lHue;
LONG lSaturation;
LONG lSharpness;
LONG lGamma;
LONG lColorEnable;
DWORD dwReserved1;
} DDCOLORCONTROL;
/*
* lBrightness field is valid.
*/
#define DDCOLOR_BRIGHTNESS 0x00000001l
/*
* lContrast field is valid.
*/
#define DDCOLOR_CONTRAST 0x00000002l
/*
* lHue field is valid.
*/
#define DDCOLOR_HUE 0x00000004l
/*
* lSaturation field is valid.
*/
#define DDCOLOR_SATURATION 0x00000008l
/*
* lSharpness field is valid.
*/
#define DDCOLOR_SHARPNESS 0x00000010l
/*
* lGamma field is valid.
*/
#define DDCOLOR_GAMMA 0x00000020l
/*
* lColorEnable field is valid.
*/
#define DDCOLOR_COLORENABLE 0x00000040l
/*============================================================================
*
* Direct Draw Capability Flags
*
* These flags are used to describe the capabilities of a given Surface.
* All flags are bit flags.
*
*==========================================================================*/
/****************************************************************************
*
* DIRECTDRAWSURFACE CAPABILITY FLAGS
*
****************************************************************************/
/*
* This bit is reserved. It should not be specified.
*/
#define DDSCAPS_RESERVED1 0x00000001l
/*
* Indicates that this surface contains alpha-only information.
* (To determine if a surface is RGBA/YUVA, the pixel format must be
* interrogated.)
*/
#define DDSCAPS_ALPHA 0x00000002l
/*
* Indicates that this surface is a backbuffer. It is generally
* set by CreateSurface when the DDSCAPS_FLIP capability bit is set.
* It indicates that this surface is THE back buffer of a surface
* flipping structure. DirectDraw supports N surfaces in a
* surface flipping structure. Only the surface that immediately
* precedeces the DDSCAPS_FRONTBUFFER has this capability bit set.
* The other surfaces are identified as back buffers by the presence
* of the DDSCAPS_FLIP capability, their attachment order, and the
* absence of the DDSCAPS_FRONTBUFFER and DDSCAPS_BACKBUFFER
* capabilities. The bit is sent to CreateSurface when a standalone
* back buffer is being created. This surface could be attached to
* a front buffer and/or back buffers to form a flipping surface
* structure after the CreateSurface call. See AddAttachments for
* a detailed description of the behaviors in this case.
*/
#define DDSCAPS_BACKBUFFER 0x00000004l
/*
* Indicates a complex surface structure is being described. A
* complex surface structure results in the creation of more than
* one surface. The additional surfaces are attached to the root
* surface. The complex structure can only be destroyed by
* destroying the root.
*/
#define DDSCAPS_COMPLEX 0x00000008l
/*
* Indicates that this surface is a part of a surface flipping structure.
* When it is passed to CreateSurface the DDSCAPS_FRONTBUFFER and
* DDSCAP_BACKBUFFER bits are not set. They are set by CreateSurface
* on the resulting creations. The dwBackBufferCount field in the
* DDSURFACEDESC structure must be set to at least 1 in order for
* the CreateSurface call to succeed. The DDSCAPS_COMPLEX capability
* must always be set with creating multiple surfaces through CreateSurface.
*/
#define DDSCAPS_FLIP 0x00000010l
/*
* Indicates that this surface is THE front buffer of a surface flipping
* structure. It is generally set by CreateSurface when the DDSCAPS_FLIP
* capability bit is set.
* If this capability is sent to CreateSurface then a standalonw front buffer
* is created. This surface will not have the DDSCAPS_FLIP capability.
* It can be attached to other back buffers to form a flipping structure.
* See AddAttachments for a detailed description of the behaviors in this
* case.
*/
#define DDSCAPS_FRONTBUFFER 0x00000020l
/*
* Indicates that this surface is any offscreen surface that is not an overlay,
* texture, zbuffer, front buffer, back buffer, or alpha surface. It is used
* to identify plain vanilla surfaces.
*/
#define DDSCAPS_OFFSCREENPLAIN 0x00000040l
/*
* Indicates that this surface is an overlay. It may or may not be directly visible
* depending on whether or not it is currently being overlayed onto the primary
* surface. DDSCAPS_VISIBLE can be used to determine whether or not it is being
* overlayed at the moment.
*/
#define DDSCAPS_OVERLAY 0x00000080l
/*
* Indicates that unique DirectDrawPalette objects can be created and
* attached to this surface.
*/
#define DDSCAPS_PALETTE 0x00000100l
/*
* Indicates that this surface is the primary surface. The primary
* surface represents what the user is seeing at the moment.
*/
#define DDSCAPS_PRIMARYSURFACE 0x00000200l
/*
* Indicates that this surface is the primary surface for the left eye.
* The primary surface for the left eye represents what the user is seeing
* at the moment with the users left eye. When this surface is created the
* DDSCAPS_PRIMARYSURFACE represents what the user is seeing with the users
* right eye.
*/
#define DDSCAPS_PRIMARYSURFACELEFT 0x00000400l
/*
* Indicates that this surface memory was allocated in system memory
*/
#define DDSCAPS_SYSTEMMEMORY 0x00000800l
/*
* Indicates that this surface can be used as a 3D texture. It does not
* indicate whether or not the surface is being used for that purpose.
*/
#define DDSCAPS_TEXTURE 0x00001000l
/*
* Indicates that a surface may be a destination for 3D rendering. This
* bit must be set in order to query for a Direct3D Device Interface
* from this surface.
*/
#define DDSCAPS_3DDEVICE 0x00002000l
/*
* Indicates that this surface exists in video memory.
*/
#define DDSCAPS_VIDEOMEMORY 0x00004000l
/*
* Indicates that changes made to this surface are immediately visible.
* It is always set for the primary surface and is set for overlays while
* they are being overlayed and texture maps while they are being textured.
*/
#define DDSCAPS_VISIBLE 0x00008000l
/*
* Indicates that only writes are permitted to the surface. Read accesses
* from the surface may or may not generate a protection fault, but the
* results of a read from this surface will not be meaningful. READ ONLY.
*/
#define DDSCAPS_WRITEONLY 0x00010000l
/*
* Indicates that this surface is a z buffer. A z buffer does not contain
* displayable information. Instead it contains bit depth information that is
* used to determine which pixels are visible and which are obscured.
*/
#define DDSCAPS_ZBUFFER 0x00020000l
/*
* Indicates surface will have a DC associated long term
*/
#define DDSCAPS_OWNDC 0x00040000l
/*
* Indicates surface should be able to receive live video
*/
#define DDSCAPS_LIVEVIDEO 0x00080000l
/*
* Indicates surface should be able to have a stream decompressed
* to it by the hardware.
*/
#define DDSCAPS_HWCODEC 0x00100000l
/*
* Surface is a ModeX surface.
*
*/
#define DDSCAPS_MODEX 0x00200000l
/*
* Indicates surface is one level of a mip-map. This surface will
* be attached to other DDSCAPS_MIPMAP surfaces to form the mip-map.
* This can be done explicitly, by creating a number of surfaces and
* attaching them with AddAttachedSurface or by implicitly by CreateSurface.
* If this bit is set then DDSCAPS_TEXTURE must also be set.
*/
#define DDSCAPS_MIPMAP 0x00400000l
/*
* This bit is reserved. It should not be specified.
*/
#define DDSCAPS_RESERVED2 0x00800000l
/*
* Indicates that memory for the surface is not allocated until the surface
* is loaded (via the Direct3D texture Load() function).
*/
#define DDSCAPS_ALLOCONLOAD 0x04000000l
/*
* Indicates that the surface will recieve data from a video port.
*/
#define DDSCAPS_VIDEOPORT 0x08000000l
/*
* Indicates that a video memory surface is resident in true, local video
* memory rather than non-local video memory. If this flag is specified then
* so must DDSCAPS_VIDEOMEMORY. This flag is mutually exclusive with
* DDSCAPS_NONLOCALVIDMEM.
*/
#define DDSCAPS_LOCALVIDMEM 0x10000000l
/*
* Indicates that a video memory surface is resident in non-local video
* memory rather than true, local video memory. If this flag is specified
* then so must DDSCAPS_VIDEOMEMORY. This flag is mutually exclusive with
* DDSCAPS_LOCALVIDMEM.
*/
#define DDSCAPS_NONLOCALVIDMEM 0x20000000l
/*
* Indicates that this surface is a standard VGA mode surface, and not a
* ModeX surface. (This flag will never be set in combination with the
* DDSCAPS_MODEX flag).
*/
#define DDSCAPS_STANDARDVGAMODE 0x40000000l
/*
* Indicates that this surface will be an optimized surface. This flag is
* currently only valid in conjunction with the DDSCAPS_TEXTURE flag. The surface
* will be created without any underlying video memory until loaded.
*/
#define DDSCAPS_OPTIMIZED 0x80000000l
/*
* Indicates that this surface will receive data from a video port using
* the de-interlacing hardware. This allows the driver to allocate memory
* for any extra buffers that may be required. The DDSCAPS_VIDEOPORT and
* DDSCAPS_OVERLAY flags must also be set.
*/
#define DDSCAPS2_HARDWAREDEINTERLACE 0x00000002L
/*
* Indicates to the driver that this surface will be locked very frequently
* (for procedural textures, dynamic lightmaps, etc). Surfaces with this cap
* set must also have DDSCAPS_TEXTURE. This cap cannot be used with
* DDSCAPS2_HINTSTATIC and DDSCAPS2_OPAQUE.
*/
#define DDSCAPS2_HINTDYNAMIC 0x00000004L
/*
* Indicates to the driver that this surface can be re-ordered/retiled on
* load. This operation will not change the size of the texture. It is
* relatively fast and symmetrical, since the application may lock these
* bits (although it will take a performance hit when doing so). Surfaces
* with this cap set must also have DDSCAPS_TEXTURE. This cap cannot be
* used with DDSCAPS2_HINTDYNAMIC and DDSCAPS2_OPAQUE.
*/
#define DDSCAPS2_HINTSTATIC 0x00000008L
/*
* Indicates that the client would like this texture surface to be managed by the
* DirectDraw/Direct3D runtime. Surfaces with this cap set must also have
* DDSCAPS_TEXTURE set.
*/
#define DDSCAPS2_TEXTUREMANAGE 0x00000010L
/*
* These bits are reserved for internal use */
#define DDSCAPS2_RESERVED1 0x00000020L
#define DDSCAPS2_RESERVED2 0x00000040L
/*
* Indicates to the driver that this surface will never be locked again.
* The driver is free to optimize this surface via retiling and actual compression.
* All calls to Lock() or Blts from this surface will fail. Surfaces with this
* cap set must also have DDSCAPS_TEXTURE. This cap cannot be used with
* DDSCAPS2_HINTDYNAMIC and DDSCAPS2_HINTSTATIC.
*/
#define DDSCAPS2_OPAQUE 0x00000080L
/*
* Applications should set this bit at CreateSurface time to indicate that they
* intend to use antialiasing. Only valid if DDSCAPS_3DDEVICE is also set.
*/
#define DDSCAPS2_HINTANTIALIASING 0x00000100L
/****************************************************************************
*
* DIRECTDRAW DRIVER CAPABILITY FLAGS
*
****************************************************************************/
/*
* Display hardware has 3D acceleration.
*/
#define DDCAPS_3D 0x00000001l
/*
* Indicates that DirectDraw will support only dest rectangles that are aligned
* on DIRECTDRAWCAPS.dwAlignBoundaryDest boundaries of the surface, respectively.
* READ ONLY.
*/
#define DDCAPS_ALIGNBOUNDARYDEST 0x00000002l
/*
* Indicates that DirectDraw will support only source rectangles whose sizes in
* BYTEs are DIRECTDRAWCAPS.dwAlignSizeDest multiples, respectively. READ ONLY.
*/
#define DDCAPS_ALIGNSIZEDEST 0x00000004l
/*
* Indicates that DirectDraw will support only source rectangles that are aligned
* on DIRECTDRAWCAPS.dwAlignBoundarySrc boundaries of the surface, respectively.
* READ ONLY.
*/
#define DDCAPS_ALIGNBOUNDARYSRC 0x00000008l
/*
* Indicates that DirectDraw will support only source rectangles whose sizes in
* BYTEs are DIRECTDRAWCAPS.dwAlignSizeSrc multiples, respectively. READ ONLY.
*/
#define DDCAPS_ALIGNSIZESRC 0x00000010l
/*
* Indicates that DirectDraw will create video memory surfaces that have a stride
* alignment equal to DIRECTDRAWCAPS.dwAlignStride. READ ONLY.
*/
#define DDCAPS_ALIGNSTRIDE 0x00000020l
/*
* Display hardware is capable of blt operations.
*/
#define DDCAPS_BLT 0x00000040l
/*
* Display hardware is capable of asynchronous blt operations.
*/
#define DDCAPS_BLTQUEUE 0x00000080l
/*
* Display hardware is capable of color space conversions during the blt operation.
*/
#define DDCAPS_BLTFOURCC 0x00000100l
/*
* Display hardware is capable of stretching during blt operations.
*/
#define DDCAPS_BLTSTRETCH 0x00000200l
/*
* Display hardware is shared with GDI.
*/
#define DDCAPS_GDI 0x00000400l
/*
* Display hardware can overlay.
*/
#define DDCAPS_OVERLAY 0x00000800l
/*
* Set if display hardware supports overlays but can not clip them.
*/
#define DDCAPS_OVERLAYCANTCLIP 0x00001000l
/*
* Indicates that overlay hardware is capable of color space conversions during
* the overlay operation.
*/
#define DDCAPS_OVERLAYFOURCC 0x00002000l
/*
* Indicates that stretching can be done by the overlay hardware.
*/
#define DDCAPS_OVERLAYSTRETCH 0x00004000l
/*
* Indicates that unique DirectDrawPalettes can be created for DirectDrawSurfaces
* other than the primary surface.
*/
#define DDCAPS_PALETTE 0x00008000l
/*
* Indicates that palette changes can be syncd with the veritcal refresh.
*/
#define DDCAPS_PALETTEVSYNC 0x00010000l
/*
* Display hardware can return the current scan line.
*/
#define DDCAPS_READSCANLINE 0x00020000l
/*
* Display hardware has stereo vision capabilities. DDSCAPS_PRIMARYSURFACELEFT
* can be created.
*/
#define DDCAPS_STEREOVIEW 0x00040000l
/*
* Display hardware is capable of generating a vertical blank interrupt.
*/
#define DDCAPS_VBI 0x00080000l
/*
* Supports the use of z buffers with blt operations.
*/
#define DDCAPS_ZBLTS 0x00100000l
/*
* Supports Z Ordering of overlays.
*/
#define DDCAPS_ZOVERLAYS 0x00200000l
/*
* Supports color key
*/
#define DDCAPS_COLORKEY 0x00400000l
/*
* Supports alpha surfaces
*/
#define DDCAPS_ALPHA 0x00800000l
/*
* colorkey is hardware assisted(DDCAPS_COLORKEY will also be set)
*/
#define DDCAPS_COLORKEYHWASSIST 0x01000000l
/*
* no hardware support at all
*/
#define DDCAPS_NOHARDWARE 0x02000000l
/*
* Display hardware is capable of color fill with bltter
*/
#define DDCAPS_BLTCOLORFILL 0x04000000l
/*
* Display hardware is bank switched, and potentially very slow at
* random access to VRAM.
*/
#define DDCAPS_BANKSWITCHED 0x08000000l
/*
* Display hardware is capable of depth filling Z-buffers with bltter
*/
#define DDCAPS_BLTDEPTHFILL 0x10000000l
/*
* Display hardware is capable of clipping while bltting.
*/
#define DDCAPS_CANCLIP 0x20000000l
/*
* Display hardware is capable of clipping while stretch bltting.
*/
#define DDCAPS_CANCLIPSTRETCHED 0x40000000l
/*
* Display hardware is capable of bltting to or from system memory
*/
#define DDCAPS_CANBLTSYSMEM 0x80000000l
/****************************************************************************
*
* MORE DIRECTDRAW DRIVER CAPABILITY FLAGS (dwCaps2)
*
****************************************************************************/
/*
* Display hardware is certified
*/
#define DDCAPS2_CERTIFIED 0x00000001l
/*
* Driver cannot interleave 2D operations (lock and blt) to surfaces with
* Direct3D rendering operations between calls to BeginScene() and EndScene()
*/
#define DDCAPS2_NO2DDURING3DSCENE 0x00000002l
/*
* Display hardware contains a video port
*/
#define DDCAPS2_VIDEOPORT 0x00000004l
/*
* The overlay can be automatically flipped according to the video port
* VSYNCs, providing automatic doubled buffered display of video port
* data using an overlay
*/
#define DDCAPS2_AUTOFLIPOVERLAY 0x00000008l
/*
* Overlay can display each field of interlaced data individually while
* it is interleaved in memory without causing jittery artifacts.
*/
#define DDCAPS2_CANBOBINTERLEAVED 0x00000010l
/*
* Overlay can display each field of interlaced data individually while
* it is not interleaved in memory without causing jittery artifacts.
*/
#define DDCAPS2_CANBOBNONINTERLEAVED 0x00000020l
/*
* The overlay surface contains color controls (brightness, sharpness, etc.)
*/
#define DDCAPS2_COLORCONTROLOVERLAY 0x00000040l
/*
* The primary surface contains color controls (gamma, etc.)
*/
#define DDCAPS2_COLORCONTROLPRIMARY 0x00000080l
/*
* RGBZ -> RGB supported for 16:16 RGB:Z
*/
#define DDCAPS2_CANDROPZ16BIT 0x00000100l
/*
* Driver supports non-local video memory.
*/
#define DDCAPS2_NONLOCALVIDMEM 0x00000200l
/*
* Dirver supports non-local video memory but has different capabilities for
* non-local video memory surfaces. If this bit is set then so must
* DDCAPS2_NONLOCALVIDMEM.
*/
#define DDCAPS2_NONLOCALVIDMEMCAPS 0x00000400l
/*
* Driver neither requires nor prefers surfaces to be pagelocked when performing
* blts involving system memory surfaces
*/
#define DDCAPS2_NOPAGELOCKREQUIRED 0x00000800l
/*
* Driver can create surfaces which are wider than the primary surface
*/
#define DDCAPS2_WIDESURFACES 0x00001000l
/*
* Driver supports bob without using a video port by handling the
* DDFLIP_ODD and DDFLIP_EVEN flags specified in Flip.
*/
#define DDCAPS2_CANFLIPODDEVEN 0x00002000l
/*
* Driver supports bob using hardware
*/
#define DDCAPS2_CANBOBHARDWARE 0x00004000l
/*
* Driver supports bltting any FOURCC surface to another surface of the same FOURCC
*/
#define DDCAPS2_COPYFOURCC 0x00008000l
/*
* Driver supports loadable gamma ramps for the primary surface
*/
#define DDCAPS2_PRIMARYGAMMA 0x00020000l
/*
* Driver can render in windowed mode.
*/
#define DDCAPS2_CANRENDERWINDOWED 0x00080000l
/*
* A calibrator is available to adjust the gamma ramp according to the
* physical display properties so that the result will be identical on
* all calibrated systems.
*/
#define DDCAPS2_CANCALIBRATEGAMMA 0x00100000l
/*
* Indicates that the driver will respond to DDFLIP_INTERVALn flags
*/
#define DDCAPS2_FLIPINTERVAL 0x00200000l
/*
* Indicates that the driver will respond to DDFLIP_NOVSYNC
*/
#define DDCAPS2_FLIPNOVSYNC 0x00400000l
/****************************************************************************
*
* DIRECTDRAW FX ALPHA CAPABILITY FLAGS
*
****************************************************************************/
/*
* Supports alpha blending around the edge of a source color keyed surface.
* For Blt.
*/
#define DDFXALPHACAPS_BLTALPHAEDGEBLEND 0x00000001l
/*
* Supports alpha information in the pixel format. The bit depth of alpha
* information in the pixel format can be 1,2,4, or 8. The alpha value becomes
* more opaque as the alpha value increases. (0 is transparent.)
* For Blt.
*/
#define DDFXALPHACAPS_BLTALPHAPIXELS 0x00000002l
/*
* Supports alpha information in the pixel format. The bit depth of alpha
* information in the pixel format can be 1,2,4, or 8. The alpha value
* becomes more transparent as the alpha value increases. (0 is opaque.)
* This flag can only be set if DDCAPS_ALPHA is set.
* For Blt.
*/
#define DDFXALPHACAPS_BLTALPHAPIXELSNEG 0x00000004l
/*
* Supports alpha only surfaces. The bit depth of an alpha only surface can be
* 1,2,4, or 8. The alpha value becomes more opaque as the alpha value increases.
* (0 is transparent.)
* For Blt.
*/
#define DDFXALPHACAPS_BLTALPHASURFACES 0x00000008l
/*
* The depth of the alpha channel data can range can be 1,2,4, or 8.
* The NEG suffix indicates that this alpha channel becomes more transparent
* as the alpha value increases. (0 is opaque.) This flag can only be set if
* DDCAPS_ALPHA is set.
* For Blt.
*/
#define DDFXALPHACAPS_BLTALPHASURFACESNEG 0x00000010l
/*
* Supports alpha blending around the edge of a source color keyed surface.
* For Overlays.
*/
#define DDFXALPHACAPS_OVERLAYALPHAEDGEBLEND 0x00000020l
/*
* Supports alpha information in the pixel format. The bit depth of alpha
* information in the pixel format can be 1,2,4, or 8. The alpha value becomes
* more opaque as the alpha value increases. (0 is transparent.)
* For Overlays.
*/
#define DDFXALPHACAPS_OVERLAYALPHAPIXELS 0x00000040l
/*
* Supports alpha information in the pixel format. The bit depth of alpha
* information in the pixel format can be 1,2,4, or 8. The alpha value
* becomes more transparent as the alpha value increases. (0 is opaque.)
* This flag can only be set if DDCAPS_ALPHA is set.
* For Overlays.
*/
#define DDFXALPHACAPS_OVERLAYALPHAPIXELSNEG 0x00000080l
/*
* Supports alpha only surfaces. The bit depth of an alpha only surface can be
* 1,2,4, or 8. The alpha value becomes more opaque as the alpha value increases.
* (0 is transparent.)
* For Overlays.
*/
#define DDFXALPHACAPS_OVERLAYALPHASURFACES 0x00000100l
/*
* The depth of the alpha channel data can range can be 1,2,4, or 8.
* The NEG suffix indicates that this alpha channel becomes more transparent
* as the alpha value increases. (0 is opaque.) This flag can only be set if
* DDCAPS_ALPHA is set.
* For Overlays.
*/
#define DDFXALPHACAPS_OVERLAYALPHASURFACESNEG 0x00000200l
#if DIRECTDRAW_VERSION < 0x0600
#endif // DIRECTDRAW_VERSION
/****************************************************************************
*
* DIRECTDRAW FX CAPABILITY FLAGS
*
****************************************************************************/
/*
* Uses arithmetic operations to stretch and shrink surfaces during blt
* rather than pixel doubling techniques. Along the Y axis.
*/
#define DDFXCAPS_BLTARITHSTRETCHY 0x00000020l
/*
* Uses arithmetic operations to stretch during blt
* rather than pixel doubling techniques. Along the Y axis. Only
* works for x1, x2, etc.
*/
#define DDFXCAPS_BLTARITHSTRETCHYN 0x00000010l
/*
* Supports mirroring left to right in blt.
*/
#define DDFXCAPS_BLTMIRRORLEFTRIGHT 0x00000040l
/*
* Supports mirroring top to bottom in blt.
*/
#define DDFXCAPS_BLTMIRRORUPDOWN 0x00000080l
/*
* Supports arbitrary rotation for blts.
*/
#define DDFXCAPS_BLTROTATION 0x00000100l
/*
* Supports 90 degree rotations for blts.
*/
#define DDFXCAPS_BLTROTATION90 0x00000200l
/*
* DirectDraw supports arbitrary shrinking of a surface along the
* x axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSHRINKX 0x00000400l
/*
* DirectDraw supports integer shrinking (1x,2x,) of a surface
* along the x axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSHRINKXN 0x00000800l
/*
* DirectDraw supports arbitrary shrinking of a surface along the
* y axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSHRINKY 0x00001000l
/*
* DirectDraw supports integer shrinking (1x,2x,) of a surface
* along the y axis (vertical direction) for blts.
*/
#define DDFXCAPS_BLTSHRINKYN 0x00002000l
/*
* DirectDraw supports arbitrary stretching of a surface along the
* x axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSTRETCHX 0x00004000l
/*
* DirectDraw supports integer stretching (1x,2x,) of a surface
* along the x axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSTRETCHXN 0x00008000l
/*
* DirectDraw supports arbitrary stretching of a surface along the
* y axis (horizontal direction) for blts.
*/
#define DDFXCAPS_BLTSTRETCHY 0x00010000l
/*
* DirectDraw supports integer stretching (1x,2x,) of a surface
* along the y axis (vertical direction) for blts.
*/
#define DDFXCAPS_BLTSTRETCHYN 0x00020000l
/*
* Uses arithmetic operations to stretch and shrink surfaces during
* overlay rather than pixel doubling techniques. Along the Y axis
* for overlays.
*/
#define DDFXCAPS_OVERLAYARITHSTRETCHY 0x00040000l
/*
* Uses arithmetic operations to stretch surfaces during
* overlay rather than pixel doubling techniques. Along the Y axis
* for overlays. Only works for x1, x2, etc.
*/
#define DDFXCAPS_OVERLAYARITHSTRETCHYN 0x00000008l
/*
* DirectDraw supports arbitrary shrinking of a surface along the
* x axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSHRINKX 0x00080000l
/*
* DirectDraw supports integer shrinking (1x,2x,) of a surface
* along the x axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSHRINKXN 0x00100000l
/*
* DirectDraw supports arbitrary shrinking of a surface along the
* y axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSHRINKY 0x00200000l
/*
* DirectDraw supports integer shrinking (1x,2x,) of a surface
* along the y axis (vertical direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSHRINKYN 0x00400000l
/*
* DirectDraw supports arbitrary stretching of a surface along the
* x axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSTRETCHX 0x00800000l
/*
* DirectDraw supports integer stretching (1x,2x,) of a surface
* along the x axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSTRETCHXN 0x01000000l
/*
* DirectDraw supports arbitrary stretching of a surface along the
* y axis (horizontal direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSTRETCHY 0x02000000l
/*
* DirectDraw supports integer stretching (1x,2x,) of a surface
* along the y axis (vertical direction) for overlays.
*/
#define DDFXCAPS_OVERLAYSTRETCHYN 0x04000000l
/*
* DirectDraw supports mirroring of overlays across the vertical axis
*/
#define DDFXCAPS_OVERLAYMIRRORLEFTRIGHT 0x08000000l
/*
* DirectDraw supports mirroring of overlays across the horizontal axis
*/
#define DDFXCAPS_OVERLAYMIRRORUPDOWN 0x10000000l
/*
* Driver can do alpha blending for blits.
*/
#define DDFXCAPS_BLTALPHA 0x00000001l
/*
* Driver can do geometric transformations (or warps) for blits.
*/
#define DDFXCAPS_BLTTRANSFORM 0x00000002l
/*
* Driver can do surface-reconstruction filtering for warped blits.
*/
#define DDFXCAPS_BLTFILTER DDFXCAPS_BLTARITHSTRETCHY
/*
* Driver can do alpha blending for overlays.
*/
#define DDFXCAPS_OVERLAYALPHA 0x00000004l
/*
* Driver can do geometric transformations (or warps) for overlays.
*/
#define DDFXCAPS_OVERLAYTRANSFORM 0x20000000l
/*
* Driver can do surface-reconstruction filtering for warped overlays.
*/
#define DDFXCAPS_OVERLAYFILTER DDFXCAPS_OVERLAYARITHSTRETCHY
/****************************************************************************
*
* DIRECTDRAW STEREO VIEW CAPABILITIES
*
****************************************************************************/
/*
* The stereo view is accomplished via enigma encoding.
*/
#define DDSVCAPS_ENIGMA 0x00000001l
/*
* The stereo view is accomplished via high frequency flickering.
*/
#define DDSVCAPS_FLICKER 0x00000002l
/*
* The stereo view is accomplished via red and blue filters applied
* to the left and right eyes. All images must adapt their colorspaces
* for this process.
*/
#define DDSVCAPS_REDBLUE 0x00000004l
/*
* The stereo view is accomplished with split screen technology.
*/
#define DDSVCAPS_SPLIT 0x00000008l
/****************************************************************************
*
* DIRECTDRAWPALETTE CAPABILITIES
*
****************************************************************************/
/*
* Index is 4 bits. There are sixteen color entries in the palette table.
*/
#define DDPCAPS_4BIT 0x00000001l
/*
* Index is onto a 8 bit color index. This field is only valid with the
* DDPCAPS_1BIT, DDPCAPS_2BIT or DDPCAPS_4BIT capability and the target
* surface is in 8bpp. Each color entry is one byte long and is an index
* into destination surface's 8bpp palette.
*/
#define DDPCAPS_8BITENTRIES 0x00000002l
/*
* Index is 8 bits. There are 256 color entries in the palette table.
*/
#define DDPCAPS_8BIT 0x00000004l
/*
* Indicates that this DIRECTDRAWPALETTE should use the palette color array
* passed into the lpDDColorArray parameter to initialize the DIRECTDRAWPALETTE
* object.
*/
#define DDPCAPS_INITIALIZE 0x00000008l
/*
* This palette is the one attached to the primary surface. Changing this
* table has immediate effect on the display unless DDPSETPAL_VSYNC is specified
* and supported.
*/
#define DDPCAPS_PRIMARYSURFACE 0x00000010l
/*
* This palette is the one attached to the primary surface left. Changing
* this table has immediate effect on the display for the left eye unless
* DDPSETPAL_VSYNC is specified and supported.
*/
#define DDPCAPS_PRIMARYSURFACELEFT 0x00000020l
/*
* This palette can have all 256 entries defined
*/
#define DDPCAPS_ALLOW256 0x00000040l
/*
* This palette can have modifications to it synced with the monitors
* refresh rate.
*/
#define DDPCAPS_VSYNC 0x00000080l
/*
* Index is 1 bit. There are two color entries in the palette table.
*/
#define DDPCAPS_1BIT 0x00000100l
/*
* Index is 2 bit. There are four color entries in the palette table.
*/
#define DDPCAPS_2BIT 0x00000200l
/*
* The peFlags member of PALETTEENTRY denotes an 8 bit alpha value
*/
#define DDPCAPS_ALPHA 0x00000400l
/****************************************************************************
*
* DIRECTDRAWPALETTE SETENTRY CONSTANTS
*
****************************************************************************/
/****************************************************************************
*
* DIRECTDRAWPALETTE GETENTRY CONSTANTS
*
****************************************************************************/
/* 0 is the only legal value */
/****************************************************************************
*
* DIRECTDRAWSURFACE SETPRIVATEDATA CONSTANTS
*
****************************************************************************/
/*
* The passed pointer is an IUnknown ptr. The cbData argument to SetPrivateData
* must be set to sizeof(IUnknown*). DirectDraw will call AddRef through this
* pointer and Release when the private data is destroyed. This includes when
* the surface or palette is destroyed before such priovate data is destroyed.
*/
#define DDSPD_IUNKNOWNPOINTER 0x00000001L
/*
* Private data is only valid for the current state of the object,
* as determined by the uniqueness value.
*/
#define DDSPD_VOLATILE 0x00000002L
/****************************************************************************
*
* DIRECTDRAWSURFACE SETPALETTE CONSTANTS
*
****************************************************************************/
/****************************************************************************
*
* DIRECTDRAW BITDEPTH CONSTANTS
*
* NOTE: These are only used to indicate supported bit depths. These
* are flags only, they are not to be used as an actual bit depth. The
* absolute numbers 1, 2, 4, 8, 16, 24 and 32 are used to indicate actual
* bit depths in a surface or for changing the display mode.
*
****************************************************************************/
/*
* 1 bit per pixel.
*/
#define DDBD_1 0x00004000l
/*
* 2 bits per pixel.
*/
#define DDBD_2 0x00002000l
/*
* 4 bits per pixel.
*/
#define DDBD_4 0x00001000l
/*
* 8 bits per pixel.
*/
#define DDBD_8 0x00000800l
/*
* 16 bits per pixel.
*/
#define DDBD_16 0x00000400l
/*
* 24 bits per pixel.
*/
#define DDBD_24 0X00000200l
/*
* 32 bits per pixel.
*/
#define DDBD_32 0x00000100l
/****************************************************************************
*
* DIRECTDRAWSURFACE SET/GET COLOR KEY FLAGS
*
****************************************************************************/
/*
* Set if the structure contains a color space. Not set if the structure
* contains a single color key.
*/
#define DDCKEY_COLORSPACE 0x00000001l
/*
* Set if the structure specifies a color key or color space which is to be
* used as a destination color key for blt operations.
*/
#define DDCKEY_DESTBLT 0x00000002l
/*
* Set if the structure specifies a color key or color space which is to be
* used as a destination color key for overlay operations.
*/
#define DDCKEY_DESTOVERLAY 0x00000004l
/*
* Set if the structure specifies a color key or color space which is to be
* used as a source color key for blt operations.
*/
#define DDCKEY_SRCBLT 0x00000008l
/*
* Set if the structure specifies a color key or color space which is to be
* used as a source color key for overlay operations.
*/
#define DDCKEY_SRCOVERLAY 0x00000010l
/****************************************************************************
*
* DIRECTDRAW COLOR KEY CAPABILITY FLAGS
*
****************************************************************************/
/*
* Supports transparent blting using a color key to identify the replaceable
* bits of the destination surface for RGB colors.
*/
#define DDCKEYCAPS_DESTBLT 0x00000001l
/*
* Supports transparent blting using a color space to identify the replaceable
* bits of the destination surface for RGB colors.
*/
#define DDCKEYCAPS_DESTBLTCLRSPACE 0x00000002l
/*
* Supports transparent blting using a color space to identify the replaceable
* bits of the destination surface for YUV colors.
*/
#define DDCKEYCAPS_DESTBLTCLRSPACEYUV 0x00000004l
/*
* Supports transparent blting using a color key to identify the replaceable
* bits of the destination surface for YUV colors.
*/
#define DDCKEYCAPS_DESTBLTYUV 0x00000008l
/*
* Supports overlaying using colorkeying of the replaceable bits of the surface
* being overlayed for RGB colors.
*/
#define DDCKEYCAPS_DESTOVERLAY 0x00000010l
/*
* Supports a color space as the color key for the destination for RGB colors.
*/
#define DDCKEYCAPS_DESTOVERLAYCLRSPACE 0x00000020l
/*
* Supports a color space as the color key for the destination for YUV colors.
*/
#define DDCKEYCAPS_DESTOVERLAYCLRSPACEYUV 0x00000040l
/*
* Supports only one active destination color key value for visible overlay
* surfaces.
*/
#define DDCKEYCAPS_DESTOVERLAYONEACTIVE 0x00000080l
/*
* Supports overlaying using colorkeying of the replaceable bits of the
* surface being overlayed for YUV colors.
*/
#define DDCKEYCAPS_DESTOVERLAYYUV 0x00000100l
/*
* Supports transparent blting using the color key for the source with
* this surface for RGB colors.
*/
#define DDCKEYCAPS_SRCBLT 0x00000200l
/*
* Supports transparent blting using a color space for the source with
* this surface for RGB colors.
*/
#define DDCKEYCAPS_SRCBLTCLRSPACE 0x00000400l
/*
* Supports transparent blting using a color space for the source with
* this surface for YUV colors.
*/
#define DDCKEYCAPS_SRCBLTCLRSPACEYUV 0x00000800l
/*
* Supports transparent blting using the color key for the source with
* this surface for YUV colors.
*/
#define DDCKEYCAPS_SRCBLTYUV 0x00001000l
/*
* Supports overlays using the color key for the source with this
* overlay surface for RGB colors.
*/
#define DDCKEYCAPS_SRCOVERLAY 0x00002000l
/*
* Supports overlays using a color space as the source color key for
* the overlay surface for RGB colors.
*/
#define DDCKEYCAPS_SRCOVERLAYCLRSPACE 0x00004000l
/*
* Supports overlays using a color space as the source color key for
* the overlay surface for YUV colors.
*/
#define DDCKEYCAPS_SRCOVERLAYCLRSPACEYUV 0x00008000l
/*
* Supports only one active source color key value for visible
* overlay surfaces.
*/
#define DDCKEYCAPS_SRCOVERLAYONEACTIVE 0x00010000l
/*
* Supports overlays using the color key for the source with this
* overlay surface for YUV colors.
*/
#define DDCKEYCAPS_SRCOVERLAYYUV 0x00020000l
/*
* there are no bandwidth trade-offs for using colorkey with an overlay
*/
#define DDCKEYCAPS_NOCOSTOVERLAY 0x00040000l
/****************************************************************************
*
* DIRECTDRAW PIXELFORMAT FLAGS
*
****************************************************************************/
/*
* The surface has alpha channel information in the pixel format.
*/
#define DDPF_ALPHAPIXELS 0x00000001l
/*
* The pixel format contains alpha only information
*/
#define DDPF_ALPHA 0x00000002l
/*
* The FourCC code is valid.
*/
#define DDPF_FOURCC 0x00000004l
/*
* The surface is 4-bit color indexed.
*/
#define DDPF_PALETTEINDEXED4 0x00000008l
/*
* The surface is indexed into a palette which stores indices
* into the destination surface's 8-bit palette.
*/
#define DDPF_PALETTEINDEXEDTO8 0x00000010l
/*
* The surface is 8-bit color indexed.
*/
#define DDPF_PALETTEINDEXED8 0x00000020l
/*
* The RGB data in the pixel format structure is valid.
*/
#define DDPF_RGB 0x00000040l
/*
* The surface will accept pixel data in the format specified
* and compress it during the write.
*/
#define DDPF_COMPRESSED 0x00000080l
/*
* The surface will accept RGB data and translate it during
* the write to YUV data. The format of the data to be written
* will be contained in the pixel format structure. The DDPF_RGB
* flag will be set.
*/
#define DDPF_RGBTOYUV 0x00000100l
/*
* pixel format is YUV - YUV data in pixel format struct is valid
*/
#define DDPF_YUV 0x00000200l
/*
* pixel format is a z buffer only surface
*/
#define DDPF_ZBUFFER 0x00000400l
/*
* The surface is 1-bit color indexed.
*/
#define DDPF_PALETTEINDEXED1 0x00000800l
/*
* The surface is 2-bit color indexed.
*/
#define DDPF_PALETTEINDEXED2 0x00001000l
/*
* The surface contains Z information in the pixels
*/
#define DDPF_ZPIXELS 0x00002000l
/*
* The surface contains stencil information along with Z
*/
#define DDPF_STENCILBUFFER 0x00004000l
/*
* Premultiplied alpha format -- the color components have been
* premultiplied by the alpha component.
*/
#define DDPF_ALPHAPREMULT 0x00008000l
/*
* Luminance data in the pixel format is valid.
* Use this flag for luminance-only or luminance+alpha surfaces,
* the bit depth is then ddpf.dwLuminanceBitCount.
*/
#define DDPF_LUMINANCE 0x00020000l
/*
* Luminance data in the pixel format is valid.
* Use this flag when hanging luminance off bumpmap surfaces,
* the bit mask for the luminance portion of the pixel is then
* ddpf.dwBumpLuminanceBitMask
*/
#define DDPF_BUMPLUMINANCE 0x00040000l
/*
* Bump map dUdV data in the pixel format is valid.
*/
#define DDPF_BUMPDUDV 0x00080000l
/*===========================================================================
*
*
* DIRECTDRAW CALLBACK FLAGS
*
*
*==========================================================================*/
/****************************************************************************
*
* DIRECTDRAW ENUMSURFACES FLAGS
*
****************************************************************************/
/*
* Enumerate all of the surfaces that meet the search criterion.
*/
#define DDENUMSURFACES_ALL 0x00000001l
/*
* A search hit is a surface that matches the surface description.
*/
#define DDENUMSURFACES_MATCH 0x00000002l
/*
* A search hit is a surface that does not match the surface description.
*/
#define DDENUMSURFACES_NOMATCH 0x00000004l
/*
* Enumerate the first surface that can be created which meets the search criterion.
*/
#define DDENUMSURFACES_CANBECREATED 0x00000008l
/*
* Enumerate the surfaces that already exist that meet the search criterion.
*/
#define DDENUMSURFACES_DOESEXIST 0x00000010l
/****************************************************************************
*
* DIRECTDRAW SETDISPLAYMODE FLAGS
*
****************************************************************************/
/*
* The desired mode is a standard VGA mode
*/
#define DDSDM_STANDARDVGAMODE 0x00000001l
/****************************************************************************
*
* DIRECTDRAW ENUMDISPLAYMODES FLAGS
*
****************************************************************************/
/*
* Enumerate Modes with different refresh rates. EnumDisplayModes guarantees
* that a particular mode will be enumerated only once. This flag specifies whether
* the refresh rate is taken into account when determining if a mode is unique.
*/
#define DDEDM_REFRESHRATES 0x00000001l
/*
* Enumerate VGA modes. Specify this flag if you wish to enumerate supported VGA
* modes such as mode 0x13 in addition to the usual ModeX modes (which are always
* enumerated if the application has previously called SetCooperativeLevel with the
* DDSCL_ALLOWMODEX flag set).
*/
#define DDEDM_STANDARDVGAMODES 0x00000002L
/****************************************************************************
*
* DIRECTDRAW SETCOOPERATIVELEVEL FLAGS
*
****************************************************************************/
/*
* Exclusive mode owner will be responsible for the entire primary surface.
* GDI can be ignored. used with DD
*/
#define DDSCL_FULLSCREEN 0x00000001l
/*
* allow CTRL_ALT_DEL to work while in fullscreen exclusive mode
*/
#define DDSCL_ALLOWREBOOT 0x00000002l
/*
* prevents DDRAW from modifying the application window.
* prevents DDRAW from minimize/restore the application window on activation.
*/
#define DDSCL_NOWINDOWCHANGES 0x00000004l
/*
* app wants to work as a regular Windows application
*/
#define DDSCL_NORMAL 0x00000008l
/*
* app wants exclusive access
*/
#define DDSCL_EXCLUSIVE 0x00000010l
/*
* app can deal with non-windows display modes
*/
#define DDSCL_ALLOWMODEX 0x00000040l
/*
* this window will receive the focus messages
*/
#define DDSCL_SETFOCUSWINDOW 0x00000080l
/*
* this window is associated with the DDRAW object and will
* cover the screen in fullscreen mode
*/
#define DDSCL_SETDEVICEWINDOW 0x00000100l
/*
* app wants DDRAW to create a window to be associated with the
* DDRAW object
*/
#define DDSCL_CREATEDEVICEWINDOW 0x00000200l
/*
* App explicitly asks DDRAW/D3D to be multithread safe. This makes D3D
* take the global crtisec more frequently.
*/
#define DDSCL_MULTITHREADED 0x00000400l
/*
* App hints that it would like to keep the FPU set up for optimal Direct3D
* performance (single precision and exceptions disabled) so Direct3D
* does not need to explicitly set the FPU each time
*/
#define DDSCL_FPUSETUP 0x00000800l
/****************************************************************************
*
* DIRECTDRAW BLT FLAGS
*
****************************************************************************/
/*
* Use the alpha information in the pixel format or the alpha channel surface
* attached to the destination surface as the alpha channel for this blt.
*/
#define DDBLT_ALPHADEST 0x00000001l
/*
* Use the dwConstAlphaDest field in the DDBLTFX structure as the alpha channel
* for the destination surface for this blt.
*/
#define DDBLT_ALPHADESTCONSTOVERRIDE 0x00000002l
/*
* The NEG suffix indicates that the destination surface becomes more
* transparent as the alpha value increases. (0 is opaque)
*/
#define DDBLT_ALPHADESTNEG 0x00000004l
/*
* Use the lpDDSAlphaDest field in the DDBLTFX structure as the alpha
* channel for the destination for this blt.
*/
#define DDBLT_ALPHADESTSURFACEOVERRIDE 0x00000008l
/*
* Use the dwAlphaEdgeBlend field in the DDBLTFX structure as the alpha channel
* for the edges of the image that border the color key colors.
*/
#define DDBLT_ALPHAEDGEBLEND 0x00000010l
/*
* Use the alpha information in the pixel format or the alpha channel surface
* attached to the source surface as the alpha channel for this blt.
*/
#define DDBLT_ALPHASRC 0x00000020l
/*
* Use the dwConstAlphaSrc field in the DDBLTFX structure as the alpha channel
* for the source for this blt.
*/
#define DDBLT_ALPHASRCCONSTOVERRIDE 0x00000040l
/*
* The NEG suffix indicates that the source surface becomes more transparent
* as the alpha value increases. (0 is opaque)
*/
#define DDBLT_ALPHASRCNEG 0x00000080l
/*
* Use the lpDDSAlphaSrc field in the DDBLTFX structure as the alpha channel
* for the source for this blt.
*/
#define DDBLT_ALPHASRCSURFACEOVERRIDE 0x00000100l
/*
* Do this blt asynchronously through the FIFO in the order received. If
* there is no room in the hardware FIFO fail the call.
*/
#define DDBLT_ASYNC 0x00000200l
/*
* Uses the dwFillColor field in the DDBLTFX structure as the RGB color
* to fill the destination rectangle on the destination surface with.
*/
#define DDBLT_COLORFILL 0x00000400l
/*
* Uses the dwDDFX field in the DDBLTFX structure to specify the effects
* to use for the blt.
*/
#define DDBLT_DDFX 0x00000800l
/*
* Uses the dwDDROPS field in the DDBLTFX structure to specify the ROPS
* that are not part of the Win32 API.
*/
#define DDBLT_DDROPS 0x00001000l
/*
* Use the color key associated with the destination surface.
*/
#define DDBLT_KEYDEST 0x00002000l
/*
* Use the dckDestColorkey field in the DDBLTFX structure as the color key
* for the destination surface.
*/
#define DDBLT_KEYDESTOVERRIDE 0x00004000l
/*
* Use the color key associated with the source surface.
*/
#define DDBLT_KEYSRC 0x00008000l
/*
* Use the dckSrcColorkey field in the DDBLTFX structure as the color key
* for the source surface.
*/
#define DDBLT_KEYSRCOVERRIDE 0x00010000l
/*
* Use the dwROP field in the DDBLTFX structure for the raster operation
* for this blt. These ROPs are the same as the ones defined in the Win32 API.
*/
#define DDBLT_ROP 0x00020000l
/*
* Use the dwRotationAngle field in the DDBLTFX structure as the angle
* (specified in 1/100th of a degree) to rotate the surface.
*/
#define DDBLT_ROTATIONANGLE 0x00040000l
/*
* Z-buffered blt using the z-buffers attached to the source and destination
* surfaces and the dwZBufferOpCode field in the DDBLTFX structure as the
* z-buffer opcode.
*/
#define DDBLT_ZBUFFER 0x00080000l
/*
* Z-buffered blt using the dwConstDest Zfield and the dwZBufferOpCode field
* in the DDBLTFX structure as the z-buffer and z-buffer opcode respectively
* for the destination.
*/
#define DDBLT_ZBUFFERDESTCONSTOVERRIDE 0x00100000l
/*
* Z-buffered blt using the lpDDSDestZBuffer field and the dwZBufferOpCode
* field in the DDBLTFX structure as the z-buffer and z-buffer opcode
* respectively for the destination.
*/
#define DDBLT_ZBUFFERDESTOVERRIDE 0x00200000l
/*
* Z-buffered blt using the dwConstSrcZ field and the dwZBufferOpCode field
* in the DDBLTFX structure as the z-buffer and z-buffer opcode respectively
* for the source.
*/
#define DDBLT_ZBUFFERSRCCONSTOVERRIDE 0x00400000l
/*
* Z-buffered blt using the lpDDSSrcZBuffer field and the dwZBufferOpCode
* field in the DDBLTFX structure as the z-buffer and z-buffer opcode
* respectively for the source.
*/
#define DDBLT_ZBUFFERSRCOVERRIDE 0x00800000l
/*
* wait until the device is ready to handle the blt
* this will cause blt to not return DDERR_WASSTILLDRAWING
*/
#define DDBLT_WAIT 0x01000000l
/*
* Uses the dwFillDepth field in the DDBLTFX structure as the depth value
* to fill the destination rectangle on the destination Z-buffer surface
* with.
*/
#define DDBLT_DEPTHFILL 0x02000000l
/****************************************************************************
*
* BLTFAST FLAGS
*
****************************************************************************/
#define DDBLTFAST_NOCOLORKEY 0x00000000
#define DDBLTFAST_SRCCOLORKEY 0x00000001
#define DDBLTFAST_DESTCOLORKEY 0x00000002
#define DDBLTFAST_WAIT 0x00000010
/****************************************************************************
*
* FLIP FLAGS
*
****************************************************************************/
#define DDFLIP_WAIT 0x00000001L
/*
* Indicates that the target surface contains the even field of video data.
* This flag is only valid with an overlay surface.
*/
#define DDFLIP_EVEN 0x00000002L
/*
* Indicates that the target surface contains the odd field of video data.
* This flag is only valid with an overlay surface.
*/
#define DDFLIP_ODD 0x00000004L
/*
* Causes DirectDraw to perform the physical flip immediately and return
* to the application. Typically, what was the front buffer but is now the back
* buffer will still be visible (depending on timing) until the next vertical
* retrace. Subsequent operations involving the two flipped surfaces will
* not check to see if the physical flip has finished (i.e. will not return
* DDERR_WASSTILLDRAWING for that reason (but may for other reasons)).
* This allows an application to perform Flips at a higher frequency than the
* monitor refresh rate, but may introduce visible artifacts.
* Only effective if DDCAPS2_FLIPNOVSYNC is set. If that bit is not set,
* DDFLIP_NOVSYNC has no effect.
*/
#define DDFLIP_NOVSYNC 0x00000008L
/*
* Flip Interval Flags. These flags indicate how many vertical retraces to wait between
* each flip. The default is one. DirectDraw will return DDERR_WASSTILLDRAWING for each
* surface involved in the flip until the specified number of vertical retraces has
* ocurred. Only effective if DDCAPS2_FLIPINTERVAL is set. If that bit is not set,
* DDFLIP_INTERVALn has no effect.
*/
/*
* DirectDraw will flip on every other vertical sync
*/
#define DDFLIP_INTERVAL2 0x02000000L
/*
* DirectDraw will flip on every third vertical sync
*/
#define DDFLIP_INTERVAL3 0x03000000L
/*
* DirectDraw will flip on every fourth vertical sync
*/
#define DDFLIP_INTERVAL4 0x04000000L
/****************************************************************************
*
* DIRECTDRAW SURFACE OVERLAY FLAGS
*
****************************************************************************/
/*
* Use the alpha information in the pixel format or the alpha channel surface
* attached to the destination surface as the alpha channel for the
* destination overlay.
*/
#define DDOVER_ALPHADEST 0x00000001l
/*
* Use the dwConstAlphaDest field in the DDOVERLAYFX structure as the
* destination alpha channel for this overlay.
*/
#define DDOVER_ALPHADESTCONSTOVERRIDE 0x00000002l
/*
* The NEG suffix indicates that the destination surface becomes more
* transparent as the alpha value increases.
*/
#define DDOVER_ALPHADESTNEG 0x00000004l
/*
* Use the lpDDSAlphaDest field in the DDOVERLAYFX structure as the alpha
* channel destination for this overlay.
*/
#define DDOVER_ALPHADESTSURFACEOVERRIDE 0x00000008l
/*
* Use the dwAlphaEdgeBlend field in the DDOVERLAYFX structure as the alpha
* channel for the edges of the image that border the color key colors.
*/
#define DDOVER_ALPHAEDGEBLEND 0x00000010l
/*
* Use the alpha information in the pixel format or the alpha channel surface
* attached to the source surface as the source alpha channel for this overlay.
*/
#define DDOVER_ALPHASRC 0x00000020l
/*
* Use the dwConstAlphaSrc field in the DDOVERLAYFX structure as the source
* alpha channel for this overlay.
*/
#define DDOVER_ALPHASRCCONSTOVERRIDE 0x00000040l
/*
* The NEG suffix indicates that the source surface becomes more transparent
* as the alpha value increases.
*/
#define DDOVER_ALPHASRCNEG 0x00000080l
/*
* Use the lpDDSAlphaSrc field in the DDOVERLAYFX structure as the alpha channel
* source for this overlay.
*/
#define DDOVER_ALPHASRCSURFACEOVERRIDE 0x00000100l
/*
* Turn this overlay off.
*/
#define DDOVER_HIDE 0x00000200l
/*
* Use the color key associated with the destination surface.
*/
#define DDOVER_KEYDEST 0x00000400l
/*
* Use the dckDestColorkey field in the DDOVERLAYFX structure as the color key
* for the destination surface
*/
#define DDOVER_KEYDESTOVERRIDE 0x00000800l
/*
* Use the color key associated with the source surface.
*/
#define DDOVER_KEYSRC 0x00001000l
/*
* Use the dckSrcColorkey field in the DDOVERLAYFX structure as the color key
* for the source surface.
*/
#define DDOVER_KEYSRCOVERRIDE 0x00002000l
/*
* Turn this overlay on.
*/
#define DDOVER_SHOW 0x00004000l
/*
* Add a dirty rect to an emulated overlayed surface.
*/
#define DDOVER_ADDDIRTYRECT 0x00008000l
/*
* Redraw all dirty rects on an emulated overlayed surface.
*/
#define DDOVER_REFRESHDIRTYRECTS 0x00010000l
/*
* Redraw the entire surface on an emulated overlayed surface.
*/
#define DDOVER_REFRESHALL 0x00020000l
/*
* Use the overlay FX flags to define special overlay FX
*/
#define DDOVER_DDFX 0x00080000l
/*
* Autoflip the overlay when ever the video port autoflips
*/
#define DDOVER_AUTOFLIP 0x00100000l
/*
* Display each field of video port data individually without
* causing any jittery artifacts
*/
#define DDOVER_BOB 0x00200000l
/*
* Indicates that bob/weave decisions should not be overridden by other
* interfaces.
*/
#define DDOVER_OVERRIDEBOBWEAVE 0x00400000l
/*
* Indicates that the surface memory is composed of interleaved fields.
*/
#define DDOVER_INTERLEAVED 0x00800000l
/*
* Indicates that bob will be performed using hardware rather than
* software or emulated.
*/
#define DDOVER_BOBHARDWARE 0x01000000l
/****************************************************************************
*
* DIRECTDRAWSURFACE LOCK FLAGS
*
****************************************************************************/
/*
* The default. Set to indicate that Lock should return a valid memory pointer
* to the top of the specified rectangle. If no rectangle is specified then a
* pointer to the top of the surface is returned.
*/
#define DDLOCK_SURFACEMEMORYPTR 0x00000000L // default
/*
* Set to indicate that Lock should wait until it can obtain a valid memory
* pointer before returning. If this bit is set, Lock will never return
* DDERR_WASSTILLDRAWING.
*/
#define DDLOCK_WAIT 0x00000001L
/*
* Set if an event handle is being passed to Lock. Lock will trigger the event
* when it can return the surface memory pointer requested.
*/
#define DDLOCK_EVENT 0x00000002L
/*
* Indicates that the surface being locked will only be read from.
*/
#define DDLOCK_READONLY 0x00000010L
/*
* Indicates that the surface being locked will only be written to
*/
#define DDLOCK_WRITEONLY 0x00000020L
/*
* Indicates that a system wide lock should not be taken when this surface
* is locked. This has several advantages (cursor responsiveness, ability
* to call more Windows functions, easier debugging) when locking video
* memory surfaces. However, an application specifying this flag must
* comply with a number of conditions documented in the help file.
* Furthermore, this flag cannot be specified when locking the primary.
*/
#define DDLOCK_NOSYSLOCK 0x00000800L
/****************************************************************************
*
* DIRECTDRAWSURFACE PAGELOCK FLAGS
*
****************************************************************************/
/*
* No flags defined at present
*/
/****************************************************************************
*
* DIRECTDRAWSURFACE PAGEUNLOCK FLAGS
*
****************************************************************************/
/*
* No flags defined at present
*/
/****************************************************************************
*
* DIRECTDRAWSURFACE BLT FX FLAGS
*
****************************************************************************/
/*
* If stretching, use arithmetic stretching along the Y axis for this blt.
*/
#define DDBLTFX_ARITHSTRETCHY 0x00000001l
/*
* Do this blt mirroring the surface left to right. Spin the
* surface around its y-axis.
*/
#define DDBLTFX_MIRRORLEFTRIGHT 0x00000002l
/*
* Do this blt mirroring the surface up and down. Spin the surface
* around its x-axis.
*/
#define DDBLTFX_MIRRORUPDOWN 0x00000004l
/*
* Schedule this blt to avoid tearing.
*/
#define DDBLTFX_NOTEARING 0x00000008l
/*
* Do this blt rotating the surface one hundred and eighty degrees.
*/
#define DDBLTFX_ROTATE180 0x00000010l
/*
* Do this blt rotating the surface two hundred and seventy degrees.
*/
#define DDBLTFX_ROTATE270 0x00000020l
/*
* Do this blt rotating the surface ninety degrees.
*/
#define DDBLTFX_ROTATE90 0x00000040l
/*
* Do this z blt using dwZBufferLow and dwZBufferHigh as range values
* specified to limit the bits copied from the source surface.
*/
#define DDBLTFX_ZBUFFERRANGE 0x00000080l
/*
* Do this z blt adding the dwZBufferBaseDest to each of the sources z values
* before comparing it with the desting z values.
*/
#define DDBLTFX_ZBUFFERBASEDEST 0x00000100l
/****************************************************************************
*
* DIRECTDRAWSURFACE OVERLAY FX FLAGS
*
****************************************************************************/
/*
* If stretching, use arithmetic stretching along the Y axis for this overlay.
*/
#define DDOVERFX_ARITHSTRETCHY 0x00000001l
/*
* Mirror the overlay across the vertical axis
*/
#define DDOVERFX_MIRRORLEFTRIGHT 0x00000002l
/*
* Mirror the overlay across the horizontal axis
*/
#define DDOVERFX_MIRRORUPDOWN 0x00000004l
/****************************************************************************
*
* Flags for dwDDFX member of DDSPRITEFX structure
*
****************************************************************************/
/*
* Use affine transformation matrix in fTransform member.
*/
#define DDSPRITEFX_AFFINETRANSFORM 0x00000001l
/*
* Use RGBA scaling factors in ddrgbaScaleFactors member.
*/
#define DDSPRITEFX_RGBASCALING 0x00000002l
/*
* Degrade RGBA scaling factors to accommodate driver's capabilities.
*/
#define DDSPRITEFX_DEGRADERGBASCALING 0x00000004l
/*
* Do bilinear filtering of stretched or warped sprite.
*/
#define DDSPRITEFX_BILINEARFILTER 0x00000008l
/*
* Do "blur" filtering of stretched or warped sprite.
*/
#define DDSPRITEFX_BLURFILTER 0x00000010l
/*
* Do "flat" filtering of stretched or warped sprite.
*/
#define DDSPRITEFX_FLATFILTER 0x00000020l
/*
* Degrade filtering operation to accommodate driver's capabilities.
*/
#define DDSPRITEFX_DEGRADEFILTER 0x00000040l
/****************************************************************************
*
* DIRECTDRAW WAITFORVERTICALBLANK FLAGS
*
****************************************************************************/
/*
* return when the vertical blank interval begins
*/
#define DDWAITVB_BLOCKBEGIN 0x00000001l
/*
* set up an event to trigger when the vertical blank begins
*/
#define DDWAITVB_BLOCKBEGINEVENT 0x00000002l
/*
* return when the vertical blank interval ends and display begins
*/
#define DDWAITVB_BLOCKEND 0x00000004l
/****************************************************************************
*
* DIRECTDRAW GETFLIPSTATUS FLAGS
*
****************************************************************************/
/*
* is it OK to flip now?
*/
#define DDGFS_CANFLIP 0x00000001l
/*
* is the last flip finished?
*/
#define DDGFS_ISFLIPDONE 0x00000002l
/****************************************************************************
*
* DIRECTDRAW GETBLTSTATUS FLAGS
*
****************************************************************************/
/*
* is it OK to blt now?
*/
#define DDGBS_CANBLT 0x00000001l
/*
* is the blt to the surface finished?
*/
#define DDGBS_ISBLTDONE 0x00000002l
/****************************************************************************
*
* DIRECTDRAW ENUMOVERLAYZORDER FLAGS
*
****************************************************************************/
/*
* Enumerate overlays back to front.
*/
#define DDENUMOVERLAYZ_BACKTOFRONT 0x00000000l
/*
* Enumerate overlays front to back
*/
#define DDENUMOVERLAYZ_FRONTTOBACK 0x00000001l
/****************************************************************************
*
* DIRECTDRAW UPDATEOVERLAYZORDER FLAGS
*
****************************************************************************/
/*
* Send overlay to front
*/
#define DDOVERZ_SENDTOFRONT 0x00000000l
/*
* Send overlay to back
*/
#define DDOVERZ_SENDTOBACK 0x00000001l
/*
* Move Overlay forward
*/
#define DDOVERZ_MOVEFORWARD 0x00000002l
/*
* Move Overlay backward
*/
#define DDOVERZ_MOVEBACKWARD 0x00000003l
/*
* Move Overlay in front of relative surface
*/
#define DDOVERZ_INSERTINFRONTOF 0x00000004l
/*
* Move Overlay in back of relative surface
*/
#define DDOVERZ_INSERTINBACKOF 0x00000005l
/****************************************************************************
*
* DIRECTDRAW SETGAMMARAMP FLAGS
*
****************************************************************************/
/*
* Request calibrator to adjust the gamma ramp according to the physical
* properties of the display so that the result should appear identical
* on all systems.
*/
#define DDSGR_CALIBRATE 0x00000001L
/*===========================================================================
*
*
* DIRECTDRAW RETURN CODES
*
* The return values from DirectDraw Commands and Surface that return an HRESULT
* are codes from DirectDraw concerning the results of the action
* requested by DirectDraw.
*
*==========================================================================*/
/*
* Status is OK
*
* Issued by: DirectDraw Commands and all callbacks
*/
#define DD_OK 0
#define DD_FALSE S_FALSE
/****************************************************************************
*
* DIRECTDRAW ENUMCALLBACK RETURN VALUES
*
* EnumCallback returns are used to control the flow of the DIRECTDRAW and
* DIRECTDRAWSURFACE object enumerations. They can only be returned by
* enumeration callback routines.
*
****************************************************************************/
/*
* stop the enumeration
*/
#define DDENUMRET_CANCEL 0
/*
* continue the enumeration
*/
#define DDENUMRET_OK 1
/****************************************************************************
*
* DIRECTDRAW ERRORS
*
* Errors are represented by negative values and cannot be combined.
*
****************************************************************************/
/*
* This object is already initialized
*/
#define DDERR_ALREADYINITIALIZED MAKE_DDHRESULT(5)
/*
* This surface can not be attached to the requested surface.
*/
#define DDERR_CANNOTATTACHSURFACE MAKE_DDHRESULT(10)
/*
* This surface can not be detached from the requested surface.
*/
#define DDERR_CANNOTDETACHSURFACE MAKE_DDHRESULT(20)
/*
* Support is currently not available.
*/
#define DDERR_CURRENTLYNOTAVAIL MAKE_DDHRESULT(40)
/*
* An exception was encountered while performing the requested operation
*/
#define DDERR_EXCEPTION MAKE_DDHRESULT(55)
/*
* Generic failure.
*/
#define DDERR_GENERIC E_FAIL
/*
* Height of rectangle provided is not a multiple of reqd alignment
*/
#define DDERR_HEIGHTALIGN MAKE_DDHRESULT(90)
/*
* Unable to match primary surface creation request with existing
* primary surface.
*/
#define DDERR_INCOMPATIBLEPRIMARY MAKE_DDHRESULT(95)
/*
* One or more of the caps bits passed to the callback are incorrect.
*/
#define DDERR_INVALIDCAPS MAKE_DDHRESULT(100)
/*
* DirectDraw does not support provided Cliplist.
*/
#define DDERR_INVALIDCLIPLIST MAKE_DDHRESULT(110)
/*
* DirectDraw does not support the requested mode
*/
#define DDERR_INVALIDMODE MAKE_DDHRESULT(120)
/*
* DirectDraw received a pointer that was an invalid DIRECTDRAW object.
*/
#define DDERR_INVALIDOBJECT MAKE_DDHRESULT(130)
/*
* One or more of the parameters passed to the callback function are
* incorrect.
*/
#define DDERR_INVALIDPARAMS E_INVALIDARG
/*
* pixel format was invalid as specified
*/
#define DDERR_INVALIDPIXELFORMAT MAKE_DDHRESULT(145)
/*
* Rectangle provided was invalid.
*/
#define DDERR_INVALIDRECT MAKE_DDHRESULT(150)
/*
* Operation could not be carried out because one or more surfaces are locked
*/
#define DDERR_LOCKEDSURFACES MAKE_DDHRESULT(160)
/*
* There is no 3D present.
*/
#define DDERR_NO3D MAKE_DDHRESULT(170)
/*
* Operation could not be carried out because there is no alpha accleration
* hardware present or available.
*/
#define DDERR_NOALPHAHW MAKE_DDHRESULT(180)
/*
* no clip list available
*/
#define DDERR_NOCLIPLIST MAKE_DDHRESULT(205)
/*
* Operation could not be carried out because there is no color conversion
* hardware present or available.
*/
#define DDERR_NOCOLORCONVHW MAKE_DDHRESULT(210)
/*
* Create function called without DirectDraw object method SetCooperativeLevel
* being called.
*/
#define DDERR_NOCOOPERATIVELEVELSET MAKE_DDHRESULT(212)
/*
* Surface doesn't currently have a color key
*/
#define DDERR_NOCOLORKEY MAKE_DDHRESULT(215)
/*
* Operation could not be carried out because there is no hardware support
* of the dest color key.
*/
#define DDERR_NOCOLORKEYHW MAKE_DDHRESULT(220)
/*
* No DirectDraw support possible with current display driver
*/
#define DDERR_NODIRECTDRAWSUPPORT MAKE_DDHRESULT(222)
/*
* Operation requires the application to have exclusive mode but the
* application does not have exclusive mode.
*/
#define DDERR_NOEXCLUSIVEMODE MAKE_DDHRESULT(225)
/*
* Flipping visible surfaces is not supported.
*/
#define DDERR_NOFLIPHW MAKE_DDHRESULT(230)
/*
* There is no GDI present.
*/
#define DDERR_NOGDI MAKE_DDHRESULT(240)
/*
* Operation could not be carried out because there is no hardware present
* or available.
*/
#define DDERR_NOMIRRORHW MAKE_DDHRESULT(250)
/*
* Requested item was not found
*/
#define DDERR_NOTFOUND MAKE_DDHRESULT(255)
/*
* Operation could not be carried out because there is no overlay hardware
* present or available.
*/
#define DDERR_NOOVERLAYHW MAKE_DDHRESULT(260)
/*
* Operation could not be carried out because the source and destination
* rectangles are on the same surface and overlap each other.
*/
#define DDERR_OVERLAPPINGRECTS MAKE_DDHRESULT(270)
/*
* Operation could not be carried out because there is no appropriate raster
* op hardware present or available.
*/
#define DDERR_NORASTEROPHW MAKE_DDHRESULT(280)
/*
* Operation could not be carried out because there is no rotation hardware
* present or available.
*/
#define DDERR_NOROTATIONHW MAKE_DDHRESULT(290)
/*
* Operation could not be carried out because there is no hardware support
* for stretching
*/
#define DDERR_NOSTRETCHHW MAKE_DDHRESULT(310)
/*
* DirectDrawSurface is not in 4 bit color palette and the requested operation
* requires 4 bit color palette.
*/
#define DDERR_NOT4BITCOLOR MAKE_DDHRESULT(316)
/*
* DirectDrawSurface is not in 4 bit color index palette and the requested
* operation requires 4 bit color index palette.
*/
#define DDERR_NOT4BITCOLORINDEX MAKE_DDHRESULT(317)
/*
* DirectDraw Surface is not in 8 bit color mode and the requested operation
* requires 8 bit color.
*/
#define DDERR_NOT8BITCOLOR MAKE_DDHRESULT(320)
/*
* Operation could not be carried out because there is no texture mapping
* hardware present or available.
*/
#define DDERR_NOTEXTUREHW MAKE_DDHRESULT(330)
/*
* Operation could not be carried out because there is no hardware support
* for vertical blank synchronized operations.
*/
#define DDERR_NOVSYNCHW MAKE_DDHRESULT(335)
/*
* Operation could not be carried out because there is no hardware support
* for zbuffer blting.
*/
#define DDERR_NOZBUFFERHW MAKE_DDHRESULT(340)
/*
* Overlay surfaces could not be z layered based on their BltOrder because
* the hardware does not support z layering of overlays.
*/
#define DDERR_NOZOVERLAYHW MAKE_DDHRESULT(350)
/*
* The hardware needed for the requested operation has already been
* allocated.
*/
#define DDERR_OUTOFCAPS MAKE_DDHRESULT(360)
/*
* DirectDraw does not have enough memory to perform the operation.
*/
#define DDERR_OUTOFMEMORY E_OUTOFMEMORY
/*
* DirectDraw does not have enough memory to perform the operation.
*/
#define DDERR_OUTOFVIDEOMEMORY MAKE_DDHRESULT(380)
/*
* hardware does not support clipped overlays
*/
#define DDERR_OVERLAYCANTCLIP MAKE_DDHRESULT(382)
/*
* Can only have ony color key active at one time for overlays
*/
#define DDERR_OVERLAYCOLORKEYONLYONEACTIVE MAKE_DDHRESULT(384)
/*
* Access to this palette is being refused because the palette is already
* locked by another thread.
*/
#define DDERR_PALETTEBUSY MAKE_DDHRESULT(387)
/*
* No src color key specified for this operation.
*/
#define DDERR_COLORKEYNOTSET MAKE_DDHRESULT(400)
/*
* This surface is already attached to the surface it is being attached to.
*/
#define DDERR_SURFACEALREADYATTACHED MAKE_DDHRESULT(410)
/*
* This surface is already a dependency of the surface it is being made a
* dependency of.
*/
#define DDERR_SURFACEALREADYDEPENDENT MAKE_DDHRESULT(420)
/*
* Access to this surface is being refused because the surface is already
* locked by another thread.
*/
#define DDERR_SURFACEBUSY MAKE_DDHRESULT(430)
/*
* Access to this surface is being refused because no driver exists
* which can supply a pointer to the surface.
* This is most likely to happen when attempting to lock the primary
* surface when no DCI provider is present.
* Will also happen on attempts to lock an optimized surface.
*/
#define DDERR_CANTLOCKSURFACE MAKE_DDHRESULT(435)
/*
* Access to Surface refused because Surface is obscured.
*/
#define DDERR_SURFACEISOBSCURED MAKE_DDHRESULT(440)
/*
* Access to this surface is being refused because the surface is gone.
* The DIRECTDRAWSURFACE object representing this surface should
* have Restore called on it.
*/
#define DDERR_SURFACELOST MAKE_DDHRESULT(450)
/*
* The requested surface is not attached.
*/
#define DDERR_SURFACENOTATTACHED MAKE_DDHRESULT(460)
/*
* Height requested by DirectDraw is too large.
*/
#define DDERR_TOOBIGHEIGHT MAKE_DDHRESULT(470)
/*
* Size requested by DirectDraw is too large -- The individual height and
* width are OK.
*/
#define DDERR_TOOBIGSIZE MAKE_DDHRESULT(480)
/*
* Width requested by DirectDraw is too large.
*/
#define DDERR_TOOBIGWIDTH MAKE_DDHRESULT(490)
/*
* Action not supported.
*/
#define DDERR_UNSUPPORTED E_NOTIMPL
/*
* FOURCC format requested is unsupported by DirectDraw
*/
#define DDERR_UNSUPPORTEDFORMAT MAKE_DDHRESULT(510)
/*
* Bitmask in the pixel format requested is unsupported by DirectDraw
*/
#define DDERR_UNSUPPORTEDMASK MAKE_DDHRESULT(520)
/*
* The specified stream contains invalid data
*/
#define DDERR_INVALIDSTREAM MAKE_DDHRESULT(521)
/*
* vertical blank is in progress
*/
#define DDERR_VERTICALBLANKINPROGRESS MAKE_DDHRESULT(537)
/*
* Informs DirectDraw that the previous Blt which is transfering information
* to or from this Surface is incomplete.
*/
#define DDERR_WASSTILLDRAWING MAKE_DDHRESULT(540)
/*
* Rectangle provided was not horizontally aligned on reqd. boundary
*/
#define DDERR_XALIGN MAKE_DDHRESULT(560)
/*
* The GUID passed to DirectDrawCreate is not a valid DirectDraw driver
* identifier.
*/
#define DDERR_INVALIDDIRECTDRAWGUID MAKE_DDHRESULT(561)
/*
* A DirectDraw object representing this driver has already been created
* for this process.
*/
#define DDERR_DIRECTDRAWALREADYCREATED MAKE_DDHRESULT(562)
/*
* A hardware only DirectDraw object creation was attempted but the driver
* did not support any hardware.
*/
#define DDERR_NODIRECTDRAWHW MAKE_DDHRESULT(563)
/*
* this process already has created a primary surface
*/
#define DDERR_PRIMARYSURFACEALREADYEXISTS MAKE_DDHRESULT(564)
/*
* software emulation not available.
*/
#define DDERR_NOEMULATION MAKE_DDHRESULT(565)
/*
* region passed to Clipper::GetClipList is too small.
*/
#define DDERR_REGIONTOOSMALL MAKE_DDHRESULT(566)
/*
* an attempt was made to set a clip list for a clipper objec that
* is already monitoring an hwnd.
*/
#define DDERR_CLIPPERISUSINGHWND MAKE_DDHRESULT(567)
/*
* No clipper object attached to surface object
*/
#define DDERR_NOCLIPPERATTACHED MAKE_DDHRESULT(568)
/*
* Clipper notification requires an HWND or
* no HWND has previously been set as the CooperativeLevel HWND.
*/
#define DDERR_NOHWND MAKE_DDHRESULT(569)
/*
* HWND used by DirectDraw CooperativeLevel has been subclassed,
* this prevents DirectDraw from restoring state.
*/
#define DDERR_HWNDSUBCLASSED MAKE_DDHRESULT(570)
/*
* The CooperativeLevel HWND has already been set.
* It can not be reset while the process has surfaces or palettes created.
*/
#define DDERR_HWNDALREADYSET MAKE_DDHRESULT(571)
/*
* No palette object attached to this surface.
*/
#define DDERR_NOPALETTEATTACHED MAKE_DDHRESULT(572)
/*
* No hardware support for 16 or 256 color palettes.
*/
#define DDERR_NOPALETTEHW MAKE_DDHRESULT(573)
/*
* If a clipper object is attached to the source surface passed into a
* BltFast call.
*/
#define DDERR_BLTFASTCANTCLIP MAKE_DDHRESULT(574)
/*
* No blter.
*/
#define DDERR_NOBLTHW MAKE_DDHRESULT(575)
/*
* No DirectDraw ROP hardware.
*/
#define DDERR_NODDROPSHW MAKE_DDHRESULT(576)
/*
* returned when GetOverlayPosition is called on a hidden overlay
*/
#define DDERR_OVERLAYNOTVISIBLE MAKE_DDHRESULT(577)
/*
* returned when GetOverlayPosition is called on a overlay that UpdateOverlay
* has never been called on to establish a destionation.
*/
#define DDERR_NOOVERLAYDEST MAKE_DDHRESULT(578)
/*
* returned when the position of the overlay on the destionation is no longer
* legal for that destionation.
*/
#define DDERR_INVALIDPOSITION MAKE_DDHRESULT(579)
/*
* returned when an overlay member is called for a non-overlay surface
*/
#define DDERR_NOTAOVERLAYSURFACE MAKE_DDHRESULT(580)
/*
* An attempt was made to set the cooperative level when it was already
* set to exclusive.
*/
#define DDERR_EXCLUSIVEMODEALREADYSET MAKE_DDHRESULT(581)
/*
* An attempt has been made to flip a surface that is not flippable.
*/
#define DDERR_NOTFLIPPABLE MAKE_DDHRESULT(582)
/*
* Can't duplicate primary & 3D surfaces, or surfaces that are implicitly
* created.
*/
#define DDERR_CANTDUPLICATE MAKE_DDHRESULT(583)
/*
* Surface was not locked. An attempt to unlock a surface that was not
* locked at all, or by this process, has been attempted.
*/
#define DDERR_NOTLOCKED MAKE_DDHRESULT(584)
/*
* Windows can not create any more DCs, or a DC was requested for a paltte-indexed
* surface when the surface had no palette AND the display mode was not palette-indexed
* (in this case DirectDraw cannot select a proper palette into the DC)
*/
#define DDERR_CANTCREATEDC MAKE_DDHRESULT(585)
/*
* No DC was ever created for this surface.
*/
#define DDERR_NODC MAKE_DDHRESULT(586)
/*
* This surface can not be restored because it was created in a different
* mode.
*/
#define DDERR_WRONGMODE MAKE_DDHRESULT(587)
/*
* This surface can not be restored because it is an implicitly created
* surface.
*/
#define DDERR_IMPLICITLYCREATED MAKE_DDHRESULT(588)
/*
* The surface being used is not a palette-based surface
*/
#define DDERR_NOTPALETTIZED MAKE_DDHRESULT(589)
/*
* The display is currently in an unsupported mode
*/
#define DDERR_UNSUPPORTEDMODE MAKE_DDHRESULT(590)
/*
* Operation could not be carried out because there is no mip-map
* texture mapping hardware present or available.
*/
#define DDERR_NOMIPMAPHW MAKE_DDHRESULT(591)
/*
* The requested action could not be performed because the surface was of
* the wrong type.
*/
#define DDERR_INVALIDSURFACETYPE MAKE_DDHRESULT(592)
/*
* Device does not support optimized surfaces, therefore no video memory optimized surfaces
*/
#define DDERR_NOOPTIMIZEHW MAKE_DDHRESULT(600)
/*
* Surface is an optimized surface, but has not yet been allocated any memory
*/
#define DDERR_NOTLOADED MAKE_DDHRESULT(601)
/*
* Attempt was made to create or set a device window without first setting
* the focus window
*/
#define DDERR_NOFOCUSWINDOW MAKE_DDHRESULT(602)
/*
* A DC has already been returned for this surface. Only one DC can be
* retrieved per surface.
*/
#define DDERR_DCALREADYCREATED MAKE_DDHRESULT(620)
/*
* An attempt was made to allocate non-local video memory from a device
* that does not support non-local video memory.
*/
#define DDERR_NONONLOCALVIDMEM MAKE_DDHRESULT(630)
/*
* The attempt to page lock a surface failed.
*/
#define DDERR_CANTPAGELOCK MAKE_DDHRESULT(640)
/*
* The attempt to page unlock a surface failed.
*/
#define DDERR_CANTPAGEUNLOCK MAKE_DDHRESULT(660)
/*
* An attempt was made to page unlock a surface with no outstanding page locks.
*/
#define DDERR_NOTPAGELOCKED MAKE_DDHRESULT(680)
/*
* There is more data available than the specified buffer size could hold
*/
#define DDERR_MOREDATA MAKE_DDHRESULT(690)
/*
* The data has expired and is therefore no longer valid.
*/
#define DDERR_EXPIRED MAKE_DDHRESULT(691)
/*
* The video port is not active
*/
#define DDERR_VIDEONOTACTIVE MAKE_DDHRESULT(695)
/*
* Surfaces created by one direct draw device cannot be used directly by
* another direct draw device.
*/
#define DDERR_DEVICEDOESNTOWNSURFACE MAKE_DDHRESULT(699)
/*
* An attempt was made to invoke an interface member of a DirectDraw object
* created by CoCreateInstance() before it was initialized.
*/
#define DDERR_NOTINITIALIZED CO_E_NOTINITIALIZED
/* Alpha bit depth constants */
#ifdef __cplusplus
};
#endif
#endif