diff options
author | Volker Grabsch <vog@notjusthosting.com> | 2010-04-13 01:33:28 (GMT) |
---|---|---|
committer | Volker Grabsch <vog@notjusthosting.com> | 2010-04-13 01:33:28 (GMT) |
commit | 3ce2cad4a4cd30823d31b41b2d1c1a236c9e030b (patch) | |
tree | 4cc67295795493b026a544da11e215538c11d567 /src/w32api-2-directx-additions-for-qt.patch | |
parent | d7b4c431c4d513ad27f6ab6db9e8047d789b64f3 (diff) | |
parent | a5e3cd030821fe807f8545eeb595445f670ba0f9 (diff) | |
download | mxe-3ce2cad4a4cd30823d31b41b2d1c1a236c9e030b.zip mxe-3ce2cad4a4cd30823d31b41b2d1c1a236c9e030b.tar.gz mxe-3ce2cad4a4cd30823d31b41b2d1c1a236c9e030b.tar.bz2 |
merge
Diffstat (limited to 'src/w32api-2-directx-additions-for-qt.patch')
-rw-r--r-- | src/w32api-2-directx-additions-for-qt.patch | 1297 |
1 files changed, 1297 insertions, 0 deletions
diff --git a/src/w32api-2-directx-additions-for-qt.patch b/src/w32api-2-directx-additions-for-qt.patch new file mode 100644 index 0000000..cf3f8fb --- /dev/null +++ b/src/w32api-2-directx-additions-for-qt.patch @@ -0,0 +1,1297 @@ +This file is part of mingw-cross-env. +See doc/index.html for further information. + +This patch contains some DirectX additions for MinGW's w32api +which were provided by the Qt project. It was generated via +the following commands: + +#--------------------------------------------------------------------# +wget -c 'http://kent.dl.sourceforge.net/project/mingw/MinGW API for MS-Windows/w32api-3.13/w32api-3.13-mingw32-dev.tar.gz' +wget -c 'http://download.qt.nokia.com/misc/MinGW-gcc440_1.zip' +mkdir a +(cd a; tar -xf ../w32api-3.13-mingw32-dev.tar.gz include) +cp -r a b +unzip -j MinGW-gcc440_1.zip 'mingw/_patches/include.zip' +unzip -aa -p include.zip '*.patch' | patch -d b/include -p1 +(cd b/include; unzip -aa ../../include.zip '*.h') +diff -ruN a b > w32api-2-directx-additions-for-qt.patch +rm -rf a b include.zip +rm -f w32api-3.13-mingw32-dev.tar.gz MinGW-gcc440_1.zip +#--------------------------------------------------------------------# + + +diff -ruN a/include/amvideo.h b/include/amvideo.h +--- a/include/amvideo.h 2008-12-06 03:31:53.000000000 +0100 ++++ b/include/amvideo.h 2010-04-12 17:12:52.000000000 +0200 +@@ -52,10 +52,10 @@ + BITMAPINFOHEADER bmiHeader; + } VIDEOINFOHEADER; + typedef struct tagVIDEOINFO { +- RECT rcSource, +- RECT rcTarget, +- DWORD dwBitRate, +- DWORD dwBitErrorRate, ++ RECT rcSource; ++ RECT rcTarget; ++ DWORD dwBitRate; ++ DWORD dwBitErrorRate; + REFERENCE_TIME AvgTimePerFrame; + BITMAPINFOHEADER bmiHeader; + union { +diff -ruN a/include/bdatypes.h b/include/bdatypes.h +--- a/include/bdatypes.h 2008-12-06 03:31:53.000000000 +0100 ++++ b/include/bdatypes.h 2010-04-12 17:12:52.000000000 +0200 +@@ -17,9 +17,9 @@ + } MEDIA_SAMPLE_CONTENT; + /*--- DirectShow Reference - DirectShow Structures */ + typedef struct { +- DWORD dwOffset +- DWORD dwPacketLength +- DWORD dwStride ++ DWORD dwOffset; ++ DWORD dwPacketLength; ++ DWORD dwStride; + } MPEG2_TRANSPORT_STRIDE; + typedef struct { + ULONG ulPID; +diff -ruN a/include/control.h b/include/control.h +--- a/include/control.h 2008-12-06 03:31:54.000000000 +0100 ++++ b/include/control.h 2010-04-12 17:12:52.000000000 +0200 +@@ -11,7 +11,63 @@ + /*--- DirectShow Reference - DirectShow Data Types */ + typedef LONG_PTR OAEVENT; + typedef LONG_PTR OAHWND; ++typedef LONG OAFilterState; + ++DEFINE_GUID(IID_IBasicAudio,0x56a868b3,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70); ++DEFINE_GUID(IID_IMediaControl,0x56a868b1,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70); ++DEFINE_GUID(IID_IMediaEvent,0x56a868b6,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70); ++DEFINE_GUID(IID_IMediaPosition,0x56a868b2,0x0ad4,0x11ce,0xb0,0x3a,0x00,0x20,0xaf,0x0b,0xa7,0x70); ++ ++#define INTERFACE IMediaControl ++DECLARE_INTERFACE_(IMediaControl, IDispatch) ++{ ++ STDMETHOD(Run)(THIS) PURE; ++ STDMETHOD(Pause)(THIS) PURE; ++ STDMETHOD(Stop)(THIS) PURE; ++ STDMETHOD(GetState)(THIS_ LONG, OAFilterState *) PURE; ++ STDMETHOD(RenderFile)(THIS_ BSTR) PURE; ++ STDMETHOD(AddSourceFilter)(THIS_ BSTR, IDispatch **) PURE; ++ STDMETHOD(get_FilterCollection)(THIS_ IDispatch **) PURE; ++ STDMETHOD(get_RegFilterCollection)(IDispatch **) PURE; ++ STDMETHOD(StopWhenReady)(THIS) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IBasicAudio ++DECLARE_INTERFACE_(IBasicAudio, IDispatch) ++{ ++ STDMETHOD(put_Volume)(THIS_ long) PURE; ++ STDMETHOD(get_Volume)(THIS_ long *) PURE; ++ STDMETHOD(put_Balance)(THIS_ long) PURE; ++ STDMETHOD(get_Balance)(THIS_ long *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaPosition ++DECLARE_INTERFACE_(IMediaPosition, IDispatch) ++{ ++ STDMETHOD(get_Duration)(THIS_ REFTIME *) PURE; ++ STDMETHOD(put_CurrentPosition)(THIS_ REFTIME) PURE; ++ STDMETHOD(get_CurrentPosition)(THIS_ REFTIME *) PURE; ++ STDMETHOD(get_StopTime)(THIS_ REFTIME *) PURE; ++ STDMETHOD(put_StopTime)(THIS_ REFTIME) PURE; ++ STDMETHOD(get_PrerollTime)(THIS_ REFTIME *) PURE; ++ STDMETHOD(put_PrerollTime)(THIS_ REFTIME) PURE; ++ STDMETHOD(put_Rate)(THIS_ double) PURE; ++ STDMETHOD(get_Rate)(THIS_ double *) PURE; ++ STDMETHOD(CanSeekForward)(THIS_ LONG *) PURE; ++ STDMETHOD(CanSeekBackward)(THIS_ LONG *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaEvent ++DECLARE_INTERFACE_(IMediaEvent, IDispatch) ++{ ++ STDMETHOD(GetEventHandle)(THIS_ OAEVENT *) PURE; ++ STDMETHOD(GetEvent)(THIS_ long *, LONG_PTR *, LONG_PTR *, long) PURE; ++ STDMETHOD(WaitForCompletion)(THIS_ long,long *) PURE; ++ STDMETHOD(CancelDefaultHandling)(THIS_ long) PURE; ++ STDMETHOD(RestoreDefaultHandling)(THIS_ long) PURE; ++ STDMETHOD(FreeEventParams)(THIS_ long, LONG_PTR, LONG_PTR) PURE; ++}; ++#undef INTERFACE + #ifdef __cplusplus + } + #endif +diff -ruN a/include/ddraw.h b/include/ddraw.h +--- a/include/ddraw.h 1970-01-01 01:00:00.000000000 +0100 ++++ b/include/ddraw.h 2009-03-09 15:37:42.000000000 +0100 +@@ -0,0 +1,344 @@ ++#ifndef _DDRAW_H ++#define _DDRAW_H ++ ++#if __GNUC__ >= 3 ++#pragma GCC system_header ++#endif ++ ++#include <objbase.h> ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++/* interfaces */ ++DECLARE_INTERFACE(IDirectDraw); ++DECLARE_INTERFACE(IDirectDrawClipper); ++DECLARE_INTERFACE(IDirectDrawPalette); ++DECLARE_INTERFACE(IDirectDrawSurface); ++typedef IDirectDraw* LPDIRECTDRAW; ++typedef IDirectDrawClipper* LPDIRECTDRAWCLIPPER; ++typedef IDirectDrawPalette* LPDIRECTDRAWPALETTE; ++typedef IDirectDrawSurface* LPDIRECTDRAWSURFACE; ++ ++ ++#define DD_ROP_SPACE (256/32) ++ ++/* struct */ ++typedef struct { ++ DWORD dwColorSpaceLowValue; ++ DWORD dwColorSpaceHighValue; ++} DDCOLORKEY, *LPDDCOLORKEY; ++ ++typedef struct { ++ DWORD dwSize; ++ DWORD dwDDFX; ++ DWORD dwROP; ++ DWORD dwDDROP; ++ DWORD dwRotationAngle; ++ DWORD dwZBufferOpCode; ++ DWORD dwZBufferLow; ++ DWORD dwZBufferHigh; ++ DWORD dwZBufferBaseDest; ++ DWORD dwZDestConstBitDepth; ++ union { ++ DWORD dwZDestConst; ++ LPDIRECTDRAWSURFACE lpDDSZBufferDest; ++ }; ++ DWORD dwZSrcConstBitDepth; ++ union { ++ DWORD dwZSrcConst; ++ LPDIRECTDRAWSURFACE lpDDSZBufferSrc; ++ }; ++ DWORD dwAlphaEdgeBlendBitDepth; ++ DWORD dwAlphaEdgeBlend; ++ DWORD dwReserved; ++ DWORD dwAlphaDestConstBitDepth; ++ union { ++ DWORD dwAlphaDestConst; ++ LPDIRECTDRAWSURFACE lpDDSAlphaDest; ++ }; ++ DWORD dwAlphaSrcConstBitDepth; ++ union { ++ DWORD dwAlphaSrcConst; ++ LPDIRECTDRAWSURFACE lpDDSAlphaSrc; ++ }; ++ union { ++ DWORD dwFillColor; ++ DWORD dwFillDepth; ++ DWORD dwFillPixel; ++ LPDIRECTDRAWSURFACE lpDDSPattern; ++ }; ++ DDCOLORKEY ddckDestColorkey; ++ DDCOLORKEY ddckSrcColorkey; ++} DDBLTFX, *LPDDBLTFX; ++ ++typedef struct { ++ LPRECT lprDest; ++ LPDIRECTDRAWSURFACE lpDDSSrc; ++ LPRECT lprSrc; ++ DWORD dwFlags; ++ LPDDBLTFX lpDDBltFx; ++} DDBLTBATCH, *LPDDBLTBATCH; ++ ++typedef struct { ++ DWORD dwCaps; ++} DDSCAPS, *LPDDSCAPS; ++ ++typedef struct ++{ ++ DWORD dwCaps; ++ DWORD dwCaps2; ++ DWORD dwCaps3; ++ union { ++ DWORD dwCaps4; ++ DWORD dwVolumeDepth; ++ }; ++} DDSCAPS2; ++ ++/*this is the DX7 version (we don't support any previous version)*/ ++typedef struct { ++ DWORD dwSize; ++ DWORD dwCaps; ++ DWORD dwCaps2; ++ DWORD dwCKeyCaps; ++ DWORD dwFXCaps; ++ DWORD dwFXAlphaCaps; ++ DWORD dwPalCaps; ++ DWORD dwSVCaps; ++ DWORD dwAlphaBltConstBitDepths; ++ DWORD dwAlphaBltPixelBitDepths; ++ DWORD dwAlphaBltSurfaceBitDepths; ++ DWORD dwAlphaOverlayConstBitDepths; ++ DWORD dwAlphaOverlayPixelBitDepths; ++ DWORD dwAlphaOverlaySurfaceBitDepths; ++ DWORD dwZBufferBitDepths; ++ DWORD dwVidMemTotal; ++ DWORD dwVidMemFree; ++ DWORD dwMaxVisibleOverlays; ++ DWORD dwCurrVisibleOverlays; ++ DWORD dwNumFourCCCodes; ++ DWORD dwAlignBoundarySrc; ++ DWORD dwAlignSizeSrc; ++ DWORD dwAlignBoundaryDest; ++ DWORD dwAlignSizeDest; ++ DWORD dwAlignStrideAlign; ++ DWORD dwRops[DD_ROP_SPACE]; ++ DDSCAPS ddsOldCaps; ++ DWORD dwMinOverlayStretch; ++ DWORD dwMaxOverlayStretch; ++ DWORD dwMinLiveVideoStretch; ++ DWORD dwMaxLiveVideoStretch; ++ DWORD dwMinHwCodecStretch; ++ DWORD dwMaxHwCodecStretch; ++ DWORD dwReserved1; ++ DWORD dwReserved2; ++ DWORD dwReserved3; ++ DWORD dwSVBCaps; ++ DWORD dwSVBCKeyCaps; ++ DWORD dwSVBFXCaps; ++ DWORD dwSVBRops[DD_ROP_SPACE]; ++ DWORD dwVSBCaps; ++ DWORD dwVSBCKeyCaps; ++ DWORD dwVSBFXCaps; ++ DWORD dwVSBRops[DD_ROP_SPACE]; ++ DWORD dwSSBCaps; ++ DWORD dwSSBCKeyCaps; ++ DWORD dwSSBFXCaps; ++ DWORD dwSSBRops[DD_ROP_SPACE]; ++ DWORD dwMaxVideoPorts; ++ DWORD dwCurrVideoPorts; ++ DWORD dwSVBCaps2; ++ DWORD dwNLVBCaps; ++ DWORD dwNLVBCaps2; ++ DWORD dwNLVBCKeyCaps; ++ DWORD dwNLVBFXCaps; ++ DWORD dwNLVBRops[DD_ROP_SPACE]; ++ DDSCAPS2 ddsCaps; ++} DDCAPS, *LPDDCAPS; ++ ++typedef struct { ++ DWORD dwSize; ++ DWORD dwFlags; ++ DWORD dwFourCC; ++ union { ++ DWORD dwRGBBitCount; ++ DWORD dwYUVBitCount; ++ DWORD dwZBufferBitDepth; ++ DWORD dwAlphaBitDepth; ++ DWORD dwLuminanceBitCount; ++ DWORD dwBumpBitCount; ++ DWORD dwPrivateFormatBitCount; ++ }; ++ union { ++ DWORD dwRBitMask; ++ DWORD dwYBitMask; ++ DWORD dwStencilBitDepth; ++ DWORD dwLuminanceBitMask; ++ DWORD dwBumpDuBitMask; ++ DWORD dwOperations; ++ }; ++ union { ++ DWORD dwGBitMask; ++ DWORD dwUBitMask; ++ DWORD dwZBitMask; ++ DWORD dwBumpDvBitMask; ++ struct { ++ WORD wFlipMSTypes; ++ WORD wBltMSTypes; ++ } MultiSampleCaps; ++ }; ++ union { ++ DWORD dwBBitMask; ++ DWORD dwVBitMask; ++ DWORD dwStencilBitMask; ++ DWORD dwBumpLuminanceBitMask; ++ }; ++ union { ++ DWORD dwRGBAlphaBitMask; ++ DWORD dwYUVAlphaBitMask; ++ DWORD dwLuminanceAlphaBitMask; ++ DWORD dwRGBZBitMask; ++ DWORD dwYUVZBitMask; ++ }; ++} DDPIXELFORMAT, * LPDDPIXELFORMAT; ++ ++typedef struct { ++ DWORD dwSize; ++ DWORD dwFlags; ++ DWORD dwHeight; ++ DWORD dwWidth; ++ union { ++ LONG lPitch; ++ DWORD dwLinearSize; ++ }; ++ DWORD dwBackBufferCount; ++ union { ++ DWORD dwMipMapCount; ++ DWORD dwZBufferBitDepth; ++ DWORD dwRefreshRate; ++ }; ++ DWORD dwAlphaBitDepth; ++ DWORD dwReserved; ++ LPVOID lpSurface; ++ DDCOLORKEY ddckCKDestOverlay; ++ DDCOLORKEY ddckCKDestBlt; ++ DDCOLORKEY ddckCKSrcOverlay; ++ DDCOLORKEY ddckCKSrcBlt; ++ DDPIXELFORMAT ddpfPixelFormat; ++ DDSCAPS ddsCaps; ++} DDSURFACEDESC, *LPDDSURFACEDESC; ++ ++typedef struct { ++ DWORD dwSize; ++ DWORD dwAlphaEdgeBlendBitDepth; ++ DWORD dwAlphaEdgeBlend; ++ DWORD dwReserved; ++ DWORD dwAlphaDestConstBitDepth; ++ union { ++ DWORD dwAlphaDestConst; ++ LPDIRECTDRAWSURFACE lpDDSAlphaDest; ++ }; ++ DWORD dwAlphaSrcConstBitDepth; ++ union { ++ DWORD dwAlphaSrcConst; ++ LPDIRECTDRAWSURFACE lpDDSAlphaSrc; ++ }; ++ DDCOLORKEY dckDestColorkey; ++ DDCOLORKEY dckSrcColorkey; ++ DWORD dwDDFX; ++ DWORD dwFlags; ++} DDOVERLAYFX, *LPDDOVERLAYFX; ++ ++typedef HRESULT (WINAPI * LPDDENUMMODESCALLBACK)(LPDDSURFACEDESC, LPVOID); ++typedef HRESULT (WINAPI * LPDDENUMSURFACESCALLBACK)(LPDIRECTDRAWSURFACE, LPDDSURFACEDESC, LPVOID); ++ ++#define INTERFACE IDirectDrawPalette ++DECLARE_INTERFACE_(IDirectDrawPalette, IUnknown) ++{ ++ 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; ++}; ++#undef INTERFACE ++#define INTERFACE IDirectDrawClipper ++DECLARE_INTERFACE_(IDirectDrawClipper, IUnknown) ++{ ++ STDMETHOD(GetClipList)(THIS_ LPRECT, LPRGNDATA, LPDWORD) PURE; ++ STDMETHOD(GetHWnd)(THIS_ HWND *) PURE; ++ STDMETHOD(Initialize)(THIS_ LPDIRECTDRAW, DWORD) PURE; ++ STDMETHOD(IsClipListChanged)(THIS_ BOOL *) PURE; ++ STDMETHOD(SetClipList)(THIS_ LPRGNDATA,DWORD) PURE; ++ STDMETHOD(SetHWnd)(THIS_ DWORD, HWND ) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IDirectDraw ++DECLARE_INTERFACE_(IDirectDraw, IUnknown) ++{ ++ STDMETHOD(Compact)(THIS) PURE; ++ STDMETHOD(CreateClipper)(THIS_ DWORD, LPDIRECTDRAWCLIPPER *, IUnknown * ) PURE; ++ STDMETHOD(CreatePalette)(THIS_ DWORD, LPPALETTEENTRY, LPDIRECTDRAWPALETTE *, IUnknown * ) PURE; ++ STDMETHOD(CreateSurface)(THIS_ LPDDSURFACEDESC, LPDIRECTDRAWSURFACE *, IUnknown *) PURE; ++ STDMETHOD(DuplicateSurface)( THIS_ LPDIRECTDRAWSURFACE, LPDIRECTDRAWSURFACE * ) 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 *) PURE; ++ STDMETHOD(GetMonitorFrequency)(THIS_ LPDWORD) PURE; ++ STDMETHOD(GetScanLine)(THIS_ LPDWORD) PURE; ++ STDMETHOD(GetVerticalBlankStatus)(THIS_ LPBOOL ) PURE; ++ STDMETHOD(Initialize)(THIS_ GUID *) PURE; ++ STDMETHOD(RestoreDisplayMode)(THIS) PURE; ++ STDMETHOD(SetCooperativeLevel)(THIS_ HWND, DWORD) PURE; ++ STDMETHOD(SetDisplayMode)(THIS_ DWORD, DWORD,DWORD) PURE; ++ STDMETHOD(WaitForVerticalBlank)(THIS_ DWORD, HANDLE ) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IDirectDrawSurface ++DECLARE_INTERFACE_(IDirectDrawSurface, IUnknown) ++{ ++ 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 *) PURE; ++ STDMETHOD(GetBltStatus)(THIS_ DWORD) PURE; ++ STDMETHOD(GetCaps)(THIS_ LPDDSCAPS) PURE; ++ STDMETHOD(GetClipper)(THIS_ LPDIRECTDRAWCLIPPER *) PURE; ++ STDMETHOD(GetColorKey)(THIS_ DWORD, LPDDCOLORKEY) PURE; ++ STDMETHOD(GetDC)(THIS_ HDC *) PURE; ++ STDMETHOD(GetFlipStatus)(THIS_ DWORD) PURE; ++ STDMETHOD(GetOverlayPosition)(THIS_ LPLONG, LPLONG ) PURE; ++ STDMETHOD(GetPalette)(THIS_ LPDIRECTDRAWPALETTE *) 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; ++}; ++#undef INTERFACE ++ ++#ifdef __cplusplus ++} ++#endif ++ ++#endif //_DDRAW_H +\ Kein Zeilenumbruch am Dateiende. +diff -ruN a/include/dmodshow.h b/include/dmodshow.h +--- a/include/dmodshow.h 1970-01-01 01:00:00.000000000 +0100 ++++ b/include/dmodshow.h 2009-03-09 16:54:08.000000000 +0100 +@@ -0,0 +1,23 @@ ++#ifndef _MODSHOW_H ++#define _MODSHOW_H ++#if __GNUC__ >= 3 ++#pragma GCC system_header ++#endif ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++DEFINE_GUID(CLSID_DMOWrapperFilter, 0x94297043,0xbd82,0x4dfd,0xb0,0xde,0x81,0x77,0x73,0x9c,0x6d,0x20); ++EXTERN_C const IID IID_IDMOWrapperFilter; ++ ++#define INTERFACE IDMOWrapperFilter ++DECLARE_INTERFACE_(IDMOWrapperFilter, IUnknown) ++{ ++ STDMETHOD(Init)(THIS_ REFCLSID, REFCLSID) PURE; ++}; ++#undef INTERFACE ++#ifdef __cplusplus ++} ++#endif ++#endif +diff -ruN a/include/dmo.h b/include/dmo.h +--- a/include/dmo.h 1970-01-01 01:00:00.000000000 +0100 ++++ b/include/dmo.h 2009-03-09 16:49:50.000000000 +0100 +@@ -0,0 +1,46 @@ ++#ifndef _DMO_H ++#define _DMO_H ++ ++#if __GNUC__ >= 3 ++#pragma GCC system_header ++#endif ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++ ++typedef struct _DMO_PARTIAL_MEDIATYPE { ++ GUID type; ++ GUID subtype; ++} DMO_PARTIAL_MEDIATYPE; ++ ++typedef enum { ++ DMO_ENUMF_INCLUDE_KEYED = 0x00000001 ++} DMO_ENUM_FLAGS; ++ ++DEFINE_GUID(DMOCATEGORY_AUDIO_EFFECT, 0xf3602b3f,0x0592,0x48df,0xa4,0xcd,0x67,0x47,0x21,0xe7,0xeb,0xeb); ++DECLARE_INTERFACE(IEnumDMO); ++ ++typedef AM_MEDIA_TYPE DMO_MEDIA_TYPE; ++STDAPI DMOEnum(REFGUID, DWORD, DWORD, const DMO_PARTIAL_MEDIATYPE *, DWORD, const DMO_PARTIAL_MEDIATYPE *, ++ IEnumDMO **); ++STDAPI DMOGetName(REFCLSID, WCHAR [80]); ++ ++ ++#define INTERFACE IEnumDMO ++DECLARE_INTERFACE_(IEnumDMO, IUnknown) ++{ ++ STDMETHOD(Next)(THIS_ DWORD, CLSID *, WCHAR **, DWORD *) PURE; ++ STDMETHOD(Skip)(THIS_ DWORD) PURE; ++ STDMETHOD(Reset)(THIS) PURE; ++ STDMETHOD(Clone)(THIS_ IEnumDMO **) PURE; ++}; ++#undef INTERFACE ++ ++ ++#ifdef __cplusplus ++} ++#endif ++ ++#endif //_DMO_H +\ Kein Zeilenumbruch am Dateiende. +diff -ruN a/include/dshow.h b/include/dshow.h +--- a/include/dshow.h 2008-12-06 03:31:56.000000000 +0100 ++++ b/include/dshow.h 2010-04-12 17:12:52.000000000 +0200 +@@ -5,7 +5,10 @@ + #endif + + #include <strmif.h> ++#ifdef DSHOW_USE_AMAUDIO + #include <amaudio.h> ++#endif ++#include <control.h> + #include <amvideo.h> + #include <evcode.h> + #include <audevcod.h> +@@ -50,10 +53,6 @@ + AM_WST_STATE_Off = 0, + AM_WST_STATE_On + } AM_WST_STATE,*PAM_WST_STATE; +-typedef enum _AM_WST_STYLE { +- AM_WST_STYLE_None = 0, +- AM_WST_STYLE_Invers +-} AM_WST_STYLE,*PAM_WST_STYLE; + typedef enum { + AM_EXSEEK_CANSEEK= 1, + AM_EXSEEK_CANSCAN = 2, +@@ -63,6 +62,10 @@ + AM_EXSEEK_BUFFERING = 32, + AM_EXSEEK_SENDS_VIDEOFRAMEREADY = 64 + } AMExtendedSeekingCapabilities; ++typedef enum _AM_WST_STYLE { ++ AM_WST_STYLE_None = 0, ++ AM_WST_STYLE_Invers ++} AM_WST_STYLE,*PAM_WST_STYLE; + /*--- DirectShow Reference - DirectShow Structures */ + typedef struct _AM_WST_PAGE { + DWORD dwPageNr; +diff -ruN a/include/medparam.h b/include/medparam.h +--- a/include/medparam.h 1970-01-01 01:00:00.000000000 +0100 ++++ b/include/medparam.h 2009-03-09 16:55:56.000000000 +0100 +@@ -0,0 +1,88 @@ ++#ifndef _MEDPARAM_H ++#define _MEDPARAM_H ++#if __GNUC__ >= 3 ++#pragma GCC system_header ++#endif ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++#define MP_CAPS_CURVE_INVSQUARE ( MP_CURVE_INVSQUARE ) ++ ++/* typedefs */ ++typedef DWORD MP_CAPS; ++typedef float MP_DATA; ++typedef DWORD MP_TIMEDATA; ++typedef DWORD MP_FLAGS; ++ ++ ++/* enum */ ++typedef ++enum _MP_CURVE_TYPE { ++ MP_CURVE_JUMP = 0x1, ++ MP_CURVE_LINEAR = 0x2, ++ MP_CURVE_SQUARE = 0x4, ++ MP_CURVE_INVSQUARE = 0x8, ++ MP_CURVE_SINE = 0x10 ++} MP_CURVE_TYPE; ++ ++typedef ++enum _MP_Type { ++ MPT_INT = 0, ++ MPT_FLOAT = ( MPT_INT + 1 ) , ++ MPT_BOOL = ( MPT_FLOAT + 1 ) , ++ MPT_ENUM = ( MPT_BOOL + 1 ) , ++ MPT_MAX = ( MPT_ENUM + 1 ) ++} MP_TYPE; ++ ++/* structs */ ++ ++typedef struct _MP_PARAMINFO { ++ MP_TYPE mpType; ++ MP_CAPS mopCaps; ++ MP_DATA mpdMinValue; ++ MP_DATA mpdMaxValue; ++ MP_DATA mpdNeutralValue; ++ WCHAR szUnitText[32]; ++ WCHAR szLabel[32]; ++} MP_PARAMINFO; ++ ++typedef struct _MP_ENVELOPE_SEGMENT { ++ REFERENCE_TIME rtStart; ++ REFERENCE_TIME rtEnd; ++ MP_DATA valStart; ++ MP_DATA valEnd; ++ MP_CURVE_TYPE iCurve; ++ MP_FLAGS flags; ++} MP_ENVELOPE_SEGMENT; ++ ++/* interfaces */ ++EXTERN_C const IID IID_IMediaParamInfo; ++EXTERN_C const IID IID_IMediaParams; ++ ++#define INTERFACE IMediaParamInfo ++DECLARE_INTERFACE_(IMediaParamInfo, IUnknown) ++{ ++ STDMETHOD(GetParamCount)(THIS_ DWORD *) PURE; ++ STDMETHOD(GetParamInfo)(THIS_ DWORD, MP_PARAMINFO *) PURE; ++ STDMETHOD(GetParamText)(THIS_ DWORD, WCHAR **) PURE; ++ STDMETHOD(GetNumTimeFormats)(THIS_ DWORD *) PURE; ++ STDMETHOD(GetSupportedTimeFormat)(THIS_ DWORD, GUID *) PURE; ++ STDMETHOD(GetCurrentTimeFormat)(THIS_ GUID *, MP_TIMEDATA *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaParams ++DECLARE_INTERFACE_(IMediaParams, IUnknown) ++{ ++ STDMETHOD(GetParam)(THIS_ DWORD, MP_DATA *) PURE; ++ STDMETHOD(SetParam)(THIS_ DWORD, MP_DATA) PURE; ++ STDMETHOD(AddEnvelope)(THIS_ DWORD, DWORD, MP_ENVELOPE_SEGMENT *) PURE; ++ STDMETHOD(FlushEnvelope)(THIS_ DWORD, REFERENCE_TIME, REFERENCE_TIME) PURE; ++ STDMETHOD(SetTimeFormat)(THIS_ GUID, MP_TIMEDATA) PURE; ++}; ++#undef INTERFACE ++#ifdef __cplusplus ++} ++#endif ++#endif +diff -ruN a/include/qnetwork.h b/include/qnetwork.h +--- a/include/qnetwork.h 1970-01-01 01:00:00.000000000 +0100 ++++ b/include/qnetwork.h 2009-03-09 16:15:46.000000000 +0100 +@@ -0,0 +1,49 @@ ++#ifndef _QNETWORK_H ++#define _QNETWORK_H ++ ++#if __GNUC__ >= 3 ++#pragma GCC system_header ++#endif ++ ++#ifdef __cplusplus ++extern "C" { ++#endif ++ ++DEFINE_GUID(IID_IAMMediaContent,0xFA2AA8F4L,0x8B62,0x11D0,0xA5,0x20,0x00,0x00,0x00,0x00,0x00,0x00); ++DEFINE_GUID(IID_IAMNetworkStatus,0xFA2AA8F3L,0x8B62,0x11D0,0xA5,0x20,0x00,0x00,0x00,0x00,0x00,0x00); ++ ++#define INTERFACE IAMMediaContent ++DECLARE_INTERFACE_(IAMMediaContent, IDispatch) ++{ ++ STDMETHOD(get_AuthorName)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_Title)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_Rating)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_Description)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_Copyright)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_BaseURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_LogoURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_LogoIconURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_WatermarkURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_MoreInfoURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_MoreInfoBannerImage)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_MoreInfoBannerURL)(THIS_ BSTR*) PURE; ++ STDMETHOD(get_MoreInfoText)(THIS_ BSTR*) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE(IAMNetworkStatus) ++DECLARE_INTERFACE_(IAMNetworkStatus, IDispatch) ++{ ++ STDMETHOD(get_ReceivedPackets)(THIS_ long*) PURE; ++ STDMETHOD(get_RecoveredPackets)(THIS_ long*) PURE; ++ STDMETHOD(get_LostPackets)(THIS_ long*) PURE; ++ STDMETHOD(get_ReceptionQuality)(THIS_ long*) PURE; ++ STDMETHOD(get_BufferingCount)(THIS_ long*) PURE; ++ STDMETHOD(get_IsBroadcast)(THIS_ VARIANT_BOOL*) PURE; ++ STDMETHOD(get_BufferingProgress)(THIS_ long*) PURE; ++}; ++#undef INTERFACE ++#ifdef __cplusplus ++} ++#endif ++ ++#endif //_QNETWORK_H +\ Kein Zeilenumbruch am Dateiende. +diff -ruN a/include/strmif.h b/include/strmif.h +--- a/include/strmif.h 2008-12-06 03:32:10.000000000 +0100 ++++ b/include/strmif.h 2010-04-12 17:12:52.000000000 +0200 +@@ -4,10 +4,79 @@ + #pragma GCC system_header + #endif + ++#include <ddraw.h> ++ + #ifdef __cplusplus + extern "C" { + #endif + ++#define MAX_FILTER_NAME 128 ++#define AM_GBF_NOTASYNCPOINT 2 ++ ++/*--- DirectShow Reference - Forward declarations of Interfaces and typedefs */ ++typedef DWORD_PTR HEVENT; ++typedef DWORD_PTR HSEMAPHORE; ++DECLARE_INTERFACE(IBaseFilter); ++DECLARE_INTERFACE(IPin); ++DECLARE_INTERFACE(IFilterGraph); ++DECLARE_INTERFACE(IEnumFilters); ++EXTERN_C const IID IID_IBaseFilter; ++EXTERN_C const IID IID_ICreateDevEnum; ++EXTERN_C const IID IID_IGraphBuilder; ++EXTERN_C const IID IID_IMediaSeeking; ++EXTERN_C const IID IID_IMediaEventSink; ++EXTERN_C const IID IID_IMemInputPin; ++EXTERN_C const IID IID_IEnumPins; ++EXTERN_C const IID IID_IMediaFilter; ++EXTERN_C const IID IID_IEnumMediaTypes; ++EXTERN_C const IID IID_IMemAllocator; ++EXTERN_C const IID IID_IPin; ++EXTERN_C const IID IID_IAsyncReader; ++ ++/* class ids*/ ++DEFINE_GUID(CLSID_AudioRender, ++0xe30629d1, 0x27e5, 0x11ce, 0x87, 0x5d, 0x0, 0x60, 0x8c, 0xb7, 0x80, 0x66); ++DEFINE_GUID(CLSID_SystemDeviceEnum, ++0x62BE5D10,0x60EB,0x11d0,0xBD,0x3B,0x00,0xA0,0xC9,0x11,0xCE,0x86); ++DEFINE_GUID(CLSID_AudioRendererCategory, ++0xe0f158e1, 0xcb04, 0x11d0, 0xbd, 0x4e, 0x0, 0xa0, 0xc9, 0x11, 0xce, 0x86); ++DEFINE_GUID(CLSID_FilterGraph, ++0xe436ebb3, 0x524f, 0x11ce, 0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70); ++DEFINE_GUID(CLSID_InfTee, ++0xf8388a40, 0xd5bb, 0x11d0, 0xbe, 0x5a, 0x0, 0x80, 0xc7, 0x6, 0x56, 0x8e); ++DEFINE_GUID(CLSID_VideoMixingRenderer9, ++0x51b4abf3, 0x748f, 0x4e3b, 0xa2, 0x76, 0xc8, 0x28, 0x33, 0x0e, 0x92, 0x6a); ++DEFINE_GUID(CLSID_MemoryAllocator, ++0x1e651cc0, 0xb199, 0x11d0, 0x82, 0x12, 0x00, 0xc0, 0x4f, 0xc3, 0x2c, 0x45); ++ ++/*other types*/ ++DEFINE_GUID(MEDIATYPE_Audio, ++0x73647561, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71); ++DEFINE_GUID(MEDIATYPE_Video, ++0x73646976, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71); ++DEFINE_GUID(MEDIATYPE_Stream, ++0xe436eb83, 0x524f, 0x11ce, 0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70); ++DEFINE_GUID(MEDIASUBTYPE_PCM, ++0x00000001, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xAA, 0x00, 0x38, 0x9B, 0x71); ++DEFINE_GUID(MEDIASUBTYPE_WAVE, ++0xe436eb8b, 0x524f, 0x11ce, 0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70); ++DEFINE_GUID(MEDIASUBTYPE_Avi, ++0xe436eb88, 0x524f, 0x11ce, 0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70); ++DEFINE_GUID(MEDIASUBTYPE_RGB32, ++0xe436eb7e, 0x524f, 0x11ce, 0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70); ++DEFINE_GUID(MEDIASUBTYPE_YV12, ++0x32315659, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71); ++DEFINE_GUID(MEDIASUBTYPE_YUY2, ++0x32595559, 0x0000, 0x0010, 0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71); ++DEFINE_GUID(FORMAT_WaveFormatEx, ++0x05589f81, 0xc356, 0x11ce, 0xbf, 0x01, 0x00, 0xaa, 0x00, 0x55, 0x59, 0x5a); ++DEFINE_GUID(FORMAT_VideoInfo, ++0x05589f80, 0xc356, 0x11ce, 0xbf, 0x01, 0x00, 0xaa, 0x00, 0x55, 0x59, 0x5a); ++DEFINE_GUID(FORMAT_VideoInfo2, ++0xf72a76A0, 0xeb0a, 0x11d0, 0xac, 0xe4, 0x00, 0x00, 0xc0, 0xcc, 0x16, 0xba); ++#define MEDIATYPE_NULL GUID_NULL ++#define MEDIASUBTYPE_NULL GUID_NULL ++ + /*--- DirectShow Reference - DirectShow Enumerated Types - TVAudioMode Enumeration */ + #define TVAUDIO_MODE_MASK 0x000000FF + #define TVAUDIO_PRESET_MASK 0x0000FF00 +@@ -24,6 +93,18 @@ + MERIT_HW_COMPRESSOR = 0x100050 + }; + /*--- DirectShow Reference - DirectShow Enumerated Types */ ++typedef ++enum AM_SEEKING_SeekingFlags { ++ AM_SEEKING_NoPositioning = 0, ++ AM_SEEKING_AbsolutePositioning = 0x1, ++ AM_SEEKING_RelativePositioning = 0x2, ++ AM_SEEKING_IncrementalPositioning = 0x3, ++ AM_SEEKING_PositioningBitsMask = 0x3, ++ AM_SEEKING_SeekToKeyFrame = 0x4, ++ AM_SEEKING_ReturnTime = 0x8, ++ AM_SEEKING_Segment = 0x10, ++ AM_SEEKING_NoFlush = 0x20 ++} AM_SEEKING_SEEKING_FLAGS; + typedef enum _AM_AUDIO_RENDERER_STAT_PARAM { + AM_AUDREND_STAT_PARAM_BREAK_COUNT = 1, + AM_AUDREND_STAT_PARAM_SLAVE_MODE, +@@ -452,7 +533,7 @@ + Famine, + Flood + } QualityMessageType; +-enum { ++typedef enum { + REG_PINFLAG_B_ZERO = 0x1, + REG_PINFLAG_B_RENDERER = 0x2, + REG_PINFLAG_B_MANY = 0x4, +@@ -613,6 +694,10 @@ + AMAP_DXVA_TARGET = 0x20 + } VMRSurfaceAllocationFlags; + /*--- DirectShow Reference - DirectShow Structures */ ++typedef struct _FilterInfo { ++ WCHAR achName[128]; ++ IFilterGraph *pGraph; ++} FILTER_INFO; + typedef struct _AllocatorProperties { + long cBuffers; + long cbBuffer; +@@ -731,10 +816,6 @@ + #define CK_NOCOLORKEY 0x00000000 + #define CK_INDEX 0x00000001 + #define CK_RGB 0x00000002 +-typedef struct { +- DWORD dw1; +- DWORD dw2; +-} DDCOLORKEY; + typedef struct tagDVD_AudioAttributes { + DVD_AUDIO_APPMODE AppMode; + DVD_AUDIO_FORMAT AudioFormat; +@@ -848,7 +929,7 @@ + BOOL fIsSourceLetterboxed; + BOOL fIsFilmMode; + } DVD_VideoAttributes; +-struct tagDVD_MenuAttributes { ++typedef struct tagDVD_MenuAttributes { + BOOL fCompatibleRegion[8]; + DVD_VideoAttributes VideoAttributes; + BOOL fAudioPresent; +@@ -1024,7 +1105,7 @@ + } VMRFrequency; + typedef struct tagVMRGUID { + GUID *pGUID; +- GUID GUID; ++ GUID _GUID; + } VMRGUID; + typedef struct tagVMRMONITORINFO { + VMRGUID guid; +@@ -1074,15 +1155,15 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,get_AvailableTVFormats)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,get_HorizontalLocked)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,get_NumberOfLines)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,get_OutputEnable)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,get_TVFormat)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,get_VCRHorizontalLocking)(THIS_ long*) PURE; +- STDMETHOD_(HRESULT,put_OutputEnable)(THIS_ long) PURE; +- STDMETHOD_(HRESULT,put_TVFormat)(THIS_ long) PURE; +- STDMETHOD_(HRESULT,put_VCRHorizontalLocking)(THIS_ long) PURE; ++ STDMETHOD(get_AvailableTVFormats)(THIS_ long*) PURE; ++ STDMETHOD(get_HorizontalLocked)(THIS_ long*) PURE; ++ STDMETHOD(get_NumberOfLines)(THIS_ long*) PURE; ++ STDMETHOD(get_OutputEnable)(THIS_ long*) PURE; ++ STDMETHOD(get_TVFormat)(THIS_ long*) PURE; ++ STDMETHOD(get_VCRHorizontalLocking)(THIS_ long*) PURE; ++ STDMETHOD(put_OutputEnable)(THIS_ long) PURE; ++ STDMETHOD(put_TVFormat)(THIS_ long) PURE; ++ STDMETHOD(put_VCRHorizontalLocking)(THIS_ long) PURE; + }; + #undef INTERFACE + #define INTERFACE IAMAudioInputMixer +@@ -1091,22 +1172,22 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,get_Bass)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,get_BassRange)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,get_Enable)(THIS_ BOOL*) PURE; +- STDMETHOD_(HRESULT,get_Loudness)(THIS_ BOOL*) PURE; +- STDMETHOD_(HRESULT,get_MixLevel)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,get_Mono)(THIS_ BOOL*) PURE; +- STDMETHOD_(HRESULT,get_Pan)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,get_Treble)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,get_TrebleRange)(THIS_ double*) PURE; +- STDMETHOD_(HRESULT,put_Bass)(THIS_ double) PURE; +- STDMETHOD_(HRESULT,put_Enable)(THIS_ BOOL) PURE; +- STDMETHOD_(HRESULT,put_Loudness)(THIS_ BOOL) PURE; +- STDMETHOD_(HRESULT,put_MixLevel)(THIS_ double) PURE; +- STDMETHOD_(HRESULT,put_Mono)(THIS_ BOOL) PURE; +- STDMETHOD_(HRESULT,put_Pan)(THIS_ double) PURE; +- STDMETHOD_(HRESULT,put_Treble)(THIS_ double) PURE; ++ STDMETHOD(get_Bass)(THIS_ double*) PURE; ++ STDMETHOD(get_BassRange)(THIS_ double*) PURE; ++ STDMETHOD(get_Enable)(THIS_ BOOL*) PURE; ++ STDMETHOD(get_Loudness)(THIS_ BOOL*) PURE; ++ STDMETHOD(get_MixLevel)(THIS_ double*) PURE; ++ STDMETHOD(get_Mono)(THIS_ BOOL*) PURE; ++ STDMETHOD(get_Pan)(THIS_ double*) PURE; ++ STDMETHOD(get_Treble)(THIS_ double*) PURE; ++ STDMETHOD(get_TrebleRange)(THIS_ double*) PURE; ++ STDMETHOD(put_Bass)(THIS_ double) PURE; ++ STDMETHOD(put_Enable)(THIS_ BOOL) PURE; ++ STDMETHOD(put_Loudness)(THIS_ BOOL) PURE; ++ STDMETHOD(put_MixLevel)(THIS_ double) PURE; ++ STDMETHOD(put_Mono)(THIS_ BOOL) PURE; ++ STDMETHOD(put_Pan)(THIS_ double) PURE; ++ STDMETHOD(put_Treble)(THIS_ double) PURE; + }; + #undef INTERFACE + #define INTERFACE IAMAudioRendererStats +@@ -1115,7 +1196,7 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,GetStatParam)(THIS_ DWORD,DWORD*,DWORD*) PURE; ++ STDMETHOD(GetStatParam)(THIS_ DWORD,DWORD*,DWORD*) PURE; + }; + #undef INTERFACE + #define INTERFACE IAMBufferNegotiation +@@ -1124,8 +1205,8 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,GetAllocatorProperties)(THIS_ ALLOCATOR_PROPERTIES*) PURE; +- STDMETHOD_(HRESULT,SuggestAllocatorProperties)(THIS_ const ALLOCATOR_PROPERTIES*) PURE; ++ STDMETHOD(GetAllocatorProperties)(THIS_ ALLOCATOR_PROPERTIES*) PURE; ++ STDMETHOD(SuggestAllocatorProperties)(THIS_ const ALLOCATOR_PROPERTIES*) PURE; + }; + #undef INTERFACE + #define INTERFACE IAMCameraControl +@@ -1134,9 +1215,9 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,Get)(THIS_ long,long*,long*) PURE; +- STDMETHOD_(HRESULT,GetRange)(THIS_ long,long*,long*,long*,long*,long*) PURE; +- STDMETHOD_(HRESULT,Set)(THIS_ long,long,long) PURE; ++ STDMETHOD(Get)(THIS_ long,long*,long*) PURE; ++ STDMETHOD(GetRange)(THIS_ long,long*,long*,long*,long*,long*) PURE; ++ STDMETHOD(Set)(THIS_ long,long,long) PURE; + }; + #undef INTERFACE + +@@ -1146,13 +1227,205 @@ + STDMETHOD(QueryInterface)(THIS_ REFIID,PVOID*) PURE; + STDMETHOD_(ULONG,AddRef)(THIS) PURE; + STDMETHOD_(ULONG,Release)(THIS) PURE; +- STDMETHOD_(HRESULT,KeyExchange)(THIS_ GUID*,BYTE**,DWORD*) PURE; +- STDMETHOD_(HRESULT,ProtectionCommand)(THIS_ const AMCOPPCommand*) PURE; +- STDMETHOD_(HRESULT,ProtectionStatus)(THIS_ const AMCOPPStatusInput*,AMCOPPStatusOutput*) PURE; +- STDMETHOD_(HRESULT,SessionSequenceStart)(THIS_ const AMCOPPSignature*) PURE; ++ STDMETHOD(KeyExchange)(THIS_ GUID*,BYTE**,DWORD*) PURE; ++ STDMETHOD(ProtectionCommand)(THIS_ const AMCOPPCommand*) PURE; ++ STDMETHOD(ProtectionStatus)(THIS_ const AMCOPPStatusInput*,AMCOPPStatusOutput*) PURE; ++ STDMETHOD(SessionSequenceStart)(THIS_ const AMCOPPSignature*) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IFilterGraph ++DECLARE_INTERFACE_(IFilterGraph ,IUnknown) ++{ ++ STDMETHOD(AddFilter)(THIS_ IBaseFilter *, LPCWSTR) PURE; ++ STDMETHOD(RemoveFilter)(THIS_ IBaseFilter *) PURE; ++ STDMETHOD(EnumFilters)(THIS_ IEnumFilters **) PURE; ++ STDMETHOD(FindFilterByName)(THIS_ LPCWSTR, IBaseFilter **) PURE; ++ STDMETHOD(ConnectDirect)(THIS_ IPin *, IPin *, const AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(Reconnect)(THIS_ IPin *) PURE; ++ STDMETHOD(Disconnect)(THIS_ IPin *) PURE; ++ STDMETHOD(SetDefaultSyncSource)(THIS) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IGraphBuilder ++DECLARE_INTERFACE_(IGraphBuilder ,IFilterGraph) ++{ ++ STDMETHOD(Connect)(THIS_ IPin *, IPin *) PURE; ++ STDMETHOD(Render)(THIS_ IPin *) PURE; ++ STDMETHOD(RenderFile)(THIS_ LPCWSTR, LPCWSTR) PURE; ++ STDMETHOD(AddSourceFilter)(THIS_ LPCWSTR, LPCWSTR, IBaseFilter **) PURE; ++ STDMETHOD(SetLogFile)(THIS_ DWORD_PTR) PURE; ++ STDMETHOD(Abort)(THIS) PURE; ++ STDMETHOD(ShouldOperationContinue)(THIS) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IReferenceClock ++DECLARE_INTERFACE_(IReferenceClock, IUnknown) ++{ ++ STDMETHOD(GetTime)(THIS_ REFERENCE_TIME *) PURE; ++ STDMETHOD(AdviseTime)(THIS_ REFERENCE_TIME, REFERENCE_TIME, HEVENT, DWORD_PTR *) PURE; ++ STDMETHOD(AdvisePeriodic)(THIS_ REFERENCE_TIME, REFERENCE_TIME, HSEMAPHORE, DWORD_PTR *) PURE; ++ STDMETHOD(Unadvise)(THIS_ DWORD_PTR) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IEnumFilters ++DECLARE_INTERFACE_(IEnumFilters, IUnknown) ++{ ++ STDMETHOD(Next)(THIS_ ULONG, IBaseFilter **, ULONG *) PURE; ++ STDMETHOD(Skip)(THIS_ ULONG) PURE; ++ STDMETHOD(Reset)(THIS) PURE; ++ STDMETHOD(Clone)(THIS_ IEnumFilters **) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IEnumMediaTypes ++DECLARE_INTERFACE_(IEnumMediaTypes, IUnknown) ++{ ++ STDMETHOD(Next)(THIS_ ULONG, AM_MEDIA_TYPE **, ULONG *) PURE; ++ STDMETHOD(Skip)(THIS_ ULONG) PURE; ++ STDMETHOD(Reset)(THIS) PURE; ++ STDMETHOD(Clone)(THIS_ IEnumMediaTypes **) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IEnumPins ++DECLARE_INTERFACE_(IEnumPins, IUnknown) ++{ ++ STDMETHOD(Next)(THIS_ ULONG, IPin **, ULONG *) PURE; ++ STDMETHOD(Skip)(THIS_ ULONG) PURE; ++ STDMETHOD(Reset)(THIS) PURE; ++ STDMETHOD(Clone)(THIS_ IEnumPins **) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IPin ++DECLARE_INTERFACE_(IPin, IUnknown) ++{ ++ STDMETHOD(Connect)(THIS_ IPin *, const AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(ReceiveConnection)(THIS_ IPin *, const AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(Disconnect)(THIS) PURE; ++ STDMETHOD(ConnectedTo)(THIS_ IPin **) PURE; ++ STDMETHOD(ConnectionMediaType)(THIS_ AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(QueryPinInfo)(THIS_ PIN_INFO *) PURE; ++ STDMETHOD(QueryDirection)(THIS_ PIN_DIRECTION *) PURE; ++ STDMETHOD(QueryId)(THIS_ LPWSTR *) PURE; ++ STDMETHOD(QueryAccept)(THIS_ const AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(EnumMediaTypes)(THIS_ IEnumMediaTypes **) PURE; ++ STDMETHOD(QueryInternalConnections)(THIS_ IPin **, ULONG *) PURE; ++ STDMETHOD(EndOfStream)(THIS) PURE; ++ STDMETHOD(BeginFlush)(THIS) PURE; ++ STDMETHOD(EndFlush)(THIS) PURE; ++ STDMETHOD(NewSegment)(THIS_ REFERENCE_TIME, REFERENCE_TIME, double) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaFilter ++DECLARE_INTERFACE_(IMediaFilter, IPersist) ++{ ++ STDMETHOD(Stop)(THIS) PURE; ++ STDMETHOD(Pause)(THIS) PURE; ++ STDMETHOD(Run)(THIS_ REFERENCE_TIME) PURE; ++ STDMETHOD(GetState)(THIS_ DWORD, FILTER_STATE *) PURE; ++ STDMETHOD(SetSyncSource)(THIS_ IReferenceClock *) PURE; ++ STDMETHOD(GetSyncSource)(THIS_ IReferenceClock **) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IBaseFilter ++DECLARE_INTERFACE_(IBaseFilter, IMediaFilter) ++{ ++ STDMETHOD(EnumPins)(THIS_ IEnumPins **) PURE; ++ STDMETHOD(FindPin)(THIS_ LPCWSTR, IPin **) PURE; ++ STDMETHOD(QueryFilterInfo)(THIS_ FILTER_INFO *) PURE; ++ STDMETHOD(JoinFilterGraph)(THIS_ IFilterGraph *, LPCWSTR) PURE; ++ STDMETHOD(QueryVendorInfo)(THIS_ LPWSTR *) PURE; + }; + #undef INTERFACE ++#define INTERFACE IMediaSeeking ++DECLARE_INTERFACE_(IMediaSeeking, IUnknown) ++{ ++ STDMETHOD(GetCapabilities)(THIS_ DWORD *) PURE; ++ STDMETHOD(CheckCapabilities)(THIS_ DWORD *) PURE; ++ STDMETHOD(IsFormatSupported)(THIS_ const GUID *) PURE; ++ STDMETHOD(QueryPreferredFormat)(THIS_ GUID *) PURE; ++ STDMETHOD(GetTimeFormat)(THIS_ GUID *) PURE; ++ STDMETHOD(IsUsingTimeFormat)(THIS_ const GUID *) PURE; ++ STDMETHOD(SetTimeFormat)(THIS_ const GUID *) PURE; ++ STDMETHOD(GetDuration)(THIS_ LONGLONG *) PURE; ++ STDMETHOD(GetStopPosition)(THIS_ LONGLONG *) PURE; ++ STDMETHOD(GetCurrentPosition)(THIS_ LONGLONG *) PURE; ++ STDMETHOD(ConvertTimeFormat)(THIS_ LONGLONG *, const GUID *, LONGLONG, const GUID *) PURE; ++ STDMETHOD(SetPositions)(THIS_ LONGLONG *, DWORD, LONGLONG *, DWORD) PURE; ++ STDMETHOD(GetPositions)(THIS_ LONGLONG *,LONGLONG *) PURE; ++ STDMETHOD(GetAvailable)(THIS_ LONGLONG *, LONGLONG *) PURE; ++ STDMETHOD(SetRate)(THIS_ double) PURE; ++ STDMETHOD(GetRate)(THIS_ double *) PURE; ++ STDMETHOD(GetPreroll)(THIS_ LONGLONG *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE ICreateDevEnum ++DECLARE_INTERFACE_(ICreateDevEnum, IUnknown) ++{ ++ STDMETHOD(CreateClassEnumerator)(THIS_ REFCLSID, IEnumMoniker **, DWORD) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaSample ++DECLARE_INTERFACE_(IMediaSample, IUnknown) ++{ ++ STDMETHOD(GetPointer)(THIS_ BYTE **) PURE; ++ STDMETHOD_(long, GetSize)(THIS) PURE; ++ STDMETHOD(GetTime)(THIS_ REFERENCE_TIME *, REFERENCE_TIME *) PURE; ++ STDMETHOD(SetTime)(THIS_ REFERENCE_TIME *, REFERENCE_TIME *) PURE; ++ STDMETHOD(IsSyncPoint)(THIS) PURE; ++ STDMETHOD(SetSyncPoint)(THIS_ BOOL) PURE; ++ STDMETHOD(IsPreroll)(THIS) PURE; ++ STDMETHOD(SetPreroll)(THIS_ BOOL) PURE; ++ STDMETHOD_(long, GetActualDataLength)(THIS) PURE; ++ STDMETHOD(SetActualDataLength)(THIS_ long) PURE; ++ STDMETHOD(GetMediaType)(THIS_ AM_MEDIA_TYPE **) PURE; ++ STDMETHOD(SetMediaType)(THIS_ AM_MEDIA_TYPE *) PURE; ++ STDMETHOD(IsDiscontinuity)(THIS) PURE; ++ STDMETHOD(SetDiscontinuity)(THIS_ BOOL) PURE; ++ STDMETHOD(GetMediaTime)(THIS_ LONGLONG *, LONGLONG *) PURE; ++ STDMETHOD(SetMediaTime)(THIS_ LONGLONG *, LONGLONG *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMemAllocator ++DECLARE_INTERFACE_(IMemAllocator, IUnknown) ++{ ++ STDMETHOD(SetProperties)(THIS_ ALLOCATOR_PROPERTIES *, ALLOCATOR_PROPERTIES *) PURE; ++ STDMETHOD(GetProperties)(THIS_ ALLOCATOR_PROPERTIES *) PURE; ++ STDMETHOD(Commit)(THIS) PURE; ++ STDMETHOD(Decommit)(THIS) PURE; ++ STDMETHOD(GetBuffer)(THIS_ IMediaSample **, REFERENCE_TIME *, REFERENCE_TIME *, DWORD) PURE; ++ STDMETHOD(ReleaseBuffer)(THIS_ IMediaSample *) PURE; + ++}; ++#undef INTERFACE ++#define INTERFACE IAsyncReader ++DECLARE_INTERFACE_(IAsyncReader, IUnknown) ++{ ++ STDMETHOD(RequestAllocator)(THIS_ IMemAllocator *, ALLOCATOR_PROPERTIES *, IMemAllocator **) PURE; ++ STDMETHOD(Request)(THIS_ IMediaSample *, DWORD_PTR) PURE; ++ STDMETHOD(WaitForNext)(THIS_ DWORD, IMediaSample **, DWORD_PTR *) PURE; ++ STDMETHOD(SyncReadAligned)(THIS_ IMediaSample *) PURE; ++ STDMETHOD(SyncRead)(THIS_ LONGLONG, LONG, BYTE *) PURE; ++ STDMETHOD(Length)(THIS_ LONGLONG *, LONGLONG *) PURE; ++ STDMETHOD(BeginFlush)(THIS) PURE; ++ STDMETHOD(EndFlush)(THIS) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMediaEventSink ++DECLARE_INTERFACE_(IMediaEventSink, IUnknown) ++{ ++ STDMETHOD(Notify)(THIS_ long, LONG_PTR, LONG_PTR) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IMemInputPin ++DECLARE_INTERFACE_(IMemInputPin, IUnknown) ++{ ++ STDMETHOD(GetAllocator)(THIS_ IMemAllocator **) PURE; ++ STDMETHOD(NotifyAllocator)(THIS_ IMemAllocator *, BOOL) PURE; ++ STDMETHOD(GetAllocatorRequirements)(THIS_ ALLOCATOR_PROPERTIES *) PURE; ++ STDMETHOD(Receive)(THIS_ IMediaSample *) PURE; ++ STDMETHOD(ReceiveMultiple)(THIS_ IMediaSample **, long, long *) PURE; ++ STDMETHOD(ReceiveCanBlock)(THIS) PURE; ++}; ++#undef INTERFACE + #ifdef __cplusplus + } + #endif +diff -ruN a/include/vmr9.h b/include/vmr9.h +--- a/include/vmr9.h 2008-12-06 03:32:11.000000000 +0100 ++++ b/include/vmr9.h 2010-04-12 17:12:52.000000000 +0200 +@@ -8,6 +8,10 @@ + extern "C" { + #endif + ++EXTERN_C const IID IID_IVMRFilterConfig9; ++EXTERN_C const IID IID_IVMRWindowlessControl9; ++EXTERN_C const IID IID_IVMRMixerControl9; ++ + /*--- DirectShow Reference - DirectShow Enumerated Types */ + typedef enum _VMR9_SampleFormat { + VMR9_SampleReserved = 1, +@@ -61,7 +65,7 @@ + MixerPref9_RenderTargetRGB = 0x00001000, + MixerPref9_RenderTargetYUV = 0x00002000, + MixerPref9_RenderTargetReserved = 0x000FC000, +- MixerPref9_RenderTargetMask = 0x000FF000 ++ MixerPref9_RenderTargetMask = 0x000FF000, + MixerPref9_DynamicSwitchToBOB = 0x00100000, + MixerPref9_DynamicDecimateBy2 = 0x00200000, + MixerPref9_DynamicReserved = 0x00C00000, +@@ -128,7 +132,7 @@ + HMONITOR hMon; + DWORD dwFlags; + wchar_t szDevice[32]; +- wchar_t szDescription[512] ++ wchar_t szDescription[512]; + LARGE_INTEGER liDriverVersion; + DWORD dwVendorId; + DWORD dwDeviceId; +@@ -181,7 +185,6 @@ + VMR9Frequency InputSampleFreq; + VMR9Frequency OutputFrameFreq; + } VMR9VideoDesc; +-/********** + typedef struct VMR9VideoStreamInfo{ + IDirect3DSurface9 *pddsVideoSurface; + DWORD dwWidth; +@@ -203,8 +206,64 @@ + COLORREF clrSrcKey; + DWORD dwFilterMode; + }; +-**********/ +- ++#define INTERFACE IVMRImageCompositor9 ++DECLARE_INTERFACE_(IVMRImageCompositor9, IUnknown) ++{ ++ STDMETHOD(InitCompositionDevice)(THIS_ IUnknown *) PURE; ++ STDMETHOD(TermCompositionDevice)(THIS_ IUnknown *) PURE; ++ STDMETHOD(SetStreamMediaType)(THIS_ DWORD, AM_MEDIA_TYPE *, BOOL) PURE; ++ STDMETHOD(CompositeImage)(THIS_ IUnknown *, IDirect3DSurface9 *, AM_MEDIA_TYPE *, ++ REFERENCE_TIME, REFERENCE_TIME, D3DCOLOR, VMR9VideoStreamInfo *, UINT) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IVMRFilterConfig9 ++DECLARE_INTERFACE_(IVMRFilterConfig9, IUnknown) ++{ ++ STDMETHOD(SetImageCompositor)(THIS_ IVMRImageCompositor9 *) PURE; ++ STDMETHOD(SetNumberOfStreams)(THIS_ DWORD) PURE; ++ STDMETHOD(GetNumberOfStreams)(THIS_ DWORD *) PURE; ++ STDMETHOD(SetRenderingPrefs)(THIS_ DWORD) PURE; ++ STDMETHOD(GetRenderingPrefs)(THIS_ DWORD *) PURE; ++ STDMETHOD(SetRenderingMode)(THIS_ DWORD) PURE; ++ STDMETHOD(GetRenderingMode)(THIS_ DWORD *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IVMRWindowlessControl9 ++DECLARE_INTERFACE_(IVMRWindowlessControl9, IUnknown) ++{ ++ STDMETHOD(GetNativeVideoSize)(THIS_ LONG *, LONG *, LONG *, LONG *) PURE; ++ STDMETHOD(GetMinIdealVideoSize)(THIS_ LONG *, LONG *) PURE; ++ STDMETHOD(GetMaxIdealVideoSize)(THIS_ LONG *, LONG *) PURE; ++ STDMETHOD(SetVideoPosition)(THIS_ const LPRECT, const LPRECT) PURE; ++ STDMETHOD(GetVideoPosition)(THIS_ LPRECT, LPRECT) PURE; ++ STDMETHOD(GetAspectRatioMode)(THIS_ DWORD *) PURE; ++ STDMETHOD(SetAspectRatioMode)(THIS_ DWORD) PURE; ++ STDMETHOD(SetVideoClippingWindow)(THIS_ HWND) PURE; ++ STDMETHOD(RepaintVideo)(THIS_ HWND, HDC) PURE; ++ STDMETHOD(DisplayModeChanged)(THIS) PURE; ++ STDMETHOD(GetCurrentImage)(THIS_ BYTE **) PURE; ++ STDMETHOD(SetBorderColor)(THIS_ COLORREF) PURE; ++ STDMETHOD(GetBorderColor)(THIS_ COLORREF *) PURE; ++}; ++#undef INTERFACE ++#define INTERFACE IVMRMixerControl9 ++DECLARE_INTERFACE_(IVMRMixerControl9, IUnknown) ++{ ++ STDMETHOD(SetAlpha)(THIS_ DWORD, float) PURE; ++ STDMETHOD(GetAlpha)(THIS_ DWORD, float *) PURE; ++ STDMETHOD(SetZOrder)(THIS_ DWORD, DWORD) PURE; ++ STDMETHOD(GetZOrder)(THIS_ DWORD, DWORD *) PURE; ++ STDMETHOD(SetOutputRect)(THIS_ DWORD, const VMR9NormalizedRect *) PURE; ++ STDMETHOD(GetOutputRect)(THIS_ DWORD, VMR9NormalizedRect *) PURE; ++ STDMETHOD(SetBackgroundClr)(THIS_ COLORREF) PURE; ++ STDMETHOD(GetBackgroundClr)(THIS_ COLORREF *) PURE; ++ STDMETHOD(SetMixingPrefs)(THIS_ DWORD) PURE; ++ STDMETHOD(GetMixingPrefs)(THIS_ DWORD *) PURE; ++ STDMETHOD(SetProcAmpControl)(THIS_ DWORD, VMR9ProcAmpControl *) PURE; ++ STDMETHOD(GetProcAmpControl)(THIS_ DWORD, VMR9ProcAmpControl *) PURE; ++ STDMETHOD(GetProcAmpControlRange)(THIS_ DWORD, VMR9ProcAmpControlRange *) PURE; ++}; ++#undef INTERFACE + #ifdef __cplusplus + } + #endif |