summaryrefslogtreecommitdiffstats
path: root/sdk/dx8sdk/Include/DShowIDL/axextend.idl
diff options
context:
space:
mode:
Diffstat (limited to 'sdk/dx8sdk/Include/DShowIDL/axextend.idl')
-rw-r--r--sdk/dx8sdk/Include/DShowIDL/axextend.idl5169
1 files changed, 0 insertions, 5169 deletions
diff --git a/sdk/dx8sdk/Include/DShowIDL/axextend.idl b/sdk/dx8sdk/Include/DShowIDL/axextend.idl
deleted file mode 100644
index 257fb19a..00000000
--- a/sdk/dx8sdk/Include/DShowIDL/axextend.idl
+++ /dev/null
@@ -1,5169 +0,0 @@
-//------------------------------------------------------------------------------
-// File: AXExtend.idl
-//
-// Desc: Extended streaming interface definitions for the ActiveMovie
-// streaming and synchronization architecture. Core streaming
-// interfaces are in AXCore.idl, and control interfaces for the
-// type library are in Control.odl.
-//
-// Copyright (c) 1992 - 2000, Microsoft Corporation. All rights reserved.
-//------------------------------------------------------------------------------
-
-
-// include after unknwn.idl, objidl.idl and axcore.idl
-
-
-// forward declarations - these are the interfaces declared in this file
-
-interface IEnumRegFilters;
-interface IFileSourceFilter;
-interface IFileSinkFilter;
-interface IFileSinkFilter2;
-interface IGraphBuilder;
-interface ICaptureGraphBuilder;
-interface ICaptureGraphBuilder2;
-interface IAMCopyCaptureFileProgress;
-interface IFilterMapper;
-interface IFilterMapper2;
-interface IMediaEventSink;
-interface IOverlay;
-interface IOverlayNotify;
-interface IOverlayNotify2;
-interface IQualityControl;
-interface ISeekingPassThru;
-interface IAMStreamConfig;
-interface IAMDevMemoryAllocator;
-interface IAMDevMemoryControl;
-interface IConfigInterleaving;
-interface IConfigAviMux;
-interface IAMVideoCompression;
-interface IAMVfwCaptureDialogs;
-interface IAMVfwCompressDialogs;
-interface IAMDroppedFrames;
-interface IAMAudioInputMixer;
-interface IAMBufferNegotiation;
-interface IAMAnalogVideoDecoder;
-interface IAMVideoProcAmp;
-interface IAMAnalogVideoEncoder;
-interface IAMCameraControl;
-interface IAMCrossbar;
-interface IAMTVTuner;
-interface IKsPropertySet;
-interface IAMPhysicalPinInfo;
-interface IAMExtDevice;
-interface IAMExtTransport;
-interface IAMTimecodeReader;
-interface IAMTimecodeGenerator;
-interface IAMTimecodeDisplay;
-interface IDrawVideoImage;
-interface IDecimateVideoImage;
-interface IAMVideoDecimationProperties;
-interface IAMPushSource;
-interface IAMAudioRendererStats;
-interface IAMLatency;
-interface IAMGraphStreams;
-interface IAMOverlayFX;
-interface IAMOpenProgress;
-interface IMpeg2Demultiplexer ;
-interface IMPEG2StreamIdMap ;
-interface IEnumStreamIdMap ;
-interface IAMClockSlave ;
-interface IEncoderAPI;
-interface IVideoEncoder;
-interface IAMGraphBuilderCallback;
-interface IAMCertifiedOutputProtection;
-
-//==========================================================================
-//==========================================================================
-// IEnumRegFilters interface -- enumerates registered filters.
-// enumerator interface returned from IFilterMapper::EnumMatchingFilters().
-// based on IEnum pseudo-template
-//==========================================================================
-//==========================================================================
-
-typedef struct {
- CLSID Clsid; // class id of the filter
- LPWSTR Name; // name of filter
-} REGFILTER;
-
-[
-object,
-uuid(56a868a4-0ad4-11ce-b03a-0020af0ba770),
-pointer_default(unique)
-]
-
-// The point of the mapper is to avoid loading filters. By looking in the
-// registry we can reduce the number of filters which must be loaded and tried.
-// This enumerator returns descriptors of filters (including the GUIDs that
-// CoCreateInstance can instantiate). The filters themselves are not loaded.
-
-interface IEnumRegFilters : IUnknown {
- import "unknwn.idl";
-
- // The caller must use CoTaskMemFree to free each REGFILTER* returned
- // in the array.
- HRESULT Next
- ( [in] ULONG cFilters, // place this many filters...
- [out] REGFILTER ** apRegFilter, // ...in this array of REGFILTER*
- [out] ULONG * pcFetched // actual count passed returned here
- );
-
- // I can't think why anyone would want to skip, so it's not implemented.
- // (anyone who thinks they know what they would be skipping over is probably
- // missing some piece of the jigsaw). This ALWAYS returns E_NOTIMPL.
-
- HRESULT Skip(
- [in] ULONG cFilters
- );
-
- HRESULT Reset(void);
-
- // No cloning either - also ALWAYS returns E_NOTIMPL.
-
- HRESULT Clone(
- [out] IEnumRegFilters **ppEnum
- );
-}
-
-
-typedef IEnumRegFilters *PENUMREGFILTERS;
-
-//========================================================================
-//========================================================================
-// abstraction representing the registered information about filters.
-// This allows properties of filters to be looked up without loading them.
-//========================================================================
-//========================================================================
-
-[
-object,
-uuid(56a868a3-0ad4-11ce-b03a-0020af0ba770),
-pointer_default(unique)
-]
-interface IFilterMapper : IUnknown {
- import "unknwn.idl";
-
- //==========================================================================
- // Registration functions.
- // A filter should be registered before any other use.
- // The registration can be NON_VOLATILE (i.e. permanent, do once ever)
- // or VOLATILE (once per boot of the system).
- // UnregisterFilter (obviously) removes the registration.
- // The action of any of the other calls on unregistered filters is undefined.
- // it will either work or you'll get an error, but I'm not saying which.
- //==========================================================================
-
- // Four predefined values controling the order in which filters are tried
- // for intelligent graph building. Intermediate values are legal.
- // Any value <=MERIT_DO_NOT_USE will mean that the filter will never
- // be tried by the filtergrah to automatically complete a connection.
-
- enum { MERIT_PREFERRED = 0x800000,
- MERIT_NORMAL = 0x600000,
- MERIT_UNLIKELY = 0x400000,
- MERIT_DO_NOT_USE = 0x200000,
- MERIT_SW_COMPRESSOR = 0x100000,
- MERIT_HW_COMPRESSOR = 0x100050
- };
-
- // Register a filter
-
- HRESULT RegisterFilter
- ( [in] CLSID clsid, // GUID of the filter
- [in] LPCWSTR Name, // Descriptive name for the filter
- [in] DWORD dwMerit // DO_NOT_USE, UNLIKELY, NORMAL or PREFERRED.
- );
-
-
- // Register an identifiable instance of a filter. This deals with cases
- // such as two similar sound cards which are driven by the same driver,
- // but we want to choose which oif these cards the sound will come out of.
- // This is not needed if there is only one instance of the filter
- // (e.g. there is only one sound card in the machine) or if all instances
- // of the filter are equivalent.
-
- // The filter itself must have already been registered // ??? Is that true?
- HRESULT RegisterFilterInstance
- ( [in] CLSID clsid, // GUID of the filter
- [in] LPCWSTR Name, // Descriptive name of instance.
- [out] CLSID *MRId // Returned Media Resource Id. A
- // locally unique id for this instance
- // of this filter
- );
-
-
- HRESULT RegisterPin
- ( [in] CLSID Filter, // GUID of filter
- [in] LPCWSTR Name, // Name of the pin
- [in] BOOL bRendered, // The filter renders this input
- [in] BOOL bOutput, // TRUE if this is an Output pin
- [in] BOOL bZero, // TRUE if OK for zero instances of pin
- // In this case you will have to Create
- // a pin to have even one instance
- [in] BOOL bMany, // TRUE if OK for many instances of pin
- [in] CLSID ConnectsToFilter, // Filter it connects to if it has
- // subterranean connection, else NULL
- [in] LPCWSTR ConnectsToPin // Name of pin it connects to
- // NULL for output pins
- );
-
- HRESULT RegisterPinType
- ( [in] CLSID clsFilter, // GUID of filter
- [in] LPCWSTR strName, // Descriptive name of the pin
- [in] CLSID clsMajorType, // Major type of the data stream
- [in] CLSID clsSubType // Sub type of the data stream
- );
-
-
- HRESULT UnregisterFilter
- ( [in] CLSID Filter // GUID of filter
- );
-
-
- HRESULT UnregisterFilterInstance
- ( [in] CLSID MRId // Media Resource Id of this instance
- );
-
-
- HRESULT UnregisterPin
- ( [in] CLSID Filter, // GUID of filter
- [in] LPCWSTR Name // Name of the pin
- );
-
-
- // Set *ppEnum to be an enumerator for filters matching the requirements.
-
- HRESULT EnumMatchingFilters
- ( [out] IEnumRegFilters **ppEnum // enumerator returned
- , [in] DWORD dwMerit // at least this merit needed
- , [in] BOOL bInputNeeded // need at least one input pin
- , [in] CLSID clsInMaj // input major type
- , [in] CLSID clsInSub // input sub type
- , [in] BOOL bRender // must the input be rendered?
- , [in] BOOL bOututNeeded // need at least one output pin
- , [in] CLSID clsOutMaj // output major type
- , [in] CLSID clsOutSub // output sub type
- );
-
-}
-
-// structure used to identify media types a pin handles. Used for
-// registration through IFilterMapper and IFilterMapper2
-//
-typedef struct
-{
- const CLSID * clsMajorType;
- const CLSID * clsMinorType;
-} REGPINTYPES;
-
-// describes pin for filter registration. Used for registration
-// through IFilterMapper and IFilterMapper2
-//
-typedef struct
-{
- LPWSTR strName;
-
- // The filter renders this input
- BOOL bRendered;
-
- // This is an Output pin
- BOOL bOutput;
-
- // OK to have zero instances of pin In this case you will have to
- // Create a pin to have even one instance
- BOOL bZero;
-
- // OK to create many instance of pin
- BOOL bMany;
-
- const CLSID * clsConnectsToFilter;
- const WCHAR * strConnectsToPin;
-
- UINT nMediaTypes;
- const REGPINTYPES * lpMediaType;
-} REGFILTERPINS;
-
-// mediums (as defined in the Windows NT DDK) for registration with
-// IFilterMapper2
-//
-typedef struct
-{
- CLSID clsMedium;
- DWORD dw1;
- DWORD dw2;
-} REGPINMEDIUM;
-
-// flags for dwFlags in REFILTERPINS2
-enum
-{
- // OK to have zero instances of pin In this case you will have to
- // Create a pin to have even one instance
- REG_PINFLAG_B_ZERO = 0x1,
-
- // The filter renders this input
- REG_PINFLAG_B_RENDERER = 0x2,
-
- // OK to create many instance of pin
- REG_PINFLAG_B_MANY = 0x4,
-
- // This is an Output pin
- REG_PINFLAG_B_OUTPUT = 0x8
-};
-
-
-// describes pin for filter registration through IFilterMapper2
-typedef struct
-{
- // combination of REG_PINFLAG flags
- DWORD dwFlags;
-
- // number of instances of the pin if known
- UINT cInstances;
-
- UINT nMediaTypes;
- [size_is(nMediaTypes)] const REGPINTYPES * lpMediaType;
-
- UINT nMediums;
- [size_is(nMediums)] const REGPINMEDIUM *lpMedium;
-
- // pin category (for Kernel Streaming pins) as defined in the
- // Windows NT DDK
- const CLSID *clsPinCategory;
-
-} REGFILTERPINS2;
-
-// describes filter for registration through IFilterMapper2
-typedef struct
-{
- DWORD dwVersion; // 1 or 2
- DWORD dwMerit;
-
- /* unnamed union */
- [switch_is(dwVersion)] [switch_type(DWORD)] union
- {
- [case(1)]
-
- struct
- {
- ULONG cPins;
- [size_is(cPins)] const REGFILTERPINS *rgPins;
- };
-
- [case(2)]
-
- struct
- {
- ULONG cPins2;
- [size_is(cPins2)] const REGFILTERPINS2 *rgPins2;
- };
-
- [default]
- ;
- } ;
-
-} REGFILTER2;
-
-
-
-[
-object,
-uuid(b79bb0b0-33c1-11d1-abe1-00a0c905f375),
-pointer_default(unique)
-]
-interface IFilterMapper2 : IUnknown {
- import "unknwn.idl";
-
- // create or rename ActiveMovie category
- HRESULT CreateCategory
- ( [in] REFCLSID clsidCategory,
- [in] DWORD dwCategoryMerit,
- [in] LPCWSTR Description
- );
-
- HRESULT UnregisterFilter
- ( [in] const CLSID *pclsidCategory,
- [in] const OLECHAR *szInstance,
- [in] REFCLSID Filter // GUID of filter
- );
-
- // Register a filter, pins, and media types under a category.
- HRESULT RegisterFilter
- ( [in] REFCLSID clsidFilter, // GUID of the filter
- [in] LPCWSTR Name, // Descriptive name for the filter
-
- // ppMoniker can be null. or *ppMoniker can contain the
- // moniker where this filter data will be written;
- // *ppMoniker will be set to null on return. or *ppMoniker
- // can be null in which case the moniker will be returned
- // with refcount.
- [in, out] IMoniker **ppMoniker,
-
- // can be null
- [in] const CLSID *pclsidCategory,
-
- // cannot be null
- [in] const OLECHAR *szInstance,
-
- // rest of filter and pin registration
- [in] const REGFILTER2 *prf2
- );
-
- // Set *ppEnum to be an enumerator for filters matching the
- // requirements.
- HRESULT EnumMatchingFilters
- ( [out] IEnumMoniker **ppEnum // enumerator returned
- , [in] DWORD dwFlags // 0
- , [in] BOOL bExactMatch // don't match wildcards
- , [in] DWORD dwMerit // at least this merit needed
- , [in] BOOL bInputNeeded // need at least one input pin
- , [in] DWORD cInputTypes // Number of input types to match
- // Any match is OK
- , [size_is(cInputTypes*2)] const GUID *pInputTypes // input major+subtype pair array
- , [in] const REGPINMEDIUM *pMedIn // input medium
- , [in] const CLSID *pPinCategoryIn // input pin category
- , [in] BOOL bRender // must the input be rendered?
- , [in] BOOL bOutputNeeded // need at least one output pin
- , [in] DWORD cOutputTypes // Number of output types to match
- // Any match is OK
- , [size_is(cOutputTypes*2)] const GUID *pOutputTypes // output major+subtype pair array
- , [in] const REGPINMEDIUM *pMedOut // output medium
- , [in] const CLSID *pPinCategoryOut // output pin category
- );
-}
-
-[
-object,
-uuid(b79bb0b1-33c1-11d1-abe1-00a0c905f375),
-pointer_default(unique)
-]
-interface IFilterMapper3 : IFilterMapper2 {
- // new interface to allow creating filters using the mapper's devenum instance
- // primarily needed for out-of-proc access to a graph
- HRESULT GetICreateDevEnum( [out] ICreateDevEnum **ppEnum );
-}
-
-//========================================================================
-//========================================================================
-// Defines IQualityControl interface
-//
-// Defines quality messages and allows a quality manager to install itself
-// as the sink for quality messages.
-//========================================================================
-//========================================================================
-
-typedef enum tagQualityMessageType {
- Famine,
- Flood
-} QualityMessageType;
-
-typedef struct tagQuality {
- QualityMessageType Type;
- long Proportion; // milli-units. 1000 = no change
- // for Flood:
- // What proportion of the media samples currently
- // coming through are required in the future.
- // 800 means please drop another 20%
- // For Famine:
- // How much to "keep in" e.g. 800 means send me
- // 20% less e.g. by dropping 20% of the samples.
- // 1100 would mean "I'm coping, send me more".
- REFERENCE_TIME Late;
- // How much you need to catch up by
- REFERENCE_TIME TimeStamp;
- // The stream time when this was generated (probably
- // corresponds to the start time on some sample).
-} Quality;
-
-typedef IQualityControl *PQUALITYCONTROL;
-
-
-[
-object,
-uuid(56a868a5-0ad4-11ce-b03a-0020af0ba770),
-pointer_default(unique)
-]
-interface IQualityControl : IUnknown {
-
- // Notify the recipient that a quality change is requested.
- // pSelf is the IBaseFilter* of the sender.
- // this is sent from a filter
- // to (the quality manager or) an upstream peer.
- HRESULT Notify
- ( [in] IBaseFilter * pSelf,
- [in] Quality q
- );
-
- // Notify the recipient that future quality messages are to be sent
- // to iqc. If piqc is NULL then quality messages are to default back to
- // the upstream peer.
- // This is sent from the quality manager to a filter.
- // The recipient should hold piqc as a WEAK reference,
- // i.e. do not AddRef it, do not Release it.
- HRESULT SetSink
- ( [in] IQualityControl * piqc
- );
-}
-
-//=====================================================================
-//=====================================================================
-// Definitions required for overlay transport
-//=====================================================================
-//=====================================================================
-
-
-// Used to communicate the colour that the IOverlay client wants the window
-// painted in so that it can draw directly to the correct clipping region
-// A colour key can be described in two alternate ways, the first is by a
-// range of one or more (system) palette indices. The second is by defining
-// a colour cube with two RGB values, any of which would be acceptable.
-//
-// The CK values are consistent with GDI PALETTEINDEX and PALETTERGB macros
-
-
-enum { CK_NOCOLORKEY = 0x0, // No color key is required
- CK_INDEX = 0x1, // Index into the current system palette
- CK_RGB = 0x2 }; // Color key is an RGB value (or range)
-
-typedef struct tagCOLORKEY {
-
- DWORD KeyType; // Explains meaning of the structure
- DWORD PaletteIndex; // Palette index if available
- COLORREF LowColorValue; // Low colour space RGB value
- COLORREF HighColorValue; // Defines the high RGB value
-
-} COLORKEY;
-
-// When a filter sets up an advise link it can ask that only certain types
-// of notifications be sent, for example just palette changes. While this
-// doesn't mean that the other notification call backs won't ever be called
-// the IOverlay implementation may use this as an efficiency optimisation
-
-enum { ADVISE_NONE = 0x0, // No notifications required
- ADVISE_CLIPPING = 0x1, // Synchronous clip information
- ADVISE_PALETTE = 0x2, // Palette change notifications
- ADVISE_COLORKEY = 0x4, // Called when colour key changes
- ADVISE_POSITION = 0x8, // Likewise when window moves etc
- ADVISE_DISPLAY_CHANGE = 0x10 // Called on WM_DISPLAYCHANGE
- };
-
-const DWORD ADVISE_ALL = ADVISE_CLIPPING |
- ADVISE_PALETTE |
- ADVISE_COLORKEY |
- ADVISE_POSITION;
-
-const DWORD ADVISE_ALL2 = ADVISE_ALL |
- ADVISE_DISPLAY_CHANGE;
-
-// This isn't defined when you run IDL
-
-cpp_quote("#ifndef _WINGDI_")
-
-typedef struct _RGNDATAHEADER {
- DWORD dwSize;
- DWORD iType;
- DWORD nCount;
- DWORD nRgnSize;
- RECT rcBound;
-} RGNDATAHEADER;
-
-typedef struct _RGNDATA {
- RGNDATAHEADER rdh;
- char Buffer[1];
-} RGNDATA;
-
-cpp_quote("#endif")
-
-
-//=====================================================================
-//=====================================================================
-// Defines IOverlayNotify interface
-//
-// This interface gives asynchronous notifications of changes to the
-// rendering window - such as changes to the exposed window area
-//=====================================================================
-//=====================================================================
-
-[
-object,
-local,
-uuid(56a868a0-0ad4-11ce-b03a-0020af0ba770),
-pointer_default(unique)
-]
-interface IOverlayNotify : IUnknown {
-
- // IOverlayNotify methods
-
- // This notifies the filter of palette changes, the filter should copy
- // the array of RGBQUADs if it needs to use them after returning. This
- // is not called when the palette is actually changed in the display
- // but at a short time after (in sync with WM_PALETTECHANGED messages)
-
- HRESULT OnPaletteChange(
- [in] DWORD dwColors, // Number of colours present
- [in] const PALETTEENTRY *pPalette); // Array of palette colours
-
- // This provides synchronous clip changes so that the client is called
- // before the window is moved to freeze the video, and then when the
- // window has stabilised it is called again to start playback again.
- // If the window rect is all zero then the window is invisible, the
- // filter must take a copy of the information if it wants to keep it
-
- HRESULT OnClipChange(
- [in] const RECT *pSourceRect, // Region of video to use
- [in] const RECT *pDestinationRect, // Where video goes
- [in] const RGNDATA *pRgnData); // Defines clipping information
-
- HRESULT OnColorKeyChange([in] const COLORKEY *pColorKey);
-
- // The calls to OnClipChange happen in sync with the window. So it is
- // called with an empty clip list before the window moves to freeze
- // the video, and then when the window has stabilised it is called
- // again with the new clip list. The OnPositionChange callback is for
- // overlay cards that don't want the expense of synchronous clipping
- // updates and just want to know when the source or destination video
- // positions change. They will NOT be called in sync with the window
- // but at some point after the window has changed (basicly in time
- // with WM_SIZE etc messages received). This is therefore suitable
- // for overlay cards that don't inlay their data to the frame buffer
- // NOTE the destination is NOT clipped to the visible display area
-
- HRESULT OnPositionChange([in] const RECT *pSourceRect,
- [in] const RECT *pDestinationRect);
-}
-
-typedef IOverlayNotify *POVERLAYNOTIFY;
-
-
-//=====================================================================
-//=====================================================================
-// Defines IOverlayNotify2 interface
-//
-// This interface gives asynchronous notifications of changes to the
-// rendering window - such as changes to the exposed window area
-// This is optionally supported by the advise sink for the purposes
-// of accepting OnDisplayChange notification.
-//=====================================================================
-//=====================================================================
-
-cpp_quote("#if !defined(HMONITOR_DECLARED) && !defined(HMONITOR) && (WINVER < 0x0500)")
-cpp_quote("#define HMONITOR_DECLARED")
-cpp_quote("#if 0")
-typedef HANDLE HMONITOR;
-cpp_quote("#endif")
-cpp_quote("DECLARE_HANDLE(HMONITOR);")
-cpp_quote("#endif")
-
-[
-object,
-local,
-uuid(680EFA10-D535-11D1-87C8-00A0C9223196),
-pointer_default(unique)
-]
-interface IOverlayNotify2 : IOverlayNotify {
-
- // IOverlayNotify2 methods
-
- HRESULT OnDisplayChange( // ADVISE_DISPLAY_CHANGE
- HMONITOR hMonitor);
-}
-
-typedef IOverlayNotify2 *POVERLAYNOTIFY2;
-
-
-//=====================================================================
-//=====================================================================
-// Defines IOverlay interface
-//
-// This interface provides information so that a filter can write direct to
-// the frame buffer while placing the video in the correct window position
-//=====================================================================
-//=====================================================================
-
-[
-object,
-local,
-uuid(56a868a1-0ad4-11ce-b03a-0020af0ba770),
-pointer_default(unique)
-]
-interface IOverlay : IUnknown {
-
- // IOverlay methods
-
- HRESULT GetPalette(
- [out] DWORD *pdwColors, // Number of colours present
- [out] PALETTEENTRY **ppPalette); // Where to put palette data
-
- HRESULT SetPalette(
- [in] DWORD dwColors, // Number of colours present
- [in] PALETTEENTRY *pPalette); // Colours to use for palette
-
- // If you change the colour key through SetColorKey then all the advise
- // links will receive an OnColorKeyChange callback with the new colour
-
- HRESULT GetDefaultColorKey([out] COLORKEY *pColorKey);
- HRESULT GetColorKey([out] COLORKEY *pColorKey);
- HRESULT SetColorKey([in,out] COLORKEY *pColorKey);
- HRESULT GetWindowHandle([out] HWND *pHwnd);
-
- // The IOverlay implementation allocates the memory for the clipping
- // rectangles as it can be variable in length. The filter calling
- // this method should free the memory when it is finished with it
-
- HRESULT GetClipList([out] RECT *pSourceRect,
- [out] RECT *pDestinationRect,
- [out] RGNDATA **ppRgnData);
-
- // Returns the current video source and destination
-
- HRESULT GetVideoPosition([out] RECT *pSourceRect,
- [out] RECT *pDestinationRect);
-
- HRESULT Advise(
- [in] IOverlayNotify *pOverlayNotify, // Notification interface
- [in] DWORD dwInterests); // Callbacks interested in
-
- HRESULT Unadvise(); // Stop the callbacks now
-}
-
-typedef IOverlay *POVERLAY;
-
-
-//=====================================================================
-//=====================================================================
-// control related interfaces (others are defined in control.odl)
-//=====================================================================
-//=====================================================================
-
-
-//=====================================================================
-//=====================================================================
-// Defines IMediaEventSink interface
-//
-// Exposed by filtergraph. Called by filters to notify events. Will be
-// passed on to application by the IMediaControl event methods.
-//=====================================================================
-//=====================================================================
-
-[
- object,
- uuid(56a868a2-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IMediaEventSink : IUnknown {
-
- // notify an event. will be queued, but not delivered to
- // the application on this thread.
- HRESULT Notify(
- [in] long EventCode,
- [in] LONG_PTR EventParam1,
- [in] LONG_PTR EventParam2
- );
-}
-
-typedef IMediaEventSink *PMEDIAEVENTSINK;
-
-//=====================================================================
-//=====================================================================
-// Defines IFileSourceFilter interface
-//
-// Exposed by source filters to set the file name and media type.
-//=====================================================================
-//=====================================================================
-
-[
- object,
- uuid(56a868a6-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IFileSourceFilter : IUnknown {
-
- // Load a file and assign it the given media type
- HRESULT Load(
- [in] LPCOLESTR pszFileName, // Pointer to absolute path of file to open
- [in, unique] const AM_MEDIA_TYPE *pmt // Media type of file - can be NULL
- );
- // Get the currently loaded file name
- HRESULT GetCurFile(
- [out] LPOLESTR *ppszFileName, // Pointer to the path for the current file
- [out] AM_MEDIA_TYPE *pmt // Pointer to the media type
- );
-}
-
-typedef IFileSourceFilter *PFILTERFILESOURCE;
-
-//=====================================================================
-//=====================================================================
-// Defines IFileSinkFilter interface
-//
-// Exposed by renderers to set the output file name.
-//=====================================================================
-//=====================================================================
-
-[
- object,
- uuid(a2104830-7c70-11cf-8bce-00aa00a3f1a6),
- pointer_default(unique)
-]
-interface IFileSinkFilter : IUnknown {
-
- // Output to this file. default is to open the existing file
- HRESULT SetFileName(
- [in] LPCOLESTR pszFileName, // Pointer to absolute path of output file
- [in, unique] const AM_MEDIA_TYPE *pmt // Media type of file - can be NULL
- );
- // Get the current file name
- HRESULT GetCurFile(
- [out] LPOLESTR *ppszFileName, // Pointer to the path for the current file
- [out] AM_MEDIA_TYPE *pmt // Pointer to the media type
- );
-}
-
-typedef IFileSinkFilter *PFILTERFILESINK;
-
-[
- object,
- uuid(00855B90-CE1B-11d0-BD4F-00A0C911CE86),
- pointer_default(unique)
-]
-interface IFileSinkFilter2 : IFileSinkFilter {
-
- HRESULT SetMode(
- [in] DWORD dwFlags // AM_FILESINK_FLAGS
- );
-
- HRESULT GetMode(
- [out] DWORD *pdwFlags // AM_FILESINK_FLAGS
- );
-}
-
-typedef IFileSinkFilter2 *PFILESINKFILTER2;
-
-typedef enum {
-
- // create a new file
- AM_FILE_OVERWRITE = 0x00000001,
-
-} AM_FILESINK_FLAGS;
-
-
-//
-// Intelligent connectivity for filters - an interface supported by
-// filter graphs (since it is an extension to IFilterGraph) that supports
-// building of graphs by automatic selection and connection of appropriate
-// filters
-
-[
- object,
- uuid(56a868a9-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IGraphBuilder : IFilterGraph {
- // Connect these two pins directly or indirectly, using transform filters
- // if necessary.
-
- HRESULT Connect
- ( [in] IPin * ppinOut, // the output pin
- [in] IPin * ppinIn // the input pin
- );
-
-
- // Connect this output pin directly or indirectly, using transform filters
- // if necessary to something that will render it.
-
- HRESULT Render
- ( [in] IPin * ppinOut // the output pin
- );
-
-
- // Build a filter graph that will render this file using this play list.
- // If lpwstrPlayList is NULL then it will use the default play list
- // which will typically render the whole file.
-
- HRESULT RenderFile
- ( [in] LPCWSTR lpcwstrFile,
- [in, unique] LPCWSTR lpcwstrPlayList
- );
-
-
- // Add to the filter graph a source filter for this file. This would
- // be the same source filter that would be added by calling Render.
- // This call gives you more control over building
- // the rest of the graph, e.g. AddFilter(<a renderer of your choice>)
- // and then Connect the two.
- // The IBaseFilter* interface exposed by the source filter is returned
- // in ppFilter, addrefed already for you
- // The filter will be known by the name lpcwstrFIlterName
- // nn this filter graph,
- HRESULT AddSourceFilter
- ( [in] LPCWSTR lpcwstrFileName,
- [in, unique] LPCWSTR lpcwstrFilterName,
- [out] IBaseFilter* *ppFilter
- );
-
-
- // If this call is made then trace information will be written to the
- // file showing the actions taken in attempting to perform an operation.
- HRESULT SetLogFile
- ( [in] DWORD_PTR hFile // open file handle e.g. from CreateFile
- );
-
-
- // Request that the graph builder should return as soon as possible from
- // its current task.
- // Note that it is possible fot the following to occur in the following
- // sequence:
- // Operation begins; Abort is requested; Operation completes normally.
- // This would be normal whenever the quickest way to finish an operation
- // was to simply continue to the end.
- HRESULT Abort();
-
- // Return S_OK if the curent operation is to continue,
- // return S_FALSE if the current operation is to be aborted.
- // This method can be called as a callback from a filter which is doing
- // some operation at the request of the graph.
- HRESULT ShouldOperationContinue();
-
-}
-
-
-//
-// New capture graph builder
-
-[
- object,
- uuid(bf87b6e0-8c27-11d0-b3f0-00aa003761c5),
- pointer_default(unique)
-]
-interface ICaptureGraphBuilder : IUnknown {
-
- // Use this filtergraph
- HRESULT SetFiltergraph(
- [in] IGraphBuilder *pfg);
-
- // what filtergraph are you using?
- // *ppfg->Release() when you're done with it
- HRESULT GetFiltergraph(
- [out] IGraphBuilder **ppfg);
-
- // creates a rendering section in the filtergraph consisting of a MUX
- // of some filetype, and a file writer (and connects them together)
- // *ppf->Release() when you're done with it
- // *ppSink->Release() when you're done with it
- HRESULT SetOutputFileName(
- [in] const GUID *pType, // type of file to write, eg. MEDIASUBTYPE_Avi
- [in] LPCOLESTR lpstrFile, // filename given to file writer
- [out] IBaseFilter **ppf, // returns pointer to the MUX
- [out] IFileSinkFilter **ppSink);// queried from file writer
-
- // Looks for an interface on the filter and on the output pin of the given
- // category. (Categories: CAPTURE/PREVIEW/VIDEOPORT/VBI etc. or
- // NULL for "don't care".
- // It will also look upstream and downstream of
- // the pin for the interface, to find interfaces on renderers, MUXES, TV
- // Tuners, etc.
- // Call *ppint->Release() when you're done with it
- [local] HRESULT FindInterface(
- [in, unique] const GUID *pCategory, // can be NULL for all pins
- [in] IBaseFilter *pf,
- [in] REFIID riid,
- [out] void **ppint);
- [call_as(FindInterface)] HRESULT RemoteFindInterface(
- [in, unique] const GUID *pCategory, // can be NULL for all pins
- [in] IBaseFilter *pf,
- [in] REFIID riid,
- [out] IUnknown **ppint);
-
- // Connects the pin of the given category of the source filter to the
- // rendering filter, optionally through another filter (compressor?)
- // For a non-NULL category, it will instantiate and connect additional
- // required filters upstream too, like TV Tuners and Crossbars.
- // If there is only one output pin on the source, use a NULL
- // category. You can also have pSource be a pin
- HRESULT RenderStream(
- [in] const GUID *pCategory, // can be NULL if only one output pin
- [in] IUnknown *pSource, // filter or pin
- [in] IBaseFilter *pfCompressor,
- [in] IBaseFilter *pfRenderer); // can be NULL
-
- // Sends IAMStreamControl messages to the pin of the desired category, eg.
- // "capture" or "preview"
- // REFERENCE_TIME=NULL means NOW
- // REFERENCE_TIME=MAX_TIME means never, or cancel previous request
- // NULL controls all capture filters in the graph - you will get one
- // notification for each filter with a pin of that category found
- // returns S_FALSE if stop will be signalled before last sample is
- // rendered.
- // return a FAILURE code if the filter does not support IAMStreamControl
- HRESULT ControlStream(
- [in] const GUID *pCategory,
- [in] IBaseFilter *pFilter,
- [in] REFERENCE_TIME *pstart,
- [in] REFERENCE_TIME *pstop,
- [in] WORD wStartCookie, // high word reserved
- [in] WORD wStopCookie); // high word reserved
-
- // creates a pre-allocated file of a given size in bytes
- HRESULT AllocCapFile(
- [in] LPCOLESTR lpstr,
- [in] DWORDLONG dwlSize);
-
- // Copies the valid file data out of the old, possibly huge old capture
- // file into a shorter new file.
- // Return S_FALSE from your progress function to abort capture, S_OK to
- // continue
- HRESULT CopyCaptureFile(
- [in] LPOLESTR lpwstrOld,
- [in] LPOLESTR lpwstrNew,
- [in] int fAllowEscAbort, // pressing ESC will abort?
- [in] IAMCopyCaptureFileProgress *pCallback); // implement this to
- // get progress
-}
-
-
-//
-// Capture graph builder "CopyCapturedFile" progress callback
-
-[
- object,
- uuid(670d1d20-a068-11d0-b3f0-00aa003761c5),
- pointer_default(unique)
-]
-interface IAMCopyCaptureFileProgress : IUnknown {
-
- // If you support this interface somewhere, this function will be called
- // periodically while ICaptureGraphBuilder::CopyCaptureFile is executing
- // to let you know the progress
- //
- // Return S_OK from this function to continue. Return S_FALSE to abort the
- // copy
- HRESULT Progress(
- [in] int iProgress); // a number between 0 and 100 (%)
-}
-
-
-//
-// Capture graph builder that can deal with a single filter having more than
-// one pin of each category... some new devices can capture both audio and
-// video, for example
-//
-
-[
- object,
- uuid(93E5A4E0-2D50-11d2-ABFA-00A0C9C6E38D),
- pointer_default(unique)
-]
-interface ICaptureGraphBuilder2 : IUnknown {
-
- // Use this filtergraph
- HRESULT SetFiltergraph(
- [in] IGraphBuilder *pfg);
-
- // what filtergraph are you using?
- // *ppfg->Release() when you're done with it
- HRESULT GetFiltergraph(
- [out] IGraphBuilder **ppfg);
-
- // creates a rendering section in the filtergraph consisting of a MUX
- // of some filetype, and a file writer (and connects them together)
- // *ppf->Release() when you're done with it
- // *ppSink->Release() when you're done with it
- HRESULT SetOutputFileName(
- [in] const GUID *pType, // GUID of MUX filter to use
- [in] LPCOLESTR lpstrFile, // filename given to file writer
- [out] IBaseFilter **ppf, // returns pointer to the MUX
- [out] IFileSinkFilter **ppSink);// queried from file writer
-
- // Looks for an interface on the filter and on the output pin of the given
- // category and type. (Categories: CAPTURE/PREVIEW/VIDEOPORT/VBI etc. or
- // NULL for "don't care". Type: MAJORTYPE_Video/Audio etc or NULL)
- // !!! Will some filters have >1 capture pin? ie RGB and MPEG?
- // It will also look upstream and downstream of
- // the pin for the interface, to find interfaces on renderers, MUXES, TV
- // Tuners, etc.
- // Call *ppint->Release() when you're done with it
- [local] HRESULT FindInterface(
- [in] const GUID *pCategory, // can be NULL for all pins
- [in] const GUID *pType, // Audio/Video/??? or NULL (don't care)
- [in] IBaseFilter *pf,
- [in] REFIID riid,
- [out] void **ppint);
- [call_as(FindInterface)] HRESULT RemoteFindInterface(
- [in] const GUID *pCategory, // can be NULL for all pins
- [in] const GUID *pType, // Audio/Video/??? or NULL (don't care)
- [in] IBaseFilter *pf,
- [in] REFIID riid,
- [out] IUnknown **ppint);
-
- // Connects the pin of the given category and type of the source filter to
- // the rendering filter, optionally through another filter (compressor?)
- // (Type is a Majortype, like Video or Audio)
- // For a non-NULL category, it will instantiate and connect additional
- // required filters upstream too, like TV Tuners and Crossbars.
- // If there is only one output pin on the source, use a NULL category
- // and type. You can also have pSource be a pin
- HRESULT RenderStream(
- [in] const GUID *pCategory, // can be NULL if only one output pin
- [in] const GUID *pType, // Major type (Video/Audio/etc)
- [in] IUnknown *pSource, // filter or pin
- [in] IBaseFilter *pfCompressor,
- [in] IBaseFilter *pfRenderer); // can be NULL
-
- // Sends IAMStreamControl messages to the pin of the desired category,
- // (eg. "capture" or "preview") and of the desired type (eg. VIDEO or AUDIO)
- // A category MUST be given. If a filter is given, a type must be too.
- // REFERENCE_TIME=NULL means NOW
- // REFERENCE_TIME=MAX_TIME means never, or cancel previous request
- // NULL controls all capture filters in the graph - you will get one
- // notification for each filter with a pin of that category found
- // returns S_FALSE if stop will be signalled before last sample is
- // rendered.
- // return a FAILURE code if the filter does not support IAMStreamControl
- HRESULT ControlStream(
- [in] const GUID *pCategory,
- [in] const GUID *pType, // Major type (Video/Audio/etc)
- [in] IBaseFilter *pFilter,
- [in] REFERENCE_TIME *pstart,
- [in] REFERENCE_TIME *pstop,
- [in] WORD wStartCookie, // high word reserved
- [in] WORD wStopCookie); // high word reserved
-
- // creates a pre-allocated file of a given size in bytes
- HRESULT AllocCapFile(
- [in] LPCOLESTR lpstr,
- [in] DWORDLONG dwlSize);
-
- // Copies the valid file data out of the old, possibly huge old capture
- // file into a shorter new file.
- // Return S_FALSE from your progress function to abort capture, S_OK to
- // continue
- HRESULT CopyCaptureFile(
- [in] LPOLESTR lpwstrOld,
- [in] LPOLESTR lpwstrNew,
- [in] int fAllowEscAbort, // pressing ESC will abort?
- [in] IAMCopyCaptureFileProgress *pCallback); // implement this to
- // get progress
- // Helper fn to find a certain pin on a filter.
- HRESULT FindPin(
- [in] IUnknown *pSource,
- [in] PIN_DIRECTION pindir, // input or output?
- [in] const GUID *pCategory, // what category? (or NULL)
- [in] const GUID *pType, // what Major type (or NULL)
- [in] BOOL fUnconnected, // must it be unconnected?
- [in] int num, // which pin matching this? (0 based)
- [out] IPin **ppPin);
-}
-
-enum _AM_RENSDEREXFLAGS {
- AM_RENDEREX_RENDERTOEXISTINGRENDERERS = 0x01 // Dont add any renderers
-};
-
-//
-// IFilterGraph2
-//
-// New methods on for IFilterGraph and IGraphBuilder will have to go here.
-//
-
-[
- object,
- uuid(36b73882-c2c8-11cf-8b46-00805f6cef60),
- pointer_default(unique)
-]
-interface IFilterGraph2: IGraphBuilder {
-
- // Add a Moniker source moniker
- HRESULT AddSourceFilterForMoniker(
- [in] IMoniker *pMoniker,
- [in] IBindCtx *pCtx,
- [in, unique] LPCWSTR lpcwstrFilterName,
- [out] IBaseFilter **ppFilter
- );
-
- // Specify the type for a reconnect
- // This is better than Reconnect as sometime the parties to a
- // reconnection can't remember what type they'd agreed (!)
- HRESULT ReconnectEx
- ( [in] IPin * ppin, // the pin to disconnect and reconnect
- [in, unique] const AM_MEDIA_TYPE *pmt // the type to reconnect with - can be NULL
- );
-
- // Render a pin without adding any new renderers
- HRESULT RenderEx( [in] IPin *pPinOut, // Pin to render
- [in] DWORD dwFlags, // flags
- [in, out] DWORD *pvContext // Unused - set to NULL
- );
-
-#if 0
- // Method looks for a filter which supports the specified interface. If such
- // a filter exists, an AddRef()'ed pointer to the requested interface is placed
- // in *ppInterface.
- //
- // *ppInterface will be NULL on return if such a filter could not be found, and
- // the method will return E_NOINTERFACE.
- //
- // pdwIndex is an internal index that is used for obtaining subsequent interfaces.
- // *pdwIndex should be initialized to zero. It is set on return to a value that
- // allows the implementation of FindFilterInterface to search for further interfaces
- // if called again. If no more such interfaces exist, the method will return E_NOINTERFACE.
- //
- // If pdwIndex is NULL, FindFilterInterface returns an interface only if there is just
- // a single filter in the graph that supports the interface. Otherwise it returns
- // E_NOINTERFACE.
- //
- HRESULT FindFilterInterface( [in] REFIID iid, [out] void ** ppInterface, [in,out] LPDWORD pdwIndex );
-
- // Tries to obtain the interface from the filter graph itself. If this fails,
- // it attempts to find the unique filter that supports the interface.
- // On failure the method will return E_NOINTERFACE. On success, it returns
- // S_OK and an AddRef()'ed pointer to the requested interface in *ppInterface.
- //
- HRESULT FindInterface( [in] REFIID iid, [out] void ** ppInterface );
-
-#endif
-}
-
-//
-// StreamBuilder
-// aka Graph building with constraints
-// aka convergent graphs
-// aka Closed captioning
-
-[
- object,
- local,
- uuid(56a868bf-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IStreamBuilder : IUnknown {
-
- // Connect this output pin directly or indirectly, using transform filters
- // if necessary to thing(s) that will render it, within this graph
- // Move from Initial state to Rendered state.
-
- HRESULT Render
- ( [in] IPin * ppinOut, // the output pin
- [in] IGraphBuilder * pGraph // the graph
- );
-
- // Undo what you did in Render. Return to Initial state.
- HRESULT Backout
- ( [in] IPin * ppinOut, // the output pin
- [in] IGraphBuilder * pGraph // the graph
- );
-}
-
-
-// async reader interface - supported by file source filters. Allows
-// multiple overlapped reads from different positions
-
-
-[
- object,
- uuid(56a868aa-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IAsyncReader : IUnknown
-{
- // pass in your preferred allocator and your preferred properties.
- // method returns the actual allocator to be used. Call GetProperties
- // on returned allocator to learn alignment and prefix etc chosen.
- // this allocator will be not be committed and decommitted by
- // the async reader, only by the consumer.
- // Must call this before calling Request.
- HRESULT RequestAllocator(
- [in] IMemAllocator* pPreferred,
- [in] ALLOCATOR_PROPERTIES* pProps,
- [out] IMemAllocator ** ppActual);
-
- // queue a request for data.
- // media sample start and stop times contain the requested absolute
- // byte position (start inclusive, stop exclusive).
- // may fail if sample not obtained from agreed allocator.
- // may fail if start/stop position does not match agreed alignment.
- // samples allocated from source pin's allocator may fail
- // GetPointer until after returning from WaitForNext.
- // Stop position must be aligned - this means it may exceed duration.
- // on completion, stop position will be corrected to unaligned
- // actual data.
- HRESULT Request(
- [in] IMediaSample* pSample,
- [in] DWORD_PTR dwUser); // user context
-
- // block until the next sample is completed or the timeout occurs.
- // timeout (millisecs) may be 0 or INFINITE. Samples may not
- // be delivered in order. If there is a read error of any sort, a
- // notification will already have been sent by the source filter,
- // and HRESULT will be an error.
- // If ppSample is not null, then a Request completed with the result
- // code returned.
- HRESULT WaitForNext(
- [in] DWORD dwTimeout,
- [out] IMediaSample** ppSample, // completed sample
- [out] DWORD_PTR * pdwUser); // user context
-
- // sync read of data. Sample passed in must have been acquired from
- // the agreed allocator. Start and stop position must be aligned.
- // equivalent to a Request/WaitForNext pair, but may avoid the
- // need for a thread on the source filter.
- HRESULT SyncReadAligned(
- [in] IMediaSample* pSample);
-
-
- // sync read. works in stopped state as well as run state.
- // need not be aligned. Will fail if read is beyond actual total
- // length.
- HRESULT SyncRead(
- [in] LONGLONG llPosition, // absolute file position
- [in] LONG lLength, // nr bytes required
- [out, size_is(lLength)]
- BYTE* pBuffer); // write data here
-
- // return total length of stream, and currently available length.
- // reads for beyond the available length but within the total length will
- // normally succeed but may block for a long period.
- HRESULT Length(
- [out] LONGLONG* pTotal,
- [out] LONGLONG* pAvailable);
-
- // cause all outstanding reads to return, possibly with a failure code
- //(VFW_E_TIMEOUT) indicating they were cancelled.
- // Between BeginFlush and EndFlush calls, Request calls will fail and
- // WaitForNext calls will always complete immediately.
- HRESULT BeginFlush(void);
- HRESULT EndFlush(void);
-}
-
-
-// interface provided by the filtergraph itself to let other objects
-// (especially plug-in distributors, but also apps like graphedt) know
-// when the graph has changed.
-[
- object,
- uuid(56a868ab-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IGraphVersion : IUnknown
-{
- // returns the current graph version number
- // this is incremented every time there is a change in the
- // set of filters in the graph or in their connections
- //
- // if this is changed since your last enumeration, then re-enumerate
- // the graph
- HRESULT QueryVersion(LONG* pVersion);
-}
-
-
-
-
-//
-// interface describing an object that uses resources.
-//
-// implement if: you request resources using IResourceManager. You will
-// need to pass your implementation of this pointer as an in param.
-//
-// use if: you are a resource manager who implements IResourceManager
-[
- object,
- uuid(56a868ad-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IResourceConsumer : IUnknown
-{
- // you may acquire the resource specified.
- // return values:
- // S_OK -- I have successfully acquired it
- // S_FALSE -- I will acquire it and call NotifyAcquire afterwards
- // VFW_S_NOT_NEEDED: I no longer need the resource
- // FAILED(hr)-I tried to acquire it and failed.
-
- HRESULT
- AcquireResource(
- [in] LONG idResource);
-
-
-
- // Please release the resource.
- // return values:
- // S_OK -- I have released it (and want it again when available)
- // S_FALSE -- I will call NotifyRelease when I have released it
- // other something went wrong.
- HRESULT
- ReleaseResource(
- [in] LONG idResource);
-}
-
-
-
-// interface describing a resource manager that will resolve contention for
-// named resources.
-//
-// implement if: you are a resource manager. The filtergraph will be a resource
-// manager, internally delegating to the system wide resource manager
-// (when there is one)
-//
-// use if: you need resources that are limited. Use the resource manager to
-// resolve contention by registering the resource with this interface,
-// and requesting it from this interface whenever needed.
-//
-// or use if: you detect focus changes which should affect resource usage.
-// Notifying change of focus to the resource manager will cause the resource
-// manager to switch contended resources to the objects that have the user's
-// focus
-[
- object,
- uuid(56a868ac-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IResourceManager : IUnknown
-{
- // tell the manager how many there are of a resource.
- // ok if already registered. will take new count. if new count
- // is lower, will de-allocate resources to new count.
- //
- // You get back a token that will be used in further calls.
- //
- // Passing a count of 0 will eliminate this resource. There is currently
- // no defined way to find the id without knowing the count.
- //
- HRESULT
- Register(
- [in] LPCWSTR pName, // this named resource
- [in] LONG cResource, // has this many instances
- [out] LONG* plToken // token placed here on return
- );
-
- HRESULT
- RegisterGroup(
- [in] LPCWSTR pName, // this named resource group
- [in] LONG cResource, // has this many resources
- [in, size_is(cResource)]
- LONG* palTokens, // these are the contained resources
- [out] LONG* plToken // group resource id put here on return
- );
-
- // request the use of a given, registered resource.
- // possible return values:
- // S_OK == yes you can use it now
- // S_FALSE == you will be called back when the resource is available
- // other - there is an error.
- //
- // The priority of this request should be affected by the associated
- // focus object -- that is, when SetFocus is called for that focus
- // object (or a 'related' object) then my request should be put through.
- //
- // A filter should pass the filter's IUnknown here. The filtergraph
- // will match filters to the filtergraph, and will attempt to trace
- // filters to common source filters when checking focus objects.
- // The Focus object must be valid for the entire lifetime of the request
- // -- until you call CancelRequest or NotifyRelease(id, p, FALSE)
- HRESULT
- RequestResource(
- [in] LONG idResource,
- [in] IUnknown* pFocusObject,
- [in] IResourceConsumer* pConsumer
- );
-
-
- // notify the resource manager that an acquisition attempt completed.
- // Call this method after an AcquireResource method returned
- // S_FALSE to indicate asynchronous acquisition.
- // HR should be S_OK if the resource was successfully acquired, or a
- // failure code if the resource could not be acquired.
- HRESULT
- NotifyAcquire(
- [in] LONG idResource,
- [in] IResourceConsumer* pConsumer,
- [in] HRESULT hr);
-
- // Notify the resource manager that you have released a resource. Call
- // this in response to a ReleaseResource method, or when you have finished
- // with the resource. bStillWant should be TRUE if you still want the
- // resource when it is next available, or FALSE if you no longer want
- // the resource.
- HRESULT
- NotifyRelease(
- [in] LONG idResource,
- [in] IResourceConsumer* pConsumer,
- [in] BOOL bStillWant);
-
- // I don't currently have the resource, and I no longer need it.
- HRESULT
- CancelRequest(
- [in] LONG idResource,
- [in] IResourceConsumer* pConsumer);
-
- // Notify the resource manager that a given object has been given the
- // user's focus. In ActiveMovie, this will normally be a video renderer
- // whose window has received the focus. The filter graph will switch
- // contended resources to (in order):
- // requests made with this same focus object
- // requests whose focus object shares a common source with this
- // requests whose focus object shares a common filter graph
- // After calling this, you *must* call ReleaseFocus before the IUnknown
- // becomes invalid, unless you can guarantee that another SetFocus
- // of a different object is done in the meantime. No addref is held.
- //
- // The resource manager will hold this pointer until replaced or cancelled,
- // and will use it to resolve resource contention. It will call
- // QueryInterface for IBaseFilter at least and if found will call methods on
- // that interface.
- HRESULT
- SetFocus(
- [in] IUnknown* pFocusObject);
-
- // Sets the focus to NULL if the current focus object is still
- // pFocusObject. Call this when
- // the focus object is about to be destroyed to ensure that no-one is
- // still referencing the object.
- HRESULT
- ReleaseFocus(
- [in] IUnknown* pFocusObject);
-
-
-
-// !!! still need
-// -- app override (some form of SetPriority)
-// -- enumeration and description of resources
-
-}
-
-
-//
-// Interface representing an object that can be notified about state
-// and other changes within a filter graph. The filtergraph will call plug-in
-// distributors that expose this optional interface so that they can
-// respond to appropriate changes.
-//
-// Implement if: you are a plug-in distributor (your class id is found
-// under HKCR\Interface\<IID>\Distributor= for some interface).
-//
-// Use if: you are the filtergraph.
-[
- object,
- uuid(56a868af-0ad4-11ce-b03a-0020af0ba770),
- pointer_default(unique)
-]
-interface IDistributorNotify : IUnknown
-{
- // called when graph is entering stop state. Called before
- // filters are stopped.
- HRESULT Stop(void);
-
- // called when graph is entering paused state, before filters are
- // notified
- HRESULT Pause(void);
-
- // called when graph is entering running state, before filters are
- // notified. tStart is the stream-time offset parameter that will be
- // given to each filter's IBaseFilter::Run method.
- HRESULT Run(REFERENCE_TIME tStart);
-
- // called when the graph's clock is changing, with the new clock. Addref
- // the clock if you hold it beyond this method. Called before
- // the filters are notified.
- HRESULT SetSyncSource(
- [in] IReferenceClock * pClock);
-
- // called when the set of filters or their connections has changed.
- // Called on every AddFilter, RemoveFilter or ConnectDirect (or anything
- // that will lead to one of these).
- // You don't need to rebuild your list of interesting filters at this point
- // but you should release any refcounts you hold on any filters that
- // have been removed.
- HRESULT NotifyGraphChange(void);
-}
-
-typedef enum {
- AM_STREAM_INFO_START_DEFINED = 0x00000001,
- AM_STREAM_INFO_STOP_DEFINED = 0x00000002,
- AM_STREAM_INFO_DISCARDING = 0x00000004,
- AM_STREAM_INFO_STOP_SEND_EXTRA = 0x00000010
-} AM_STREAM_INFO_FLAGS;
-
-// Stream information
-typedef struct {
- REFERENCE_TIME tStart;
- REFERENCE_TIME tStop;
- DWORD dwStartCookie;
- DWORD dwStopCookie;
- DWORD dwFlags;
-} AM_STREAM_INFO;
-
-//
-// IAMStreamControl
-//
-
-[
- object,
- uuid(36b73881-c2c8-11cf-8b46-00805f6cef60),
- pointer_default(unique)
-]
-interface IAMStreamControl : IUnknown
-{
- // The REFERENCE_TIME pointers may be null, which
- // indicates immediately. If the pointer is non-NULL
- // and dwCookie is non-zero, then pins should send
- // EC_STREAM_CONTROL_STOPPED / EC_STREAM_CONTROL_STARTED
- // with an IPin pointer and the cookie, thus allowing
- // apps to tie the events back to their requests.
- // If either dwCookies is zero, or the pointer is null,
- // then no event is sent.
-
- // If you have a capture pin hooked up to a MUX input pin and they
- // both support IAMStreamControl, you'll want the MUX to signal the
- // stop so you know the last frame was written out. In order for the
- // MUX to know it's finished, the capture pin will have to send one
- // extra sample after it was supposed to stop, so the MUX can trigger
- // off that. So you would set bSendExtra to TRUE for the capture pin
- // Leave it FALSE in all other cases.
-
- HRESULT StartAt( [in] const REFERENCE_TIME * ptStart,
- [in] DWORD dwCookie );
- HRESULT StopAt( [in] const REFERENCE_TIME * ptStop,
- [in] BOOL bSendExtra,
- [in] DWORD dwCookie );
- HRESULT GetInfo( [out] AM_STREAM_INFO *pInfo);
-}
-
-
-
-//
-// ISeekingPassThru
-//
-
-[
- object,
- uuid(36b73883-c2c8-11cf-8b46-00805f6cef60),
- pointer_default(unique)
-]
-interface ISeekingPassThru : IUnknown
-{
- HRESULT Init( [in] BOOL bSupportRendering,
- [in] IPin *pPin);
-}
-
-
-
-//
-// IAMStreamConfig - pin interface
-//
-
-// A capture filter or compression filter's output pin
-// supports this interface - no matter what data type you produce.
-
-// This interface can be used to set the output format of a pin (as an
-// alternative to connecting the pin using a specific media type).
-// After setting an output format, the pin will use that format
-// the next time it connects to somebody, so you can just Render that
-// pin and get a desired format without using Connect(CMediaType)
-// Your pin should do that by ONLY OFFERING the media type set in SetFormat
-// in its enumeration of media types, and no others. This will ensure that
-// that format is indeed used for connection (or at least offer it first).
-// An application interested in enumerating accepted mediatypes may have to
-// do so BEFORE calling SetFormat.
-
-// But this interface's GetStreamCaps function can get more information
-// about accepted media types than the traditional way of enumerating a pin's
-// media types, so it should typically be used instead.
-// GetStreamCaps gets information about the kinds of formats allowed... how
-// it can stretch and crop, and the frame rate and data rates allowed (for
-// video)
-
-// VIDEO EXAMPLE
-//
-// GetStreamCaps returns a whole array of {MediaType, Capabilities}.
-// Let's say your capture card supports JPEG anywhere between 160x120 and
-// 320x240, and also the size 640x480. Also, say it supports RGB24 at
-// resolutions between 160x120 and 320x240 but only multiples of 8. You would
-// expose these properties by offering a media type of 320 x 240 JPEG
-// (if that is your default or preferred size) coupled with
-// capabilities saying minimum 160x120 and maximum 320x240 with granularity of
-// 1. The next pair you expose is a media type of 640x480 JPEG coupled with
-// capabilities of min 640x480 max 640x480. The third pair is media type
-// 320x240 RGB24 with capabilities min 160x120 max 320x240 granularity 8.
-// In this way you can expose almost every quirk your card might have.
-// An application interested in knowing what compression formats you provide
-// can get all the pairs and make a list of all the unique sub types of the
-// media types.
-//
-// If a filter's output pin is connected with a media type that has rcSource
-// and rcTarget not empty, it means the filter is being asked to stretch the
-// rcSource sub-rectangle of its InputSize (the format of the input pin for
-// a compressor, and the largest bitmap a capture filter can generate with
-// every pixel unique) into the rcTarget sub-rectangle of its output format.
-// For instance, if a video compressor has as input 160x120 RGB, and as output
-// 320x240 MPEG with an rcSource of (10,10,20,20) and rcTarget of (0,0,100,100)
-// this means the compressor is being asked to take a 10x10 piece of the 160x120
-// RGB bitmap, and make it fill the top 100x100 area of a 320x240 bitmap,
-// leaving the rest of the 320x240 bitmap untouched.
-// A filter does not have to support this and can fail to connect with a
-// media type where rcSource and rcTarget are not empty.
-//
-// Your output pin is connected to the next filter with a certain media
-// type (either directly or using the media type passed by SetFormat),
-// and you need to look at the AvgBytesPerSecond field of the format
-// of that mediatype to see what data rate you are being asked to compress
-// the video to, and use that data rate. Using the number of frames per
-// second in AvgTimePerFrame, you can figure out how many bytes each frame
-// is supposed to be. You can make it smaller, but NEVER EVER make a bigger
-// data rate. For a video compressor, your input pin's media type tells you
-// the frame rate (use that AvgTimePerFrame). For a capture filter, the
-// output media type tells you, so use that AvgTimePerFrame.
-//
-// The cropping rectangle described below is the same as the rcSrc of the
-// output pin's media type.
-//
-// The output rectangle described below is the same of the width and height
-// of the BITMAPINFOHEADER of the media type of the output pin's media type
-
-
-// AUDIO EXAMPLE
-//
-// This API can return an array of pairs of (media type, capabilities).
-// This can be used to expose all kinds of wierd capabilities. Let's say you
-// do any PCM frequency from 11,025 to 44,100 at 8 or 16 bit mono or
-// stereo, and you also do 48,000 16bit stereo as a special combination.
-// You would expose 3 pairs. The first pair would have Min Freq of 11025 and
-// Max Freq of 44100, with MaxChannels=2 and MinBits=8 and MaxBits=8 for the
-// capabilites structure, and a media type of anything you like, maybe
-// 22kHz, 8bit stereo as a default.
-// The 2nd pair would be the same except for MinBits=16 and MaxBits=16 in
-// the capabilities structure and the media type could be something like
-// 44kHz, 16bit stereo as a default (the media type in the pair should always
-// be something legal as described by the capabilities structure... the
-// structure tells you how you can change the media type to produce other
-// legal media types... for instance changing 44kHz to 29010Hz would be legal,
-// but changing bits from 16 to 14 would not be.)
-// The 3rd pair would be MinFreq=48000 MaxFreq=48000 MaxChannels=2
-// MinBits=16 and MaxBits=16, and the media type would be 48kHz 16bit stereo.
-// You can also use the Granularity elements of the structure (like the example
-// for video) if you support values that multiples of n, eg. you could say
-// minimum bits per sample 8, max 16, and granularity 8 to describe doing
-// either 8 or 16 bit all in one structure
-//
-// If you support non-PCM formats, the media type returned in GetStreamCaps
-// can show which non-PCM formats you support (with a default sample rate,
-// bit rate and channels) and the capabilities structure going with that
-// media type can describe which other sample rates, bit rates and channels
-// you support.
-
-[
- object,
- uuid(C6E13340-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
-]
-interface IAMStreamConfig : IUnknown
-{
-
- // this is the structure returned by a VIDEO filter
- //
- typedef struct _VIDEO_STREAM_CONFIG_CAPS {
-
- GUID guid; // will be MEDIATYPE_Video
-
- // the logical or of all the AnalogVideoStandard's supported
- // typically zero if not supported
- ULONG VideoStandard;
-
- // the inherent size of the incoming signal... taken from the input
- // pin for a compressor, or the largest size a capture filter can
- // digitize the signal with every pixel still unique
- SIZE InputSize;
-
- // The input of a compressor filter may have to be connected for these
- // to be known
-
- // smallest rcSrc cropping rect allowed
- SIZE MinCroppingSize;
- // largest rcSrc cropping rect allowed
- SIZE MaxCroppingSize;
- // granularity of cropping size - eg only widths a multiple of 4 allowed
- int CropGranularityX;
- int CropGranularityY;
- // alignment of cropping rect - eg rect must start on multiple of 4
- int CropAlignX;
- int CropAlignY;
-
- // The input of a compressor filter may have to be connected for these
- // to be known
-
- // smallest bitmap this pin can produce
- SIZE MinOutputSize;
- // largest bitmap this pin can produce
- SIZE MaxOutputSize;
- // granularity of output bitmap size
- int OutputGranularityX;
- int OutputGranularityY;
- // !!! what about alignment of rcTarget inside BIH if different?
-
- // how well can you stretch in the x direction? 0==not at all
- // 1=pixel doubling 2=interpolation(2 taps) 3=better interpolation
- // etc.
- int StretchTapsX;
- int StretchTapsY;
- // how well can you shrink in the x direction? 0==not at all
- // 1=pixel doubling 2=interpolation(2 taps) 3=better interpolation
- // etc.
- int ShrinkTapsX;
- int ShrinkTapsY;
-
- // CAPTURE filter only - what frame rates are allowed?
- LONGLONG MinFrameInterval;
- LONGLONG MaxFrameInterval;
-
- // what data rates can this pin produce?
- LONG MinBitsPerSecond;
- LONG MaxBitsPerSecond;
- } VIDEO_STREAM_CONFIG_CAPS;
-
-
- // this is the structure returned by an AUDIO filter
- //
- typedef struct _AUDIO_STREAM_CONFIG_CAPS {
-
- GUID guid; // will be MEDIATYPE_Audio
- ULONG MinimumChannels;
- ULONG MaximumChannels;
- ULONG ChannelsGranularity;
- ULONG MinimumBitsPerSample;
- ULONG MaximumBitsPerSample;
- ULONG BitsPerSampleGranularity;
- ULONG MinimumSampleFrequency;
- ULONG MaximumSampleFrequency;
- ULONG SampleFrequencyGranularity;
- } AUDIO_STREAM_CONFIG_CAPS;
-
- // - only allowed when pin is not streaming, else the call will FAIL
- // - If your output pin is not yet connected, and you can
- // connect your output pin with this media type, you should
- // succeed the call, and start offering it first (enumerate as format#0)
- // from GetMediaType so that this format will be used to connect with
- // when you do connect to somebody
- // - if your output pin is already connected, and you can provide this
- // type, reconnect your pin. If the other pin can't accept it, FAIL
- // this call and leave your connection alone.
- HRESULT SetFormat(
- [in] AM_MEDIA_TYPE *pmt);
-
- // the format it's connected with, or will connect with
- // the application is responsible for calling DeleteMediaType(*ppmt);
- HRESULT GetFormat(
- [out] AM_MEDIA_TYPE **ppmt);
-
- // how many different Stream Caps structures are there?
- // also, how big is the stream caps structure?
- HRESULT GetNumberOfCapabilities(
- [out] int *piCount,
- [out] int *piSize); // pSCC of GetStreamCaps needs to be this big
-
- // - gets one of the pairs of {Mediatype, Caps}
- // - return S_FALSE if iIndex is too high
- // - the application is responsible for calling DeleteMediaType(*ppmt);
- // - the first thing pSCC points to is a GUID saying MEDIATYPE_Video
- // or MEDIATYPE_Audio, so you can tell if you have a pointer to a
- // VIDEO_STREAM_CONFIG_CAPS or an AUDIO_STREAM_CONFIG_CAPS structure
- // There could potentially be many more possibilities other than video
- // or audio.
- HRESULT GetStreamCaps(
- [in] int iIndex, // 0 to #caps-1
- [out] AM_MEDIA_TYPE **ppmt,
- [out] BYTE *pSCC);
-
-}
-
-
-
-// Interface to control interleaving of different streams in one file
-[
-object,
-uuid(BEE3D220-157B-11d0-BD23-00A0C911CE86),
-pointer_default(unique)
-]
-interface IConfigInterleaving : IUnknown
-{
- import "unknwn.idl";
-
- typedef enum
- {
- // uninterleaved - samples written out in the order they
- // arrive.
- INTERLEAVE_NONE,
-
- // approximate interleaving with less overhead for video
- // capture
- INTERLEAVE_CAPTURE,
-
- // full, precise interleaving. slower.
- INTERLEAVE_FULL,
-
- // samples written out in the order they arrive. writes are
- // buffered
- INTERLEAVE_NONE_BUFFERED
-
- } InterleavingMode;
-
- HRESULT put_Mode(
- [in] InterleavingMode mode
- );
-
- HRESULT get_Mode(
- [out] InterleavingMode *pMode
- );
-
- HRESULT put_Interleaving(
- [in] const REFERENCE_TIME *prtInterleave,
- [in] const REFERENCE_TIME *prtPreroll
- );
-
- HRESULT get_Interleaving(
- [out] REFERENCE_TIME *prtInterleave,
- [out] REFERENCE_TIME *prtPreroll
- );
-}
-
-// Interface to control the AVI mux
-[
-object,
-uuid(5ACD6AA0-F482-11ce-8B67-00AA00A3F1A6),
-pointer_default(unique)
-]
-interface IConfigAviMux : IUnknown
-{
- import "unknwn.idl";
-
- // control whether the AVI mux adjusts the frame rate or audio
- // sampling rate for drift when the file is closed. -1 to disables
- // this behavior.
- HRESULT SetMasterStream([in] LONG iStream);
- HRESULT GetMasterStream([out] LONG *pStream);
-
- // control whether the AVI mux writes out an idx1 index chunk for
- // compatibility with older AVI players.
- HRESULT SetOutputCompatibilityIndex([in] BOOL fOldIndex);
- HRESULT GetOutputCompatibilityIndex([out] BOOL *pfOldIndex);
-}
-
- //---------------------------------------------------------------------
- // CompressionCaps enum
- //---------------------------------------------------------------------
-
- // This tells you which features of IAMVideoCompression are supported
-
- // CanCrunch means that it can compress video to a specified data rate
- // If so, then the output pin's media type will contain that data rate
- // in the format's AvgBytesPerSecond field, and that should be used.
-
- typedef enum
- {
- CompressionCaps_CanQuality = 0x01,
- CompressionCaps_CanCrunch = 0x02,
- CompressionCaps_CanKeyFrame = 0x04,
- CompressionCaps_CanBFrame = 0x08,
- CompressionCaps_CanWindow = 0x10
- } CompressionCaps;
-
-
-
- //---------------------------------------------------------------------
- // IAMVideoCompression interface
- //
- // Control compression parameters - pin interface
- //---------------------------------------------------------------------
-
- // This interface is implemented by the output pin of a video capture
- // filter or video compressor that provides video data
-
- // You use this interface to control how video is compressed... how
- // many keyframes, etc., and to find information like capabilities and
- // the description of this compressor
-
- [
- object,
- uuid(C6E13343-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMVideoCompression : IUnknown
- {
- // - Only valid if GetInfo's pCapabilities sets
- // CompressionCaps_CanKeyFrame
- // - KeyFrameRate < 0 means use the compressor default
- // - KeyFrames == 0 means only the first frame is a key
- HRESULT put_KeyFrameRate (
- [in] long KeyFrameRate);
-
- HRESULT get_KeyFrameRate (
- [out] long * pKeyFrameRate);
-
- // - Only valid if GetInfo's pCapabilities sets
- // CompressionCaps_CanBFrame
- // - If keyframes are every 10, and there are 3 P Frames per key,
- // they will be spaced evenly between the key frames and the other
- // 6 frames will be B frames
- // - PFramesPerKeyFrame < 0 means use the compressor default
- HRESULT put_PFramesPerKeyFrame (
- [in] long PFramesPerKeyFrame);
-
- HRESULT get_PFramesPerKeyFrame (
- [out] long * pPFramesPerKeyFrame);
-
- // - Only valid if GetInfo's pCapabilities sets
- // CompressionCaps_CanQuality
- // - Controls image quality
- // - If you are compressing to a fixed data rate, a high quality
- // means try and use all of the data rate, and a low quality means
- // feel free to use much lower than the data rate if you want to.
- // - Quality < 0 means use the compressor default
- HRESULT put_Quality (
- [in] double Quality);
-
- HRESULT get_Quality (
- [out] double * pQuality);
-
- // If you have set a data rate of 100K/sec on a 10fps movie, that
- // will normally mean each frame must be <=10K. But a window size
- // means every consecutive n frames must average to the data rate,
- // but an individual frame (if n > 1) is allowed to exceed the
- // frame size suggested by the data rate
- HRESULT put_WindowSize (
- [in] DWORDLONG WindowSize);
-
- HRESULT get_WindowSize (
- [out] DWORDLONG * pWindowSize);
-
- // - pszVersion might be "Version 2.1.0"
- // - pszDescription might be "Danny's awesome video compressor"
- // - pcbVersion and pcbDescription will be filled in with the
- // required length if they are too short
- // - *pCapabilities is a logical OR of some CompressionCaps flags
- HRESULT GetInfo(
- [out, size_is(*pcbVersion)] WCHAR * pszVersion,
- [in,out] int *pcbVersion,
- [out, size_is(*pcbDescription)] LPWSTR pszDescription,
- [in,out] int *pcbDescription,
- [out] long *pDefaultKeyFrameRate,
- [out] long *pDefaultPFramesPerKey,
- [out] double *pDefaultQuality,
- [out] long *pCapabilities //CompressionCaps
- );
-
- // - this means when this frame number comes along after the graph
- // is running, make it a keyframe even if you weren't going to
- HRESULT OverrideKeyFrame(
- [in] long FrameNumber
- );
-
- // - Only valid if GetInfo's pCapabilities sets
- // CompressionCaps_CanCrunch
- // - this means when this frame number comes along after the graph
- // is running, make it this many bytes big instead of whatever size
- // you were going to make it.
- HRESULT OverrideFrameSize(
- [in] long FrameNumber,
- [in] long Size
- );
-
- }
-
- //---------------------------------------------------------------------
- // VfwCaptureDialogs enum
- //---------------------------------------------------------------------
-
- typedef enum
- {
- VfwCaptureDialog_Source = 0x01,
- VfwCaptureDialog_Format = 0x02,
- VfwCaptureDialog_Display = 0x04
- } VfwCaptureDialogs;
-
-
- //---------------------------------------------------------------------
- // VfwCompressDialogs enum
- //---------------------------------------------------------------------
-
- typedef enum
- {
- VfwCompressDialog_Config = 0x01,
- VfwCompressDialog_About = 0x02,
- // returns S_OK if the dialog exists and can be shown, else S_FALSE
- VfwCompressDialog_QueryConfig = 0x04,
- VfwCompressDialog_QueryAbout = 0x08
- } VfwCompressDialogs;
-
-
- //---------------------------------------------------------------------
- // IAMVfwCaptureDialogs - filter interface
- //
- // Show a VfW capture driver dialog - SOURCE, FORMAT, or DISPLAY
- //---------------------------------------------------------------------
-
- // This interface is supported only by Microsoft's Video For Windows
- // capture driver Capture Filter. It allows an application to bring up
- // one of the 3 driver dialogs that VfW capture drivers have.
-
- [
- object,
- local,
- uuid(D8D715A0-6E5E-11D0-B3F0-00AA003761C5),
- pointer_default(unique)
- ]
- interface IAMVfwCaptureDialogs : IUnknown
- {
- HRESULT HasDialog(
- [in] int iDialog // VfwCaptureDialogs enum
- );
-
- HRESULT ShowDialog(
- [in] int iDialog, // VfwCaptureDialogs enum
- [in] HWND hwnd
- );
-
- HRESULT SendDriverMessage(
- [in] int iDialog, // VfwCaptureDialogs enum
- [in] int uMsg,
- [in] long dw1,
- [in] long dw2
- );
-
- // - iDialog can be one of the VfwCaptureDialogs enums
- // - HasDialog returns S_OK if it has the dialog, else S_FALSE
- // - ShowDialog can only be called when not streaming or when another
- // dialog is not already up
- // - SendDriverMessage can send a private message to the capture driver.
- // USE IT AT YOUR OWN RISK!
- }
-
- //---------------------------------------------------------------------
- // IAMVfwCompressDialogs - filter interface
- //
- // Show a VfW codec driver dialog - CONFIG or ABOUT
- //---------------------------------------------------------------------
-
- // This interface is supported only by Microsoft's ICM Compressor filter
- // (Co). It allows an application to bring up either the Configure or
- // About dialogs for the ICM codec that it is currently using.
-
- [
- object,
- local,
- uuid(D8D715A3-6E5E-11D0-B3F0-00AA003761C5),
- pointer_default(unique)
- ]
- interface IAMVfwCompressDialogs : IUnknown
- {
-
- // Bring up a dialog for this codec
- HRESULT ShowDialog(
- [in] int iDialog, // VfwCompressDialogs enum
- [in] HWND hwnd
- );
-
- // Calls ICGetState and gives you the result
- HRESULT GetState(
- [out, size_is(*pcbState)] LPVOID pState,
- [in, out] int *pcbState
- );
-
- // Calls ICSetState
- HRESULT SetState(
- [in, size_is(cbState)] LPVOID pState,
- [in] int cbState
- );
-
- // Send a codec specific message
- HRESULT SendDriverMessage(
- [in] int uMsg,
- [in] long dw1,
- [in] long dw2
- );
-
- // - iDialog can be one of the VfwCaptureDialogs enums
- // - ShowDialog can only be called when not streaming or when no other
- // dialog is up already
- // - an application can call GetState after ShowDialog(CONFIG) to
- // see how the compressor was configured and next time the graph
- // is used, it can call SetState with the data it saved to return
- // the codec to the state configured by the dialog box from last time
- // - GetState with a NULL pointer returns the size needed
- // - SendDriverMessage can send a private message to the codec.
- // USE IT AT YOUR OWN RISK!
- }
-
-
- //---------------------------------------------------------------------
- // IAMDroppedFrames interface
- //
- // Report status of capture - pin interface
- //---------------------------------------------------------------------
-
- // A capture filter's video output pin supports this. It reports
- // how many frames were not sent (dropped), etc.
-
- // Every time your filter goes from STOPPED-->PAUSED, you reset all your
- // counts to zero.
-
- // An app may call this all the time while you are capturing to see how
- // capturing is going. MAKE SURE you always return as current information
- // as possible while you are running.
-
- // When your capture filter starts running, it starts by sending frame 0,
- // then 1, 2, 3, etc. The time stamp of each frame sent should correspond
- // to the graph clock's time when the image was digitized. The end time
- // is the start time plus the duration of the video frame.
- // You should also set the MediaTime of each sample (SetMediaTime) as well.
- // This should be the frame number ie (0,1) (1,2) (2,3).
- // If a frame is dropped, a downstream filter will be able to tell easily
- // not by looking for gaps in the regular time stamps, but by noticing a
- // frame number is missing (eg. (1,2) (2,3) (4,5) (5,6) means frame 3
- // was dropped.
-
- // Using the info provided by this interface, an application can figure out
- // the number of frames dropped, the frame rate achieved (the length of
- // time the graph was running divided by the number of frames not dropped),
- // and the data rate acheived (the length of time the graph was running
- // divided by the average frame size).
-
- // If your filter is running, then paused, and then run again, you need
- // to continue to deliver frames as if it was never paused. The first
- // frame after the second RUN cannot be time stamped earlier than the last
- // frame sent before the pause.
-
- // Your filter must always increment the MediaTime of each sample sent.
- // Never send the same frame # twice, and never go back in time. The
- // regular time stamp of a sample can also never go back in time.
-
- [
- object,
- uuid(C6E13344-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMDroppedFrames : IUnknown
- {
- // Get the number of dropped frames
- HRESULT GetNumDropped(
- [out] long * plDropped
-
- );
-
- //Get the number of non-dropped frames
- HRESULT GetNumNotDropped(
- [out] long * plNotDropped
-
- );
-
- // - plArray points to an array of lSize longs. The filter will
- // fill it with the frame number of the first lSize frames dropped.
- // A filter may not have bothered to remember as many as you asked
- // for, so it will set *plNumCopied to the number of frames it filled
- // in.
- HRESULT GetDroppedInfo(
- [in] long lSize,
- [out] long * plArray,
- [out] long * plNumCopied
- );
-
- // - This is the average size of the frames it didn't drop (in bytes)
- HRESULT GetAverageFrameSize(
- [out] long * plAverageSize
-
- );
-
- }
-
-
-
- cpp_quote("#define AMF_AUTOMATICGAIN -1.0")
-
- //---------------------------------------------------------------------
- // IAMAudioInputMixer interface
- //
- // Sets the recording levels, pan and EQ for the audio card inputs
- //---------------------------------------------------------------------
-
- // This interface is implemented by each input pin of an audio capture
- // filter, to tell it what level, panning, and EQ to use for each input.
- // The name of each pin will reflect the type of input, eg. "Line input 1"
- // or "Mic". An application uses the pin names to decide how it wants to
- // set the recording levels
-
- // This interface can also be supported by the audio capture filter itself
- // to control to overall record level and panning after the mix
-
- [
- object,
- uuid(54C39221-8380-11d0-B3F0-00AA003761C5),
- pointer_default(unique)
- ]
- interface IAMAudioInputMixer : IUnknown
- {
- // This interface is only supported by the input pins, not the filter
- // If disabled, this channel will not be mixed in as part of the
- // recorded signal.
- HRESULT put_Enable (
- [in] BOOL fEnable); // TRUE=enable FALSE=disable
-
- //Is this channel enabled?
- HRESULT get_Enable (
- [out] BOOL *pfEnable);
-
- // When set to mono mode, making a stereo recording of this channel
- // will have both channels contain the same data... a mixture of the
- // left and right signals
- HRESULT put_Mono (
- [in] BOOL fMono); // TRUE=mono FALSE=multi channel
-
- //all channels combined into a mono signal?
- HRESULT get_Mono (
- [out] BOOL *pfMono);
-
- // !!! WILL CARDS BE ABLE TO BOOST THE GAIN?
- //Set the record level for this channel
- HRESULT put_MixLevel (
- [in] double Level); // 0 = off, 1 = full (unity?) volume
- // AMF_AUTOMATICGAIN, if supported,
- // means automatic
-
- //Get the record level for this channel
- HRESULT get_MixLevel (
- [out] double *pLevel);
-
- // For instance, when panned full left, and you make a stereo recording
- // of this channel, you will record a silent right channel.
- HRESULT put_Pan (
- [in] double Pan); // -1 = full left, 0 = centre, 1 = right
-
- //Get the pan for this channel
- HRESULT get_Pan (
- [out] double *pPan);
-
- // Boosts the bass of low volume signals before they are recorded
- // to compensate for the fact that your ear has trouble hearing quiet
- // bass sounds
- HRESULT put_Loudness (
- [in] BOOL fLoudness);// TRUE=on FALSE=off
-
- HRESULT get_Loudness (
- [out] BOOL *pfLoudness);
-
- // boosts or cuts the treble of the signal before it's recorded by
- // a certain amount of dB
- HRESULT put_Treble (
- [in] double Treble); // gain in dB (-ve = attenuate)
-
- //Get the treble EQ for this channel
- HRESULT get_Treble (
- [out] double *pTreble);
-
- // This is the maximum value allowed in put_Treble. ie 6.0 means
- // any value between -6.0 and 6.0 is allowed
- HRESULT get_TrebleRange (
- [out] double *pRange); // largest value allowed
-
- // boosts or cuts the bass of the signal before it's recorded by
- // a certain amount of dB
- HRESULT put_Bass (
- [in] double Bass); // gain in dB (-ve = attenuate)
-
- // Get the bass EQ for this channel
- HRESULT get_Bass (
- [out] double *pBass);
-
- // This is the maximum value allowed in put_Bass. ie 6.0 means
- // any value between -6.0 and 6.0 is allowed
- HRESULT get_BassRange (
- [out] double *pRange); // largest value allowed
-
- }
-
-
- //---------------------------------------------------------------------
- // IAMBufferNegotiation interface
- //
- // Tells a pin what kinds of buffers to use when connected
- //---------------------------------------------------------------------
-
- // This interface can be implemented by any pin that will connect to
- // another pin using IMemInputPin. All capture filters should support
- // this interface.
-
- // SuggestAllocatorProperties is a way for an application to get
- // in on the buffer negotiation process for a pin. This pin will use
- // the numbers given to it by the application as its request to the
- // allocator. An application can use a negative number for any element
- // in the ALLOCATOR_PROPERTIES to mean "don't care". An application must
- // call this function before the pin is connected, or it will be too late
- // To ensure that an application gets what it wants, it would be wise to
- // call this method on both pins being connected together, so the other
- // pin doesn't overrule the application's request.
-
- // GetAllocatorProperties can only be called after a pin is connected and
- // it returns the properties of the current allocator being used
-
- [
- object,
- uuid(56ED71A0-AF5F-11D0-B3F0-00AA003761C5),
- pointer_default(unique)
- ]
- interface IAMBufferNegotiation : IUnknown
- {
- HRESULT SuggestAllocatorProperties (
- [in] const ALLOCATOR_PROPERTIES *pprop);
-
- HRESULT GetAllocatorProperties (
- [out] ALLOCATOR_PROPERTIES *pprop);
-
- }
-
-
- //---------------------------------------------------------------------
- // AnalogVideoStandard enum
- //---------------------------------------------------------------------
-
- typedef enum tagAnalogVideoStandard
- {
- AnalogVideo_None = 0x00000000, // This is a digital sensor
- AnalogVideo_NTSC_M = 0x00000001, // 75 IRE Setup
- AnalogVideo_NTSC_M_J = 0x00000002, // Japan, 0 IRE Setup
- AnalogVideo_NTSC_433 = 0x00000004,
-
- AnalogVideo_PAL_B = 0x00000010,
- AnalogVideo_PAL_D = 0x00000020,
- AnalogVideo_PAL_G = 0x00000040,
- AnalogVideo_PAL_H = 0x00000080,
- AnalogVideo_PAL_I = 0x00000100,
- AnalogVideo_PAL_M = 0x00000200,
- AnalogVideo_PAL_N = 0x00000400,
-
- AnalogVideo_PAL_60 = 0x00000800,
-
- AnalogVideo_SECAM_B = 0x00001000,
- AnalogVideo_SECAM_D = 0x00002000,
- AnalogVideo_SECAM_G = 0x00004000,
- AnalogVideo_SECAM_H = 0x00008000,
- AnalogVideo_SECAM_K = 0x00010000,
- AnalogVideo_SECAM_K1 = 0x00020000,
- AnalogVideo_SECAM_L = 0x00040000,
- AnalogVideo_SECAM_L1 = 0x00080000,
-
- AnalogVideo_PAL_N_COMBO // Argentina
- = 0x00100000
- } AnalogVideoStandard;
-
- cpp_quote("#define AnalogVideo_NTSC_Mask 0x00000007")
- cpp_quote("#define AnalogVideo_PAL_Mask 0x00100FF0")
- cpp_quote("#define AnalogVideo_SECAM_Mask 0x000FF000")
-
-
- //---------------------------------------------------------------------
- // TunerInputType enum
- //---------------------------------------------------------------------
-
- typedef enum tagTunerInputType
- {
- TunerInputCable,
- TunerInputAntenna
- } TunerInputType;
-
- //---------------------------------------------------------------------
- // VideoCopyProtectionType enum
- //---------------------------------------------------------------------
-
- typedef enum
- {
- VideoCopyProtectionMacrovisionBasic,
- VideoCopyProtectionMacrovisionCBI
- } VideoCopyProtectionType;
-
- //---------------------------------------------------------------------
- // PhysicalConnectorType enum
- //---------------------------------------------------------------------
-
- typedef enum tagPhysicalConnectorType
- {
- PhysConn_Video_Tuner = 1,
- PhysConn_Video_Composite,
- PhysConn_Video_SVideo,
- PhysConn_Video_RGB,
- PhysConn_Video_YRYBY,
- PhysConn_Video_SerialDigital,
- PhysConn_Video_ParallelDigital,
- PhysConn_Video_SCSI,
- PhysConn_Video_AUX,
- PhysConn_Video_1394,
- PhysConn_Video_USB,
- PhysConn_Video_VideoDecoder,
- PhysConn_Video_VideoEncoder,
- PhysConn_Video_SCART,
- PhysConn_Video_Black,
-
-
- PhysConn_Audio_Tuner = 0x1000,
- PhysConn_Audio_Line,
- PhysConn_Audio_Mic,
- PhysConn_Audio_AESDigital,
- PhysConn_Audio_SPDIFDigital,
- PhysConn_Audio_SCSI,
- PhysConn_Audio_AUX,
- PhysConn_Audio_1394,
- PhysConn_Audio_USB,
- PhysConn_Audio_AudioDecoder,
- } PhysicalConnectorType;
-
-
-
-
- //---------------------------------------------------------------------
- // IAMAnalogVideoDecoder interface
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(C6E13350-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMAnalogVideoDecoder : IUnknown
- {
-
- //Gets the supported analog video standards (NTSC/M, PAL/B, SECAM/K1...
- HRESULT get_AvailableTVFormats(
- [out] long *lAnalogVideoStandard
- );
-
- //Sets or gets the current analog video standard (NTSC/M, PAL/B, SECAM/K1, ...
- HRESULT put_TVFormat(
- [in] long lAnalogVideoStandard
- );
-
- // Sets or gets the current analog video standard (NTSC/M, PAL/B, SECAM/K1, ...
- HRESULT get_TVFormat(
- [out] long * plAnalogVideoStandard
- );
-
- // True if horizontal sync is locked
- HRESULT get_HorizontalLocked (
- [out] long * plLocked);
-
- // True if connected to a VCR (changes PLL timing)
- HRESULT put_VCRHorizontalLocking (
- [in] long lVCRHorizontalLocking);
-
- HRESULT get_VCRHorizontalLocking (
- [out] long * plVCRHorizontalLocking);
-
- // Returns the number of lines in the video signal")]
- HRESULT get_NumberOfLines (
- [out] long *plNumberOfLines);
-
- // Enables or disables the output bus
- HRESULT put_OutputEnable (
- [in] long lOutputEnable);
-
- HRESULT get_OutputEnable (
- [out] long *plOutputEnable);
-
- }
-
-
- //---------------------------------------------------------------------
- // VideoProcAmp Property enum
- //---------------------------------------------------------------------
-
- typedef enum tagVideoProcAmpProperty
- {
- VideoProcAmp_Brightness,
- VideoProcAmp_Contrast,
- VideoProcAmp_Hue,
- VideoProcAmp_Saturation,
- VideoProcAmp_Sharpness,
- VideoProcAmp_Gamma,
- VideoProcAmp_ColorEnable,
- VideoProcAmp_WhiteBalance,
- VideoProcAmp_BacklightCompensation,
- VideoProcAmp_Gain
- } VideoProcAmpProperty;
-
- //---------------------------------------------------------------------
- // VideoProcAmp Flags enum
- //---------------------------------------------------------------------
-
- typedef enum tagVideoProcAmpFlags
- {
- VideoProcAmp_Flags_Auto = 0x0001,
- VideoProcAmp_Flags_Manual = 0x0002
- } VideoProcAmpFlags;
-
- //---------------------------------------------------------------------
- // IAMVideoProcAmp interface
- //
- // Adjusts video quality in either the analog or digital domain.
- //
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(C6E13360-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMVideoProcAmp : IUnknown
- {
- // Returns min, max, step size, and default values
- HRESULT GetRange(
- [in] long Property, // Which property to query
- [out] long * pMin, // Range minimum
- [out] long * pMax, // Range maxumum
- [out] long * pSteppingDelta,// Step size
- [out] long * pDefault, // Default value
- [out] long * pCapsFlags // VideoProcAmpFlags
-
- );
-
- // Set a VideoProcAmp property
- HRESULT Set(
- [in] long Property, // VideoProcAmpProperty
- [in] long lValue, // Value to set
- [in] long Flags // VideoProcAmp_Flags_*
-
- );
-
- // Get a VideoProcAmp property
- HRESULT Get(
- [in] long Property, // VideoProcAmpProperty
- [out] long * lValue, // Current value
- [out] long * Flags // VideoProcAmp_Flags_*
- );
- }
-
-
- //---------------------------------------------------------------------
- // CameraControl Property enum
- //---------------------------------------------------------------------
-
- typedef enum tagCameraControlProperty
- {
- CameraControl_Pan,
- CameraControl_Tilt,
- CameraControl_Roll,
- CameraControl_Zoom,
- CameraControl_Exposure,
- CameraControl_Iris,
- CameraControl_Focus
- } CameraControlProperty;
-
- //---------------------------------------------------------------------
- // CameraControl Flags enum
- //---------------------------------------------------------------------
-
- typedef enum tagCameraControlFlags
- {
- CameraControl_Flags_Auto = 0x0001,
- CameraControl_Flags_Manual = 0x0002
- } CameraControlFlags;
-
- //---------------------------------------------------------------------
- // IAMCameraControl interface
- //
- // Control of local or remote cameras
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(C6E13370-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMCameraControl : IUnknown
- {
- // Returns min, max, step size, and default values
- HRESULT GetRange(
- [in] long Property, // Which property to query
- [out] long * pMin, // Range minimum
- [out] long * pMax, // Range maxumum
- [out] long * pSteppingDelta,// Step size
- [out] long * pDefault, // Default value
- [out] long * pCapsFlags // CamaeraControlFlags
-
- );
-
- // Set a CameraControl property
- HRESULT Set(
- [in] long Property, // CameraControlProperty
- [in] long lValue, // Value to set
- [in] long Flags // CameraControl_Flags_*
-
- );
-
- // Get a CameraControl property
- HRESULT Get(
- [in] long Property, // CameraControlProperty
- [out] long * lValue, // Current value
- [out] long * Flags // CameraControl_Flags_*
- );
- }
-
- //---------------------------------------------------------------------
- // VideoControl Flags enum
- //---------------------------------------------------------------------
-
- typedef enum tagVideoControlFlags
- {
- VideoControlFlag_FlipHorizontal = 0x0001,
- VideoControlFlag_FlipVertical = 0x0002,
- VideoControlFlag_ExternalTriggerEnable = 0x0004,
- VideoControlFlag_Trigger = 0x0008
-
- } VideoControlFlags;
-
- //---------------------------------------------------------------------
- // IAMVideoControl interface
- //
- // Control of horizontal & vertical flip, external trigger,
- // and listing available frame rates
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(6a2e0670-28e4-11d0-a18c-00a0c9118956),
- pointer_default(unique)
- ]
- interface IAMVideoControl : IUnknown
- {
- // What can the underlying hardware do?
- HRESULT GetCaps(
- [in] IPin * pPin, // the pin to query or control
- [out] long * pCapsFlags // VideoControlFlag_*
-
- );
-
- // Set the mode of operation
- HRESULT SetMode(
- [in] IPin * pPin, // the pin to query or control
- [in] long Mode // VideoControlFlag_*
-
- );
-
- // Get the mode of operation
- HRESULT GetMode(
- [in] IPin * pPin, // the pin to query or control
- [out] long * Mode // VideoControlFlag_*
- );
-
- // Get actual frame rate info for USB and 1394
- // This is only available when streaming
- HRESULT GetCurrentActualFrameRate(
- [in] IPin * pPin, // the pin to query or control
- [out] LONGLONG * ActualFrameRate // 100 nS units
- );
-
- // Get max available frame rate info for USB and 1394
- // Returns the max frame rate currently available based on bus bandwidth usage
- HRESULT GetMaxAvailableFrameRate(
- [in] IPin * pPin, // the pin to query or control
- [in] long iIndex, // 0 to IAMStreamConfig->GetNumberOfCapabilities-1
- [in] SIZE Dimensions, // width and height
- [out] LONGLONG * MaxAvailableFrameRate // 100 nS units
- );
-
- // Get List of available frame rates
- HRESULT GetFrameRateList(
- [in] IPin * pPin, // the pin to query or control
- [in] long iIndex, // 0 to IAMStreamConfig->GetNumberOfCapabilities-1
- [in] SIZE Dimensions, // width and height
- [out] long * ListSize, // Number of elements in the list
- [out] LONGLONG ** FrameRates // Array of framerates in 100 nS units
- // or NULL to just get ListSize
- );
-
- }
-
-
- //---------------------------------------------------------------------
- // IAMCrossbar interface
- //
- // Controls a routing matrix for analog or digital video or audio
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(C6E13380-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMCrossbar : IUnknown
- {
-
- // How many pins are there?
- HRESULT get_PinCounts(
- [out] long * OutputPinCount, // count of output pins
- [out] long * InputPinCount); // count of input pins
-
- // True if routing is possible
- HRESULT CanRoute (
- [in] long OutputPinIndex, // the output pin
- [in] long InputPinIndex); // the input pin
-
- // Routes an input pin to an output pin
- HRESULT Route (
- [in] long OutputPinIndex, // the output pin
- [in] long InputPinIndex); // the input pin
-
- // Returns the input pin connected to a given output pin
- HRESULT get_IsRoutedTo (
- [in] long OutputPinIndex, // the output pin
- [out] long * InputPinIndex); // the connected input pin
-
- // Returns a pin which is related to a given pin
- // (ie. this audio pin is related to a video pin)
- HRESULT get_CrossbarPinInfo (
- [in] BOOL IsInputPin, // TRUE for input pins
- [in] long PinIndex, // a pin
- [out] long * PinIndexRelated, // Index of related pin
- [out] long * PhysicalType); // Physical type of pin
-
- }
-
-
- //---------------------------------------------------------------------
- // IAMTuner interface
- //
- // base tuner device
- //---------------------------------------------------------------------
-
- // predefined subchannel values
- typedef enum tagAMTunerSubChannel
- {
- AMTUNER_SUBCHAN_NO_TUNE = -2, // don't tune
- AMTUNER_SUBCHAN_DEFAULT = -1 // use default sub chan
- } AMTunerSubChannel;
-
- // predefined signal strength values
- typedef enum tagAMTunerSignalStrength
- {
- AMTUNER_HASNOSIGNALSTRENGTH = -1, // cannot indicate signal strength
- AMTUNER_NOSIGNAL = 0, // no signal available
- AMTUNER_SIGNALPRESENT = 1 // signal present
- } AMTunerSignalStrength;
-
- // specifies the mode of operation of the tuner
- typedef enum tagAMTunerModeType
- {
- AMTUNER_MODE_DEFAULT = 0x0000, // default tuner mode
- AMTUNER_MODE_TV = 0x0001, // tv
- AMTUNER_MODE_FM_RADIO = 0x0002, // fm radio
- AMTUNER_MODE_AM_RADIO = 0x0004, // am radio
- AMTUNER_MODE_DSS = 0x0008, // dss
- } AMTunerModeType;
-
- // Events reported by IAMTunerNotification
- typedef enum tagAMTunerEventType{
- AMTUNER_EVENT_CHANGED = 0x0001, // status changed
- } AMTunerEventType;
-
- interface IAMTunerNotification;
-
- [
- object,
- uuid(211A8761-03AC-11d1-8D13-00AA00BD8339),
- pointer_default(unique)
- ]
- interface IAMTuner : IUnknown
- {
- // Sets and gets the Channel
- HRESULT put_Channel(
- [in] long lChannel,
- [in] long lVideoSubChannel,
- [in] long lAudioSubChannel
- );
- HRESULT get_Channel(
- [out] long *plChannel,
- [out] long *plVideoSubChannel,
- [out] long *plAudioSubChannel
- );
-
- // Gets the minimum and maximum channel available
- HRESULT ChannelMinMax(
- [out] long *lChannelMin,
- [out] long *lChannelMax
- );
-
- // CountryCode is the same as the international
- // long distance telephone dialing prefix
-
- HRESULT put_CountryCode(
- [in] long lCountryCode
- );
- HRESULT get_CountryCode(
- [out] long *plCountryCode
- );
-
- HRESULT put_TuningSpace(
- [in] long lTuningSpace
- );
- HRESULT get_TuningSpace(
- [out] long *plTuningSpace
- );
-
- [local] HRESULT Logon(
- [in] HANDLE hCurrentUser
- );
- HRESULT Logout();
-
- // Signal status for current channel
- // signal strength == TUNER_NOSIGNAL, or strength value
- HRESULT SignalPresent(
- [out] long * plSignalStrength // AMTunerSignalStrength
- );
-
- // allow multifunction tuner to be switch between modes
- HRESULT put_Mode(
- [in] AMTunerModeType lMode // AMTunerModeType
- );
- HRESULT get_Mode(
- [out] AMTunerModeType *plMode // AMTunerModeType
- );
-
- // retrieve a bitmask of the possible modes
- HRESULT GetAvailableModes(
- [out] long *plModes // AMTunerModeType
- );
-
- // allow IAMTuner clients to receive event notification
- HRESULT RegisterNotificationCallBack(
- [in] IAMTunerNotification *pNotify,
- [in] long lEvents // bitmask from AMTunerEventType enumeration
- );
- HRESULT UnRegisterNotificationCallBack(
- [in] IAMTunerNotification *pNotify
- );
- }
-
- //---------------------------------------------------------------------
- // IAMTunerNotification interface
- //
- // Provided to IAMTuner if notification callbacks are desired
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(211A8760-03AC-11d1-8D13-00AA00BD8339),
- pointer_default(unique)
- ]
- interface IAMTunerNotification : IUnknown
- {
- HRESULT OnEvent([in] AMTunerEventType Event);
- }
-
-
- //---------------------------------------------------------------------
- // IAMTVTuner interface
- //
- // Controls an analog TV tuner device
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(211A8766-03AC-11d1-8D13-00AA00BD8339),
- pointer_default(unique)
- ]
- interface IAMTVTuner : IAMTuner
- {
- // Gets the supported analog video standards (NTSC/M, PAL/B, SECAM/K1, ...
- HRESULT get_AvailableTVFormats(
- [out] long *lAnalogVideoStandard
- );
-
- // Gets the current analog video standard (NTSC/M, PAL/B, SECAM/K1, ...)
- HRESULT get_TVFormat(
- [out] long * plAnalogVideoStandard
- );
-
- // Scans for a signal on a given channel
- // NOTE: this is equivalent to put_Channel(), SignalStrength()
- HRESULT AutoTune(
- [in] long lChannel,
- [out] long * plFoundSignal
- );
-
- // Saves the fine tuning information for all channels")]
- HRESULT StoreAutoTune();
-
- // The number of TV sources plugged into the tuner
- HRESULT get_NumInputConnections(
- [out] long * plNumInputConnections
- );
-
- // Sets or gets the tuner input type (Cable or Antenna)
- HRESULT put_InputType(
- [in] long lIndex,
- [in] TunerInputType InputType
- );
- HRESULT get_InputType(
- [in] long lIndex,
- [out] TunerInputType * pInputType
- );
-
- // Sets or gets the tuner input
- HRESULT put_ConnectInput(
- [in] long lIndex
- );
- HRESULT get_ConnectInput(
- [out] long *plIndex
- );
-
- // Gets the video and audio carrier frequencies
- HRESULT get_VideoFrequency(
- [out] long *lFreq
- );
- HRESULT get_AudioFrequency(
- [out] long *lFreq
- );
- }
-
-
- //---------------------------------------------------------------------
- // IBPCSatelliteTuner interface
- //
- // An interface supporting Satellite tuning-related functions
- //---------------------------------------------------------------------
- [
- object,
- local,
- uuid(211A8765-03AC-11d1-8D13-00AA00BD8339),
- pointer_default(unique)
- ]
- interface IBPCSatelliteTuner : IAMTuner
- {
- HRESULT get_DefaultSubChannelTypes(
- [out] long *plDefaultVideoType, // Provider-specific service type
- [out] long *plDefaultAudioType // Provider-specific service type
- );
-
- HRESULT put_DefaultSubChannelTypes(
- [in] long lDefaultVideoType, // Provider-specific service type
- [in] long lDefaultAudioType // Provider-specific service type
- );
-
- HRESULT IsTapingPermitted(); // S_OK yes, S_FALSE no
- }
-
-
-
- //---------------------------------------------------------------------
- // IAMTVAudio interface
- //
- // TV Audio control
- //---------------------------------------------------------------------
-
- typedef enum tagTVAudioMode
- {
- AMTVAUDIO_MODE_MONO = 0x0001, // Mono
- AMTVAUDIO_MODE_STEREO = 0x0002, // Stereo
- AMTVAUDIO_MODE_LANG_A = 0x0010, // Primary language
- AMTVAUDIO_MODE_LANG_B = 0x0020, // 2nd avail language
- AMTVAUDIO_MODE_LANG_C = 0x0040, // 3rd avail language
- } TVAudioMode;
-
- // Events reported by IAMTVAudioNotification
- typedef enum tagAMTVAudioEventType
- {
- AMTVAUDIO_EVENT_CHANGED = 0x0001, // mode changed
- } AMTVAudioEventType;
-
- interface IAMTVAudioNotification;
-
- [
- object,
- local,
- uuid(83EC1C30-23D1-11d1-99E6-00A0C9560266),
- pointer_default(unique)
- ]
- interface IAMTVAudio : IUnknown
- {
- // retrieve a bitmask of the formats available in the hardware
- HRESULT GetHardwareSupportedTVAudioModes(
- [out] long *plModes // TVAudioMode
- );
-
- // retrieve a bitmask of the possible modes
- HRESULT GetAvailableTVAudioModes(
- [out] long *plModes // TVAudioMode
- );
-
- HRESULT get_TVAudioMode(
- [out] long *plMode // TVAudioMode
- );
- HRESULT put_TVAudioMode(
- [in] long lMode // TVAudioMode
- );
-
- // allow IAMTVAudio clients to receive event notification
- HRESULT RegisterNotificationCallBack(
- [in] IAMTunerNotification *pNotify,
- [in] long lEvents // bitmask from AMTVAudioEventType enumeration
- );
- HRESULT UnRegisterNotificationCallBack(
- IAMTunerNotification *pNotify
- );
- }
-
- //---------------------------------------------------------------------
- // IAMTVAudioNotification interface
- //
- // Provided to IAMTVAudio clients if notification callbacks are desired
- //---------------------------------------------------------------------
-
- [
- object,
- local,
- uuid(83EC1C33-23D1-11d1-99E6-00A0C9560266),
- pointer_default(unique)
- ]
- interface IAMTVAudioNotification : IUnknown
- {
- HRESULT OnEvent([in] AMTVAudioEventType Event);
- }
-
-
-
-
- //---------------------------------------------------------------------
- // IAMAnalogVideoEncoder interface
- //---------------------------------------------------------------------
-
- [
- object,
- uuid(C6E133B0-30AC-11d0-A18C-00A0C9118956),
- pointer_default(unique)
- ]
- interface IAMAnalogVideoEncoder : IUnknown
- {
- // Gets the supported analog video standards (NTSC/M, PAL/B, SECAM/K1, ...)
- HRESULT get_AvailableTVFormats(
- [out] long *lAnalogVideoStandard
- );
-
- // Sets or gets the current analog video standard (NTSC/M, PAL/B, SECAM/K1, ...)
- HRESULT put_TVFormat(
- [in] long lAnalogVideoStandard
- );
-
- HRESULT get_TVFormat(
- [out] long * plAnalogVideoStandard
- );
-
- // Sets or gets the copy protection
- HRESULT put_CopyProtection (
- [in] long lVideoCopyProtection); // VideoCopyProtectionType
-
- HRESULT get_CopyProtection (
- [out] long *lVideoCopyProtection); // VideoCopyProtectionType
-
-
- // Enables and disables close captioning
- HRESULT put_CCEnable (
- [in] long lCCEnable);
-
- HRESULT get_CCEnable (
- [out] long *lCCEnable);
-
- }
-
- // used by IKsPropertySet set AMPROPSETID_Pin
- typedef enum {
- AMPROPERTY_PIN_CATEGORY,
- AMPROPERTY_PIN_MEDIUM
- } AMPROPERTY_PIN;
-
- //---------------------------------------------------------------------
- // IKsPropertySet interface
- //
- // Sets or gets a property identified by a property set GUID and a
- // property ID.
- //
- // Return codes for all 3 methods:
- // E_PROP_SET_UNSUPPORTED the property set is not supported
- // E_PROP_ID_UNSUPPORTED the property ID is not supported
- // for the specified property set
- //---------------------------------------------------------------------
-
-cpp_quote("#ifndef _IKsPropertySet_")
-cpp_quote("#define _IKsPropertySet_")
-
- //---------------------------------------------------------------------
- // #defines for IKsPropertySet::QuerySupported return result in pTypeSupport
- //---------------------------------------------------------------------
-
-cpp_quote("#define KSPROPERTY_SUPPORT_GET 1")
-cpp_quote("#define KSPROPERTY_SUPPORT_SET 2")
-
-
- [
- object,
- uuid(31EFAC30-515C-11d0-A9AA-00AA0061BE93),
- pointer_default(unique)
- ]
- interface IKsPropertySet : IUnknown
- {
- [local] HRESULT Set(
- [in] REFGUID guidPropSet,
- [in] DWORD dwPropID,
- [in, size_is(cbInstanceData)] LPVOID pInstanceData,
- [in] DWORD cbInstanceData,
- [in, size_is(cbPropData)] LPVOID pPropData,
- [in] DWORD cbPropData);
-
- [call_as(Set)] HRESULT RemoteSet(
- [in] REFGUID guidPropSet,
- [in] DWORD dwPropID,
- [in, size_is(cbInstanceData)] byte * pInstanceData,
- [in] DWORD cbInstanceData,
- [in, size_is(cbPropData)] byte * pPropData,
- [in] DWORD cbPropData);
-
- // To get a property, the caller allocates a buffer which the called
- // function fills in. To determine necessary buffer size, call Get with
- // pPropData=NULL and cbPropData=0.
- [local] HRESULT Get(
- [in] REFGUID guidPropSet,
- [in] DWORD dwPropID,
- [in, size_is(cbInstanceData)] LPVOID pInstanceData,
- [in] DWORD cbInstanceData,
- [out, size_is(cbPropData)] LPVOID pPropData,
- [in] DWORD cbPropData,
- [out] DWORD * pcbReturned);
-
- [call_as(Get)] HRESULT RemoteGet(
- [in] REFGUID guidPropSet,
- [in] DWORD dwPropID,
- [in, size_is(cbInstanceData)] byte * pInstanceData,
- [in] DWORD cbInstanceData,
- [out, size_is(cbPropData)] byte * pPropData,
- [in] DWORD cbPropData,
- [out] DWORD * pcbReturned);
- // QuerySupported must either return E_NOTIMPL or correctly indicate
- // if getting or setting the property set and property is supported.
- // S_OK indicates the property set and property ID combination is
- HRESULT QuerySupported(
- [in] REFGUID guidPropSet,
- [in] DWORD dwPropID,
- [out] DWORD *pTypeSupport);
- }
-cpp_quote("#endif // _IKsPropertySet_")
-
-[
-object,
-uuid(6025A880-C0D5-11d0-BD4E-00A0C911CE86),
-pointer_default(unique)
-]
-interface IMediaPropertyBag : IPropertyBag
-{
- import "ocidl.idl";
-
- typedef IMediaPropertyBag *LPMEDIAPROPERTYBAG;
-
- // return the i'th element in the property bag
- HRESULT EnumProperty(
- [in] ULONG iProperty,
- [in, out] VARIANT * pvarPropertyName,
- [in, out] VARIANT * pvarPropertyValue
- );
-
-}
-
-
-[
-object,
-uuid(5738E040-B67F-11d0-BD4D-00A0C911CE86),
-pointer_default(unique)
-]
-interface IPersistMediaPropertyBag : IPersist
-{
- import "ocidl.idl";
- import "unknwn.idl";
-
- HRESULT InitNew(
- void
- );
-
- HRESULT Load(
- [in] IMediaPropertyBag * pPropBag,
- [in] IErrorLog * pErrorLog
- );
-
- HRESULT Save(
- [in] IMediaPropertyBag * pPropBag,
- [in] BOOL fClearDirty,
- [in] BOOL fSaveAllProperties
- );
-
-
- typedef IPersistMediaPropertyBag * LPPERSISTMEDIAPROPERTYBAG;
-}
-
-
- //---------------------------------------------------------------------
- //
- // Defines IAMPhysicalPinInfo Interface
- //
- // Returns an enum and string that describes an input pin's physical type.
- //
- // Implement if: you have physical input pins such as video or audio (like
- // on a video capture card or a VCR)
- //
- // Use if: you want to communicate to a user available physical input pins
- // and allow them to select the active one if there is more than one
- //---------------------------------------------------------------------
-
-
-[
- object,
- uuid(F938C991-3029-11cf-8C44-00AA006B6814),
- pointer_default(unique)
- ]
-interface IAMPhysicalPinInfo : IUnknown {
-
- // Returns VFW_E_NO_ACCEPTABLE_TYPES if not a physical pin
- HRESULT GetPhysicalType(
- [out] long *pType, // the enum representing the Physical Type
- [out] LPOLESTR *ppszType // a friendly name
- );
-}
-typedef IAMPhysicalPinInfo *PAMPHYSICALPININFO;
-
- //---------------------------------------------------------------------
- // Defines IAMExtDevice Interface
- //
- // Base interface for external professional devices
- //
- // Implement if: the filter controls an external device such as a VCR,
- // timecode reader/generator, etc. The intent is to build a object from
- // this implementation plus another that specifically describes the device,
- // such as IAMExtTransport.
- //
- // Use if: you want to control and external device such as a VCR
- //
- // See edevdefs.h for the enumerated parameter list
- //---------------------------------------------------------------------
- [
- object,
- uuid(B5730A90-1A2C-11cf-8C23-00AA006B6814),
- pointer_default(unique)
- ]
- interface IAMExtDevice : IUnknown
- {
- // General device capabilities property. See edevdefs.h for supported
- // values
- HRESULT GetCapability(
- [in] long Capability, // identify the property
- [out] long *pValue, // return value
- [out] double *pdblValue // return value
- );
-
- // Get external device identification string. Usually the model #
- // of the device
- HRESULT get_ExternalDeviceID(
- [out] LPOLESTR *ppszData // ID string
- );
-
- HRESULT get_ExternalDeviceVersion(
- [out] LPOLESTR *ppszData // revision string
- );
-
- // Controls the external device's power mode
- HRESULT put_DevicePower([in] long PowerMode
- );
- HRESULT get_DevicePower([out] long *pPowerMode
- );
-
- // Some devices need to be reset in some way, i.e., rewinding a VCR
- // to the beginning of the tape and resetting the counter to zero.
- HRESULT Calibrate(
- [in] HEVENT hEvent,
- [in] long Mode,
- [out] long *pStatus // OATRUE is active, OAFALSE is inactive
- );
-
- // Selects the device's communications port, i.e.,COM1, IEEE1394, etc.
- // See edevdefs.h for enums
- HRESULT put_DevicePort([in] long DevicePort
- );
- HRESULT get_DevicePort([out] long *pDevicePort
- );
-
-}
-typedef IAMExtDevice *PEXTDEVICE;
-
- //---------------------------------------------------------------------
- // Defines IAMExtTransport Interface
- //
- // Contains properties and methods that control behavior of an external
- // transport device such as a VTR
- //
- // Implement if: you control such a device. Intended to be agregated
- // with IAMExtDevice.
- //
- // Use if: you want to control such a device
- //
- // See edevdefs.h for the parameter lists
- //---------------------------------------------------------------------
-[
- object,
- uuid(A03CD5F0-3045-11cf-8C44-00AA006B6814),
- pointer_default(unique)
- ]
-interface IAMExtTransport : IUnknown {
-
- // General transport capabilities property. See edevdefs.h for enums
- HRESULT GetCapability(
- [in] long Capability, // identify the property
- [out] long *pValue, // return value
- [out] double *pdblValue // return value
- );
-
- // For disc-based devices: spinning, or not spinning.
- // For tape-based device: threaded, unthreaded or ejected
- HRESULT put_MediaState([in] long State
- );
- HRESULT get_MediaState([out] long *pState // see edevdefs.h
- );
-
- // Determines state of unit's front panel
- HRESULT put_LocalControl([in] long State
- );
- HRESULT get_LocalControl([out] long *pState // OATRUE or OAFALSE
- );
-
- // Transport status such as Play, Stop, etc. More extensive
- // than AM states.
- HRESULT GetStatus(
- [in] long StatusItem, // see edevdefs.h
- [out] long *pValue
- );
-
- // Parameters such as recording speed, servo reference, ballistics, etc.
- HRESULT GetTransportBasicParameters(
- [in] long Param,
- [out] long *pValue,
- [out] LPOLESTR *ppszData
- );
-
- HRESULT SetTransportBasicParameters(
- [in] long Param,
- [in] long Value,
- [in] LPCOLESTR pszData
- );
-
- // Parameters such as video output mode
- HRESULT GetTransportVideoParameters(
- [in] long Param,
- [out] long *pValue
- );
-
- HRESULT SetTransportVideoParameters(
- [in] long Param,
- [in] long Value
- );
-
- // Parameters such as audio channel enable
- HRESULT GetTransportAudioParameters(
- [in] long Param,
- [out] long *pValue
- );
-
- HRESULT SetTransportAudioParameters(
- [in] long Param,
- [in] long Value
- );
-
- // Mode is the movement of the transport, i.e., Play, Stop,
- // Record, Edit, etc.
- HRESULT put_Mode([in] long Mode
- );
- HRESULT get_Mode([out] long *pMode
- );
-
- // Rate is for variable speed control of the the device. This
- // can be linked to IMediaControl::Rate() in the implementation
- // if desired.
- HRESULT put_Rate([in] double dblRate
- );
- HRESULT get_Rate([out] double *pdblRate
- );
-
- // This is a lengthy method, that is, it is in effect until canceled or complete and
- // requires housekeeping by the filter. It puts transport in play mode and maintains
- // fixed relationship between master time reference and transport position.
- HRESULT GetChase(
- [out] long *pEnabled, // OATRUE | OAFALSE
- [out] long *pOffset, // offset in current time format
- [out] HEVENT *phEvent // completion notification
- );
- HRESULT SetChase(
- [in] long Enable, // OATRUE | OAFALSE
- [in] long Offset, // offset in current time format
- [in] HEVENT hEvent // completion notification
- );
-
- // Also a lengthy method: temporarily change transport speed (for synchronizing).
- HRESULT GetBump(
- [out] long *pSpeed,
- [out] long *pDuration // in current time format
- );
- HRESULT SetBump(
- [in] long Speed,
- [in] long Duration // in current time format
- );
-
- // Enable/Disable transport anti-headclog control.
- HRESULT get_AntiClogControl([out] long *pEnabled // OATRUE | OAFALSE
- );
- HRESULT put_AntiClogControl([in] long Enable // OATRUE | OAFALSE
- );
-
- // The following group of properties describes edit events. An edit event can be a
- // standard insert or assemble edit or a memorized position called a bookmark.
- // A NOTE ABOUT EVENTS: as with all lengthy commands, event objects must be created to
- // signal completion or error.
-
- // Intended usage: an edit event is prepared for use by:
- // 1. Registering an edit property set and getting an EditID
- // 2. Setting the necessary edit properties
- // 3. Setting the edit property set active
-
- // Please see edevdefs.h for properties and values
-
- // The reference clock's advance is the mechanism that puts an edit in motion (see
- // ED_EDIT_REC_INPOINT).
-
- // Property set methods
- HRESULT GetEditPropertySet(
- [in] long EditID,
- [out] long *pState // ED_SET_ACTIVE | ED_SET_INACTIVE | ED_SET_INVALID
- // | ED_SET_EXECUTING
- );
-
- HRESULT SetEditPropertySet(
- [in, out] long *pEditID,
- [in] long State // ED_SET_REGISTER | ED_SET_DELETE | ED_SET_ACTIVE |
- ); // ED_SET_INACTIVE
-
- // the following properties define an edit event such as a bookmark, seek point, or
- // actual edit
- HRESULT GetEditProperty(
- [in] long EditID,
- [in] long Param,
- [out] long *pValue
- );
- HRESULT SetEditProperty(
- [in] long EditID,
- [in] long Param,
- [in] long Value
- );
-
- // Activates a capable transport's edit control (typically used for "on the fly" editing).
- HRESULT get_EditStart([out] long *pValue // OATRUE or OAFALSE
- );
- HRESULT put_EditStart([in] long Value // OATRUE or OAFALSE
- );
-}
-typedef IAMExtTransport *PIAMEXTTRANSPORT;
-
- //---------------------------------------------------------------------
- // Defines IAMTimecodeReader Interface
- //
- // Contains properties and methods that define behavior of a
- // SMPTE/MIDI Timecode Reader. It is expected that this interface
- // will be combined (aggregated) with IAMExtTransport to "build" a pro
- // VCR.
- //
- // Implement if: you control such a device
- //
- // Use if: you want to control such a device
- //
- // See edevdefs.h for the parameter lists
- //=====================================================================
-
-
-// timecode structures
-cpp_quote("#if 0")
-cpp_quote("/* the following is what MIDL knows how to remote */")
-typedef struct tagTIMECODE {
- WORD wFrameRate; // will be replaced by AM defs, but see ED_FORMAT_SMPTE for now
- WORD wFrameFract; // fractional frame. full scale is always 0x1000
- DWORD dwFrames;
-}TIMECODE;
-cpp_quote("#else /* 0 */")
-cpp_quote("#ifndef TIMECODE_DEFINED")
-cpp_quote("#define TIMECODE_DEFINED")
-cpp_quote("typedef union _timecode {")
-cpp_quote(" struct {")
-cpp_quote(" WORD wFrameRate;")
-cpp_quote(" WORD wFrameFract;")
-cpp_quote(" DWORD dwFrames;")
-cpp_quote(" };")
-cpp_quote(" DWORDLONG qw;")
-cpp_quote(" } TIMECODE;")
-cpp_quote("")
-cpp_quote("#endif /* TIMECODE_DEFINED */")
-cpp_quote("#endif /* 0 */")
-
-typedef TIMECODE *PTIMECODE;
-
-typedef struct tagTIMECODE_SAMPLE {
- LONGLONG qwTick; // ActiveMovie 100ns timestamp
- TIMECODE timecode; // timecode
- DWORD dwUser; // timecode user data (aka user bits)
- DWORD dwFlags; // timecode flags - see below
-} TIMECODE_SAMPLE;
-typedef TIMECODE_SAMPLE *PTIMECODE_SAMPLE;
-
-
-[
- object,
- uuid(9B496CE1-811B-11cf-8C77-00AA006B6814),
- pointer_default(unique)
-]
-interface IAMTimecodeReader : IUnknown
-{
- // Timecode Reader Mode - gets/sets the following properties
- // ED_TCR_SOURCE - timecode gen (readback), LTC, VITC, or Control Track
- HRESULT GetTCRMode(
- [in] long Param,
- [out] long *pValue);
- HRESULT SetTCRMode(
- [in] long Param,
- [in] long Value);
-
- // Select which line of the vertical interval timecode will be read from (if VITC).
- // To read VITC on specific multiple lines, the caller would make successive calls to
- // put_VITCLine(), once for each line desired.
- HRESULT put_VITCLine(
- [in] long Line ); // valid lines are 11-20, 0 means autoselect,
- // hi bit set means add to list of lines (for
- // readers that test across multiple lines)
- HRESULT get_VITCLine(
- [out] long *pLine ); // hi bit set means multiple lines are used,
- // and successive calls will cycle through the
- // line numbers (like an enumerator, only simpler)
-
- // GetTimecode can be used to obtain the most recent timecode value available in the
- // stream. The client can use this to monitor the timecode, parse duplicates and
- // discontinuities. The source filter supplying the timecode or possibly a down stream
- // filter might want to parse for discontinuities or errors since you have to look at
- // every sample to do this properly.
- //
-
- HRESULT GetTimecode(
- [out] PTIMECODE_SAMPLE pTimecodeSample) ;
-
-}
-typedef IAMTimecodeReader *PIAMTIMECODEREADER;
-
- //---------------------------------------------------------------------
- //=====================================================================
- // Defines IAMTimecodeGenerator Interface
- //
- // Contains properties and methods that define behavior of an external
- // SMPTE/MIDI Timecode Generator. It is expected that this interface
- // will be combined (aggregated) with IAMExtTransport to "build" a pro
- // VCR.
- //
- // Implement if: you control such a device
- //
- // Use if: you want to control such a device
- //
- // See edevdefs.h for the parameter lists
- //---------------------------------------------------------------------
-[
- object,
- uuid(9B496CE0-811B-11cf-8C77-00AA006B6814),
- pointer_default(unique)
- ]
-interface IAMTimecodeGenerator : IUnknown {
-
- // Timecode Generator Mode - gets/sets the following properties (see
- // vcrdefss.h for detailed values):
- // ED_TCG_TIMECODE_TYPE - LTC, VITC, or MIDI
- // ED_TCG_FRAMERATE - 24, 25, 30 drop or 30 nondrop
- // ED_TCG_SYNC_SOURCE - what is driving the bitclock
- // ED_TCG_REFERENCE_SOURCE - what is driving the count value
- HRESULT GetTCGMode(
- [in] long Param,
- [out] long *pValue);
-
- HRESULT SetTCGMode(
- [in] long Param,
- [in] long Value);
-
- // Select into which line(s) of the vertical interval timecode will be inserted (if VITC).
- // Hi bit set means add this line to any previously set lines.
- // To generate VITC on specific multiple lines, the caller would make successive calls to
- // put_VITCLine(), once for each line desired.
- HRESULT put_VITCLine(
- [in] long Line // valid lines are 11-20, 0 means autoselect(this setting
- ); // is for TC readers that decode from multiple lines)
- HRESULT get_VITCLine(
- [out] long *pLine
- );
-
- // Sets timecode and/or userbit value. If generator is running, takes effect
- // immediately. If caller wants to set only timecode, set userbit value to -1L (and
- // same for setting userbits only)
- //
-
- HRESULT SetTimecode(
- [in] PTIMECODE_SAMPLE pTimecodeSample) ;
-
-
- // GetTimecode can be used to obtain the most recent timecode value available in the
- // stream. The client can use this to monitor the timecode and verify the generator is
- // working properly
- //
-
- HRESULT GetTimecode(
- [out] PTIMECODE_SAMPLE pTimecodeSample) ;
-
-}
-typedef IAMTimecodeGenerator *PIAMTIMECODEGENERATOR;
-
- //---------------------------------------------------------------------
- // Defines IAMTimecodeDisplay Interface
- //
- // Contains properties and methods that define behavior of an external
- // SMPTE/MIDI Timecode Display device (aka "character generator" for
- // making "burn-ins" or "window dubs"). It is expected that this interface
- // will be combined (aggregated) with IAMExtTransport and the timecode
- // interfaces to "build" a pro VCR.
- //
- // Implement if: you control such a device
- //
- // Use if: you want to control such a device
- //
- // See edevdefs.h for the parameter lists
- //---------------------------------------------------------------------
-[
- object,
- uuid(9B496CE2-811B-11cf-8C77-00AA006B6814),
- pointer_default(unique)
- ]
-interface IAMTimecodeDisplay : IUnknown
-{
- // Enable/disable external device's timecode reader's character generator output. Some
- // readers have this feature - this is not intended for rendering inside the PC!
- HRESULT GetTCDisplayEnable(
- [out] long *pState); // OATRUE | OAFALSE
- HRESULT SetTCDisplayEnable(
- [in] long State); // OATRUE | OAFALSE
- // Timecode reader's character generator output
- // characteristics (size, position, intensity, etc.).
- HRESULT GetTCDisplay(
- [in] long Param,
- [out] long *pValue);
- HRESULT SetTCDisplay(
- [in] long Param,
- [in] long Value);
-
- /* Allowable params and values (see edevdefs.h for details):
- ED_TCD_SOURCE
- ED_TCR | ED_TCG
- ED_TCD_SIZE
- ED_SMALL | ED_MED | ED_LARGE
- ED_TCD_POSITION
- ED_TOP | ED_MIDDLE | ED_BOTTOM or'd with
- ED_LEFT | ED_CENTER | ED_RIGHT
- ED_TCD_INTENSITY
- ED_HIGH | ED_LOW
- ED_TCD_TRANSPARENCY // set from 0 to 4, 0 being completely opaque
- ED_TCD_INVERT // white on black or black on white
- OATRUE | OAFALSE
- ED_TCD_BORDER // white border for black chars, black border for white letters
- OATRUE | OAFALSE
- */
-}
-typedef IAMTimecodeDisplay *PIAMTIMECODEDISPLAY;
-
-
-[
- object,
- uuid(c6545bf0-e76b-11d0-bd52-00a0c911ce86),
- pointer_default(unique)
-]
-interface IAMDevMemoryAllocator : IUnknown
-{
- HRESULT GetInfo(
- [out] DWORD *pdwcbTotalFree,
- [out] DWORD *pdwcbLargestFree,
- [out] DWORD *pdwcbTotalMemory,
- [out] DWORD *pdwcbMinimumChunk);
-
- HRESULT CheckMemory(
- [in] const BYTE *pBuffer);
-
- HRESULT Alloc(
- [out] BYTE **ppBuffer,
- [in, out] DWORD *pdwcbBuffer);
-
- HRESULT Free(
- [in] BYTE *pBuffer);
-
- HRESULT GetDevMemoryObject(
- [out] IUnknown **ppUnkInnner,
- [in] IUnknown *pUnkOuter);
-}
-typedef IAMDevMemoryAllocator *PAMDEVMEMORYALLOCATOR;
-
-
-[
- object,
- uuid(c6545bf1-e76b-11d0-bd52-00a0c911ce86),
- pointer_default(unique)
-]
-interface IAMDevMemoryControl : IUnknown
-{
- HRESULT QueryWriteSync();
-
- HRESULT WriteSync();
-
- HRESULT GetDevId(
- [out] DWORD *pdwDevId);
-
-}
-typedef IAMDevMemoryControl *PAMDEVMEMORYCONTROL;
-
-// Flags for IAMStreamSelection::Info
-enum _AMSTREAMSELECTINFOFLAGS {
- AMSTREAMSELECTINFO_ENABLED = 0x01, // Enable - off for disable
- AMSTREAMSELECTINFO_EXCLUSIVE = 0x02 // Turns off the others in the group
- // when enabling this one
-};
-// Flags for IAMStreamSelection::Enable
-enum _AMSTREAMSELECTENABLEFLAGS {
- // Currently valid values are :
- // 0 - disable all streams in the group containing this stream
- // ..._ENABLE - enable only this stream with in the given group
- // and disable all others
- // ..._ENABLEALL - send out all streams
- AMSTREAMSELECTENABLE_ENABLE = 0x01, // Enable
- AMSTREAMSELECTENABLE_ENABLEALL = 0x02 // Enable all streams in the group
- // containing this stream
-};
-
-// Control which logical streams are played and find out information about
-// them
-// Normally supported by a filter
-[
- object,
- uuid(c1960960-17f5-11d1-abe1-00a0c905f375),
- pointer_default(unique)
-]
-interface IAMStreamSelect : IUnknown
-{
- // Returns total count of streams
- HRESULT Count(
- [out] DWORD *pcStreams); // Count of logical streams
-
- // Return info for a given stream - S_FALSE if iIndex out of range
- // The first steam in each group is the default
- HRESULT Info(
- [in] long lIndex, // 0-based index
- [out] AM_MEDIA_TYPE **ppmt, // Media type - optional
- // Use DeleteMediaType to free
- [out] DWORD *pdwFlags, // flags - optional
- [out] LCID *plcid, // LCID (returns 0 if none) - optional
- [out] DWORD *pdwGroup, // Logical group - optional
- [out] WCHAR **ppszName, // Name - optional - free with CoTaskMemFree
- // optional
- [out] IUnknown **ppObject, // Associated object - optional
- // Object may change if Enable is
- // called on this interface
- // - returns NULL if no associated object
- // Returns pin or filter for DShow
- [out] IUnknown **ppUnk); // Stream specific interface
-
- // Enable or disable a given stream
- HRESULT Enable(
- [in] long lIndex,
- [in] DWORD dwFlags);
-}
-typedef IAMStreamSelect *PAMSTREAMSELECT;
-
-enum _AMRESCTL_RESERVEFLAGS
-{
- AMRESCTL_RESERVEFLAGS_RESERVE = 0x00, // Increment reserve count
- AMRESCTL_RESERVEFLAGS_UNRESERVE = 0x01 // Decrement reserve count
-};
-
-// Reserve resources now so that playback can be subsequently
-// guaranteed
-//
-// Normally supported by a filter
-//
-[
- object,
- uuid(8389d2d0-77d7-11d1-abe6-00a0c905f375),
- pointer_default(unique),
- local
-]
-interface IAMResourceControl : IUnknown
-{
- // The reserve count is incremented/decremented if and only if
- // S_OK is returned
- // Unreserve once for every Reserve call
- HRESULT Reserve(
- [in] DWORD dwFlags, // From _AMRESCTL_RESERVEFLAGS enum
- [in] PVOID pvReserved // Must be NULL
- );
-}
-
-
-// Set clock adjustments - supported by some clocks
-[
- object,
- uuid(4d5466b0-a49c-11d1-abe8-00a0c905f375),
- pointer_default(unique),
- local
-]
-interface IAMClockAdjust : IUnknown
-{
- // Set the following delta to clock times
- // The clock will add adjust its times by the given delta
- HRESULT SetClockDelta(
- [in] REFERENCE_TIME rtDelta
- );
-};
-
-// Filter miscellaneous status flags
-
-enum _AM_FILTER_MISC_FLAGS {
- AM_FILTER_MISC_FLAGS_IS_RENDERER = 0x00000001, /* Will deliver EC_COMPLETE
- at end of media */
- AM_FILTER_MISC_FLAGS_IS_SOURCE = 0x00000002 /* Filter sources data */
-};
-
-[
- object,
- uuid(2dd74950-a890-11d1-abe8-00a0c905f375),
- pointer_default(unique),
- local
-]
-interface IAMFilterMiscFlags : IUnknown
-{
- // Get miscellaneous property flags
- ULONG GetMiscFlags(void);
-};
-
-
-// Video Image drawing interface
-[
- object,
- local,
- uuid(48efb120-ab49-11d2-aed2-00a0c995e8d5),
- pointer_default(unique),
-]
-interface IDrawVideoImage : IUnknown
-{
- HRESULT DrawVideoImageBegin();
-
- HRESULT DrawVideoImageEnd();
-
- HRESULT DrawVideoImageDraw(
- [in] HDC hdc,
- [in] LPRECT lprcSrc,
- [in] LPRECT lprcDst
- );
-}
-
-//
-// Video Image decimation interface
-//
-// The aim of this interface is to enable a video renderer filter to
-// control the decimation properties of a video decoder connected to
-// the video renderer
-//
-// This interface should only be supported by decoders that are capable of
-// decimating their output image by an arbitary amount.
-//
-//
-[
- object,
- local,
- uuid(2e5ea3e0-e924-11d2-b6da-00a0c995e8df),
- pointer_default(unique),
-]
-interface IDecimateVideoImage : IUnknown
-{
- //
- // Informs the decoder that it should decimate its output
- // image to the specified width and height. If the decoder can
- // decimate to this size it should return S_OK.
- // If the decoder can't perform the requested decimation
- // or wants to stop performing the decimation that it is
- // currently doing it should return E_FAIL.
- //
- HRESULT SetDecimationImageSize(
- [in] long lWidth,
- [in] long lHeight);
-
- //
- // Informs the decoder that it should stop decimating its output image
- // and resume normal output.
- //
- HRESULT ResetDecimationImageSize();
-}
-
-typedef enum _DECIMATION_USAGE {
- DECIMATION_LEGACY, // decimate at ovly then video port then crop
- DECIMATION_USE_DECODER_ONLY, // decimate image at the decoder only
- DECIMATION_USE_VIDEOPORT_ONLY, // decimate at the video port only
- DECIMATION_USE_OVERLAY_ONLY, // decimate at the overlay only
- DECIMATION_DEFAULT // decimate at decoder then ovly the vide port then crop
-} DECIMATION_USAGE;
-
-[
- object,
- local,
- uuid(60d32930-13da-11d3-9ec6-c4fcaef5c7be),
- pointer_default(unique),
-]
-interface IAMVideoDecimationProperties: IUnknown
-{
- //
- // Queries the current usage of the above IDecimateVideoImage
- // interface.
- //
- HRESULT QueryDecimationUsage(
- [out] DECIMATION_USAGE* lpUsage); // from DECIMATION_USAGE enum
-
- //
- // Sets the current usage of the above IDecimateVideoImage
- // interface.
- //
- HRESULT SetDecimationUsage(
- [in] DECIMATION_USAGE Usage); // from DECIMATION_USAGE enum
-}
-
-//---------------------------------------------------------------------
-//
-// IVideoFrameStep interface
-//
-//---------------------------------------------------------------------
-
-[
- object,
- uuid(e46a9787-2b71-444d-a4b5-1fab7b708d6a),
- pointer_default(unique),
-]
-interface IVideoFrameStep : IUnknown
-{
- //
- // Stop(), Pause(), Run() all cancel Step as does any seeking
- // request.
- //
- // The Step() and CancelStep() methods of this interface
- // Cancel any previous step.
- //
- // When stepping is complete EC_STEP_COMPLETE is signalled.
- //
- // When the filter graph gets EC_STEP_COMPLETE it automatically
- // sets the filter graph into paused state and forwards the
- // notification to the application
- //
- // Returns S_OK if stepping initiated.
- //
- // dwFrames
- // 1 means step 1 frame forward
- // 0 is invalid
- // n (n > 1) means skip n - 1 frames and show the nth
- //
- // pStepObject
- // NULL - default step object (filter) picked
- // non-NULL - use this object for stepping
- //
- HRESULT Step(DWORD dwFrames, [unique] IUnknown *pStepObject);
-
- // Can step?
- // Returns S_OK if it can, S_FALSE if it can't or error code.
- // bMultiple - if TRUE return whether can step n > 1
- HRESULT CanStep(long bMultiple, [unique] IUnknown *pStepObject);
-
- // Cancel stepping
- HRESULT CancelStep();
-}
-
-
-
-
-//---------------------------------------------------------------------
-//
-// IAMPushSource interface
-//
-// Provides a means for source filters to describe information about the
-// data that they source, such as whether the data is live or not, and
-// what type of clock was used for timestamps. This information may be
-// needed by other clocks in the graph in order to provide accurate
-// synchronization. Also provides a way to specify an offset value for
-// the filter to use when timestamping the streams it sources. Provides
-// support for the IAMLatency interface as well.
-//
-//---------------------------------------------------------------------
-
-enum _AM_PUSHSOURCE_FLAGS {
-
- //
- // The default assumption is that the data is from a live source,
- // time stamped with the graph clock, and the source does not
- // attempt to rate match the data it delivers.
- // The following flags can be used to override this assumption.
- //
-
- // capability flags
- AM_PUSHSOURCECAPS_INTERNAL_RM = 0x00000001, // source provides internal support for rate matching
- AM_PUSHSOURCECAPS_NOT_LIVE = 0x00000002, // don't treat source data as live
- AM_PUSHSOURCECAPS_PRIVATE_CLOCK = 0x00000004, // source data timestamped with clock not
- // exposed to the graph
-
- // request flags, set by user via SetPushSourceFlags method
- AM_PUSHSOURCEREQS_USE_STREAM_CLOCK = 0x00010000, // source was requested to timestamp
- // using a clock that isn't the graph clock
-
- AM_PUSHSOURCEREQS_USE_CLOCK_CHAIN = 0x00020000, // source requests reference clock chaining
-};
-
-//
-// Used to set a source filter to run in a "live" mode.
-//
-[
-object,
- uuid(F185FE76-E64E-11d2-B76E-00C04FB6BD3D),
- pointer_default(unique)
-]
-interface IAMPushSource : IAMLatency
-{
- // used to discover push source's capabilities.
- // may be any combination of the AM_PUSHSOURCE_FLAGS flags.
- HRESULT GetPushSourceFlags (
- [out] ULONG *pFlags
- );
-
- // used to set request flags for a push source.
- // may be a combination of the AM_PUSHSOURCE_REQS_xxx flags.
- HRESULT SetPushSourceFlags (
- [in] ULONG Flags
- );
-
- // specify an offset for push source time stamps
- HRESULT SetStreamOffset (
- [in] REFERENCE_TIME rtOffset
- );
-
- // retrieve the offset this push source is using
- HRESULT GetStreamOffset (
- [out] REFERENCE_TIME *prtOffset
- );
-
- // retrieve the maximum stream offset this push source thinks it can support
- HRESULT GetMaxStreamOffset (
- [out] REFERENCE_TIME *prtMaxOffset
- );
-
- // allows the filter graph to tell a push source the maximum latency allowed on the graph
- // this allows pins like the video capture preview pin to be more efficient with the amount
- // of buffering required to support the maximum graph latency
- HRESULT SetMaxStreamOffset (
- [in] REFERENCE_TIME rtMaxOffset
- );
-};
-
-
-// ------------------------------------------------------------------------
-//
-// IAMDeviceRemoval interface
-//
-// Implemented by filters to request and receive WM_DEVICECHANGE
-// notifications
-//
-// ------------------------------------------------------------------------
-
-[
- object,
- uuid(f90a6130-b658-11d2-ae49-0000f8754b99),
- pointer_default(unique)
-]
-interface IAMDeviceRemoval : IUnknown
-{
-
- HRESULT DeviceInfo(
- [out] CLSID *pclsidInterfaceClass,
- [out] WCHAR **pwszSymbolicLink);
-
- HRESULT Reassociate();
-
- HRESULT Disassociate();
-}
-
-//
-// for DV
-//
-typedef struct {
- //for 1st 5/6 DIF seq.
- DWORD dwDVAAuxSrc;
- DWORD dwDVAAuxCtl;
- //for 2nd 5/6 DIF seq.
- DWORD dwDVAAuxSrc1;
- DWORD dwDVAAuxCtl1;
- //for video information
- DWORD dwDVVAuxSrc;
- DWORD dwDVVAuxCtl;
- DWORD dwDVReserved[2];
-
-} DVINFO, *PDVINFO;
-
-// ------------------------------------------------------------------------
-//
-// IDVEnc interface
-//
-// Implemented by DV encoder filters to set Encoder format
-//
-// ------------------------------------------------------------------------
-enum _DVENCODERRESOLUTION { //resolution
- DVENCODERRESOLUTION_720x480 = 2012,
- DVENCODERRESOLUTION_360x240 = 2013,
- DVENCODERRESOLUTION_180x120 = 2014,
- DVENCODERRESOLUTION_88x60 = 2015
-};
-enum _DVENCODERVIDEOFORMAT { //PAL/ntsc
- DVENCODERVIDEOFORMAT_NTSC = 2000,
- DVENCODERVIDEOFORMAT_PAL = 2001
-};
-enum _DVENCODERFORMAT { // dvsd/dvhd/dvsl
- DVENCODERFORMAT_DVSD = 2007,
- DVENCODERFORMAT_DVHD = 2008,
- DVENCODERFORMAT_DVSL = 2009
-};
-[
- object,
- uuid(d18e17a0-aacb-11d0-afb0-00aa00b67a42),
- pointer_default(unique)
-]
-interface IDVEnc : IUnknown
-{
-
- HRESULT get_IFormatResolution (
- [out] int *VideoFormat, //pal or ntsc
- [out] int *DVFormat, //dvsd dvhd dvsl
- [out] int *Resolution, //720, 360, 180,88
- [in] BYTE fDVInfo, //TRUE: DVINFO structure exist, FALSE: Do not care DVINFO
- [out] DVINFO *sDVInfo //NULL if fDVInfo=FALSE,
- );
-
- HRESULT put_IFormatResolution (
- [in] int VideoFormat,
- [in] int DVFormat,
- [in] int Resolution,
- [in] BYTE fDVInfo, //TRUE: DVINFO structure exist, FALSE: Do not care DVINFO
- [in] DVINFO *sDVInfo //NULL if fDVInfo=FALSE,
- );
-
-}
-
-// ------------------------------------------------------------------------
-//
-// IDVDec interface
-//
-// Implemented by DV decoder filters to set decoder size
-//
-// ------------------------------------------------------------------------
-enum _DVDECODERRESOLUTION {
- DVDECODERRESOLUTION_720x480 = 1000,
- DVDECODERRESOLUTION_360x240 = 1001,
- DVDECODERRESOLUTION_180x120 = 1002,
- DVDECODERRESOLUTION_88x60 = 1003
-};
-enum _DVRESOLUTION {
- DVRESOLUTION_FULL = 1000,
- DVRESOLUTION_HALF = 1001,
- DVRESOLUTION_QUARTER = 1002,
- DVRESOLUTION_DC = 1003
-};
-[
- object,
- uuid(b8e8bd60-0bfe-11d0-af91-00aa00b67a42),
- pointer_default(unique)
-]
-interface IIPDVDec : IUnknown
-{
- HRESULT get_IPDisplay (
- [out] int *displayPix // The display pixels arrage
- );
-
- HRESULT put_IPDisplay (
- [in] int displayPix // Change to this display pixel arrage
- ) ;
-}
-
-//------------------------------------------------------------------------
-//
-// IDVRGB219 interface
-//
-// Implemented by both the DV encoder and decoder filters
-// Used for enabling the 219 mode in which the Range of RGB24 either received
-// by the encoder or produced by the decoder becomes (16,16,16)--(235,235,235)
-// instead of (0,0,0)--(255,255,255).
-// The interface's method has no effect in case of any other color space than
-// RGB 24
-//
-//------------------------------------------------------------------------
-
-[
- object,
- uuid(58473A19-2BC8-4663-8012-25F81BABDDD1),
- pointer_default(unique)
-]
-interface IDVRGB219 : IUnknown
-{
- HRESULT SetRGB219 ([in] BOOL bState); // State = True Turn 219 mode on else turn it off.
-}
-
-
-// ------------------------------------------------------------------------
-//
-// IDVSplitter interface
-//
-// Implemented by DV splitter filters
-//
-// ------------------------------------------------------------------------
-[
- object,
- uuid(92a3a302-da7c-4a1f-ba7e-1802bb5d2d02)
-]
-interface IDVSplitter : IUnknown
-{
- HRESULT DiscardAlternateVideoFrames(
- [in] int nDiscard
- ) ;
-}
-
-// Audio Renderer statistics params for IAMAudioRendererStats interface
-enum _AM_AUDIO_RENDERER_STAT_PARAM {
- AM_AUDREND_STAT_PARAM_BREAK_COUNT = 1, // audio breaks
- AM_AUDREND_STAT_PARAM_SLAVE_MODE, // current slave mode, see AM_AUDREND_SLAVE_MODEs
- AM_AUDREND_STAT_PARAM_SILENCE_DUR, // silence inserted due to gaps (ms)
- AM_AUDREND_STAT_PARAM_LAST_BUFFER_DUR, // duration of the last buffer received
- AM_AUDREND_STAT_PARAM_DISCONTINUITIES, // discontinuities seen since running
- AM_AUDREND_STAT_PARAM_SLAVE_RATE, // what rate are we currently slaving at? S_FALSE if not slaving
- AM_AUDREND_STAT_PARAM_SLAVE_DROPWRITE_DUR, // for waveOut slaving - data dropped or added to stay in-sync
- // dwParam1 - dropped duration(ms)
- // dwParam2 - paused duration(ms)
- AM_AUDREND_STAT_PARAM_SLAVE_HIGHLOWERROR, // highest & lowest clock differences seen
- // dwParam1 - high err
- // dwParam2 - low err
- AM_AUDREND_STAT_PARAM_SLAVE_LASTHIGHLOWERROR, // last high and low errs seen
- // dwParam1 - last high err
- // dwParam2 - last low err
- AM_AUDREND_STAT_PARAM_SLAVE_ACCUMERROR, // error between master/slave clocks
- AM_AUDREND_STAT_PARAM_BUFFERFULLNESS, // percent audio buffer fullness
- AM_AUDREND_STAT_PARAM_JITTER // input buffer jitter
-};
-
-//---------------------------------------------------------------------
-//
-// IAMAudioRendererStats interface
-//
-// Interface to get at statistical information that is optionally stored
-// in an audio renderer filter. Supported on the filter interface (although
-// this might be better for ksproxy if we define it as a pin interface?)
-//
-//---------------------------------------------------------------------
-
-[
-object,
- uuid(22320CB2-D41A-11d2-BF7C-D7CB9DF0BF93),
- pointer_default(unique)
-]
-interface IAMAudioRendererStats : IUnknown
-{
- // Get value corresponding to the passed in parameter id
- HRESULT GetStatParam(
- [in] DWORD dwParam,
- [out] DWORD *pdwParam1,
- [out] DWORD *pdwParam2
- );
-}
-
-//---------------------------------------------------------------------
-//
-// IAMLatency interface
-//
-// Allows a filter to report the expected latency associated with a data
-// stream flowing from its input to output pin. Supported on output pins.
-//
-//---------------------------------------------------------------------
-
-[
-object,
- uuid(62EA93BA-EC62-11d2-B770-00C04FB6BD3D),
- pointer_default(unique)
-]
-interface IAMLatency : IUnknown
-{
- HRESULT GetLatency(
- [in] REFERENCE_TIME *prtLatency
- );
-}
-
-
-enum _AM_INTF_SEARCH_FLAGS {
- AM_INTF_SEARCH_INPUT_PIN = 0x00000001, // search input pins
- AM_INTF_SEARCH_OUTPUT_PIN = 0x00000002, // search output pins
- AM_INTF_SEARCH_FILTER = 0x00000004 // search filters
-};
-
-//---------------------------------------------------------------------
-//
-// IAMGraphStreams interface
-//
-// Interface used to control or search over connected streams of data
-// flow within a filter graph.
-//
-//---------------------------------------------------------------------
-
-[
-object,
- uuid(632105FA-072E-11d3-8AF9-00C04FB6BD3D),
- pointer_default(unique)
-]
-interface IAMGraphStreams : IUnknown
-{
- // Search upstream from the current pin, for the specified interface.
- // dwFlags can be any combination of the AM_INTF_SEARCH_FLAGS, and allows
- // control over what objects to search. A value of 0 means to search all.
- HRESULT FindUpstreamInterface(
- [in] IPin *pPin,
- [in] REFIID riid,
- [out, iid_is(riid)] void **ppvInterface,
- [in] DWORD dwFlags );
-
- // Enable or disable the graph's setting of a timestamp offset
- // on push sources.
- HRESULT SyncUsingStreamOffset( [in] BOOL bUseStreamOffset );
-
- // allow an app to set the maximum offset used on push source filters
- HRESULT SetMaxGraphLatency( [in] REFERENCE_TIME rtMaxGraphLatency );
-}
-
-
-//
-// IAMOverlayFX
-//
-// This interface is exposed by the overlay mixer filter and allows
-// an application to apply various "effects" to the overlay surface
-// used by the overlay mixer.
-//
-// The effects that can be applied are described by the AMOVERLAYFX
-// enumeration.
-//
-enum AMOVERLAYFX {
- // Normal (ie. top down, left to right) video
- AMOVERFX_NOFX = 0x00000000,
-
- // Mirror the overlay across the vertical axis
- AMOVERFX_MIRRORLEFTRIGHT = 0x00000002,
-
- // Mirror the overlay across the horizontal axis
- AMOVERFX_MIRRORUPDOWN = 0x00000004,
-
- // Deinterlace the overlay, if possible
- AMOVERFX_DEINTERLACE = 0x00000008
-};
-
-[
-object,
- uuid(62fae250-7e65-4460-bfc9-6398b322073c),
- pointer_default(unique)
-]
-interface IAMOverlayFX : IUnknown
-{
- // Use this method to determine what overlay effects are currently available
- // for the overlay surface used by the overlay mixer filter.
- //
- HRESULT QueryOverlayFXCaps(
- [out] DWORD *lpdwOverlayFXCaps
- );
-
- // Use this method to apply a new overlay effect to the overlay surface
- // used by the overlay mixer filter. This method can be called while the
- // filter graph is running, the effect is applied immediately
- //
- HRESULT SetOverlayFX(
- [in] DWORD dwOverlayFX
- );
-
- // Use this method to determine what effect (if any) is currently being
- // applied to the overlay surface by the overlay mixer filter.
- //
- HRESULT GetOverlayFX(
- [out] DWORD *lpdwOverlayFX
- );
-}
-
-
-
-// IAMOpenProgress interface provides information about current progress through
-// a download
-
-[
-object,
-uuid(8E1C39A1-DE53-11cf-AA63-0080C744528D),
-pointer_default(unique)
-]
-
-interface IAMOpenProgress : IUnknown
-{
- // QueryProgress can be used to query the source filter which supports this interface
- // for progress information during a renderfile operation.
- HRESULT QueryProgress(
- [out] LONGLONG* pllTotal,
- [out] LONGLONG* pllCurrent
- );
-
- // AbortOperation can be used to request an abort of RenderFile operation
- // causing it to stop downloading. This methods instructs the exporter of
- // the IAMOpenProgress interface to hold up their internal abort flag until
- // further notice.
- HRESULT AbortOperation(
- );
-}
-
-
-/*++
- IMpeg2Demultiplexer
-
- This interface is implemented by the MPEG-2 Demultiplexer filter,
- irrespective of program vs. transport stream splitting functionality.
---*/
-[
- object,
- local,
- uuid (436eee9c-264f-4242-90e1-4e330c107512),
- pointer_default(unique)
-]
-interface IMpeg2Demultiplexer : IUnknown
-{
- /*++
- ------------------------------------------------------------------------
- purpose: Creates an output pin of the specified media type.
-
- pMediaType media type specifier for the new pin
- pszPinName pin name; cannot be a duplicate of an existing pin
- ppIPin IPin interface pointer to the newly created pin
- --*/
- HRESULT
- CreateOutputPin (
- [in] AM_MEDIA_TYPE * pMediaType,
- [in] LPWSTR pszPinName,
- [out] IPin ** ppIPin
- ) ;
-
- /*++
- ------------------------------------------------------------------------
- purpose: Updates the media type of the specified output pin. If no
- connection exists, the media type is updated always. If
- the pin is connected, the success/failure of the call will
- depend on downstream input pin's accetance/rejection of
- the specified media type, and subsequent success/failure
- of a reconnect.
-
- pszPinName pin name
- pMediaType new media type specifier
- --*/
- HRESULT
- SetOutputPinMediaType (
- [in] LPWSTR pszPinName,
- [in] AM_MEDIA_TYPE * pMediaType
- ) ;
-
- /*++
- ------------------------------------------------------------------------
- purpose: Deletes the specified output pin.
-
- pszPinName pin name
- --*/
- HRESULT
- DeleteOutputPin (
- [in] LPWSTR pszPinName
- ) ;
-} ;
-
-//---------------------------------------------------------------------
-// IEnumStreamIdMap interface
-//---------------------------------------------------------------------
-
-cpp_quote("#define MPEG2_PROGRAM_STREAM_MAP 0x00000000")
-cpp_quote("#define MPEG2_PROGRAM_ELEMENTARY_STREAM 0x00000001")
-cpp_quote("#define MPEG2_PROGRAM_DIRECTORY_PES_PACKET 0x00000002")
-cpp_quote("#define MPEG2_PROGRAM_PACK_HEADER 0x00000003")
-cpp_quote("#define MPEG2_PROGRAM_PES_STREAM 0x00000004")
-cpp_quote("#define MPEG2_PROGRAM_SYSTEM_HEADER 0x00000005")
-
-cpp_quote("#define SUBSTREAM_FILTER_VAL_NONE 0x10000000")
-
-typedef struct {
- ULONG stream_id ; // mpeg-2 stream_id
- DWORD dwMediaSampleContent ; // #define'd above
- ULONG ulSubstreamFilterValue ; // filtering value
- int iDataOffset ; // offset to elementary stream
-} STREAM_ID_MAP ;
-
-/*++
- Enumerates the StreamIds mapped on a pin
---*/
-[
- object,
- local,
- uuid (945C1566-6202-46fc-96C7-D87F289C6534),
- pointer_default(unique)
-]
-interface IEnumStreamIdMap : IUnknown
-{
- HRESULT
- Next (
- [in] ULONG cRequest,
- [in, out, size_is (cRequest)] STREAM_ID_MAP * pStreamIdMap,
- [out] ULONG * pcReceived
- ) ;
-
- HRESULT
- Skip (
- [in] ULONG cRecords
- ) ;
-
- HRESULT
- Reset (
- ) ;
-
- HRESULT
- Clone (
- [out] IEnumStreamIdMap ** ppIEnumStreamIdMap
- ) ;
-} ;
-
-/*++
- Implemented on the output pin.
-
- Provides the ability to map/unmap a stream_id to/from an output pin.
---*/
-[
- object,
- local,
- uuid (D0E04C47-25B8-4369-925A-362A01D95444),
- pointer_default(unique)
-]
-interface IMPEG2StreamIdMap : IUnknown
-{
- HRESULT
- MapStreamId (
- [in] ULONG ulStreamId, // mpeg-2 stream_id
- [in] DWORD MediaSampleContent, // #define'd above IEnumStreamIdMap
- [in] ULONG ulSubstreamFilterValue, // filter value
- [in] int iDataOffset // elementary stream offset
- ) ;
-
- HRESULT
- UnmapStreamId (
- [in] ULONG culStreamId, // number of stream_id's in pulStreamId
- [in] ULONG * pulStreamId // array of stream_id's to unmap
- ) ;
-
- HRESULT
- EnumStreamIdMap (
- [out] IEnumStreamIdMap ** ppIEnumStreamIdMap
- ) ;
-} ;
-
-
-// Register a service provider with the filter graph
-[
- object,
- local,
- uuid(7B3A2F01-0751-48DD-B556-004785171C54),
- pointer_default(unique)
-]
-interface IRegisterServiceProvider : IUnknown
-{
- // registers one service into it's internal table.. Object is refcounted.
- // register a NULL value to remove the service
- HRESULT RegisterService([in] REFGUID guidService, [in] IUnknown *pUnkObject);
-};
-
-
-
-//---------------------------------------------------------------------
-//
-// IAMClockSlave interface
-//
-// When the audio renderer is slaving to a separate graph clock this
-// interface provides a way for an app to specify how closely in sync
-// the slaving renderer should try to stay to the graph clock. Note that
-// using a larger tolerance for a video & audio playback graph will likely
-// result in looser a/v sync, so it recommended not to change this setting
-// except under special circumstances.
-//
-//---------------------------------------------------------------------
-
-//
-// Used to set/get the error tolerance used by a slaving audio renderer
-//
-[
-object,
- uuid(9FD52741-176D-4b36-8F51-CA8F933223BE),
- pointer_default(unique)
-]
-interface IAMClockSlave : IUnknown
-{
- // set millisecond value to use for slaving tolerance
- // the allowed range is 1 to 1000ms
- HRESULT SetErrorTolerance (
- [in] DWORD dwTolerance
- );
-
- // get millisecond value currently being used for slaving tolerance
- HRESULT GetErrorTolerance (
- [out] DWORD *pdwTolerance
- );
-};
-
-
-
-//---------------------------------------------------------------------
-//
-// IAMGraphBuilderCallback interface
-//
-// Interface which gives the app a chance to configure filters
-// before a connection is attempted.
-//
-// If this interface is supported by the site passed in to the graph
-// via IObjectWithSite::SetSite, the graph will call back with each
-// filter it creates as part of the Render or Connect process. Does
-// not call back for source filters. Filter may be discarded and not
-// used in graph or may be connected and disconnected more than once
-//
-// The callback occurs with the graph lock held, so do not call into
-// the graph again and do not wait on other threads calling into the
-// graph.
-//
-//---------------------------------------------------------------------
-
-[
- object,
- uuid(4995f511-9ddb-4f12-bd3b-f04611807b79),
- local,
- pointer_default(unique)
-]
-interface IAMGraphBuilderCallback : IUnknown
-{
- // graph builder selected a filter to create and attempt to
- // connect. failure indicates filter should be rejected.
- HRESULT SelectedFilter(
- [in] IMoniker *pMon
- );
-
- // app configures filter during this call. failure indicates
- // filter should be rejected.
- HRESULT CreatedFilter(
- [in] IBaseFilter *pFil
- );
-};
-
-cpp_quote("#ifdef __cplusplus")
-cpp_quote("#ifndef _IAMFilterGraphCallback_")
-cpp_quote("#define _IAMFilterGraphCallback_")
-cpp_quote("// Note: Because this interface was not defined as a proper interface it is")
-cpp_quote("// supported under C++ only. Methods aren't stdcall.")
-cpp_quote("EXTERN_GUID(IID_IAMFilterGraphCallback,0x56a868fd,0x0ad4,0x11ce,0xb0,0xa3,0x0,0x20,0xaf,0x0b,0xa7,0x70);")
-cpp_quote("interface IAMFilterGraphCallback : public IUnknown")
-cpp_quote("{")
-cpp_quote(" // S_OK means rendering complete, S_FALSE means retry now.")
-cpp_quote(" virtual HRESULT UnableToRender(IPin *pPin) = 0;")
-cpp_quote(" ")
-cpp_quote("};")
-cpp_quote("#endif // _IAMFilterGraphCallback_")
-cpp_quote("#endif")
-
-//------------------------------------------------------------------------------
-// File: EncAPI.idl
-//
-// Desc: Encoder (and future decoder) interface definitions.
-//
-// Copyright (c) 1992 - 2002, Microsoft Corporation. All rights reserved.
-//------------------------------------------------------------------------------
-
-struct CodecAPIEventData
-{
- GUID guid;
- DWORD dataLength;
- DWORD reserved[3];
- // BYTE data[dataLength];
-};
-
-interface IStream; // forward declaration
-//
-// Applications can pass the CODECAPI_VIDEO_ENCODER to IsSupported to test for video encoders
-// Similarly, the GUIDs for audio encoders, video decoders, audio decoders and muxes can be
-// used to test for the codec classification
-//
-// See uuids.h for a more detailed list.
-//
-[
- object,
- uuid(901db4c7-31ce-41a2-85dc-8fa0bf41b8da),
- pointer_default(unique)
-]
-interface ICodecAPI : IUnknown
-{
- //
- // IsSupported():
- //
- // Query whether a given parameter is supported.
- //
- HRESULT
- IsSupported (
- [in] const GUID *Api
- );
-
- //
- // IsModifiable
- //
- // Query whether a given parameter can be changed given the codec selection
- // and other parameter selections.
- //
- HRESULT
- IsModifiable (
- [in] const GUID *Api
- );
-
- //
- // GetParameterRange():
- //
- // Returns the valid range of values that the parameter supports should
- // the parameter support a stepped range as opposed to a list of specific
- // values. The support is [ValueMin .. ValueMax] by SteppingDelta.
- //
- // Ranged variant types must fall into one of the below types. Each
- // parameter will, by definition, return a specific type.
- //
- // If the range has no stepping delta (any delta will do), the Stepping
- // delta will be empty (VT_EMPTY).
- //
- HRESULT
- GetParameterRange (
- [in] const GUID *Api,
- [out] VARIANT *ValueMin,
- [out] VARIANT *ValueMax,
- [out] VARIANT *SteppingDelta
- );
-
- //
- // GetParameterValues():
- //
- // Returns the list of values supported by the given parameter as a
- // COM allocated array. The total number of values will be placed in
- // the ValuesCount parameter and the Values array will contain the
- // individual values. This array must be freed by the caller through
- // CoTaskMemFree().
- //
- HRESULT
- GetParameterValues (
- [in] const GUID *Api,
- [out, size_is(,*ValuesCount)] VARIANT **Values,
- [out] ULONG *ValuesCount
- );
-
- //
- // GetDefaultValue():
- //
- // Get the default value for a parameter, if one exists. Otherwise,
- // an error will be returned.
- //
- HRESULT
- GetDefaultValue (
- [in] const GUID *Api,
- [out] VARIANT *Value
- );
-
- //
- // GetValue():
- //
- // Get the current value of a parameter.
- //
- HRESULT
- GetValue (
- [in] const GUID *Api,
- [out] VARIANT *Value
- );
-
- //
- // SetValue():
- //
- // Set the current value of a parameter.
- //
- HRESULT
- SetValue (
- [in] const GUID *Api,
- [in] VARIANT *Value
- );
-
- // new methods beyond IEncoderAPI
-
- //
- // RegisterForEvent():
- //
- // Enable events to be reported for the given event GUID. For DShow
- // events, the event is returned as
- // (EC_CODECAPI_EVENT, lParam=userData, lParam2=CodecAPIEventData* Data)
- // where
- // - the CodecAPIEventData is COM allocated memory and must be handled and freed
- // by the application using CoTaskMemFree().
- // - the userData is the same pointer passed to RegisterForEvent
- //
- // Each data block starts with the following structure:
- // struct CodecAPIEventData
- // {
- // GUID guid;
- // DWORD dataLength;
- // DWORD reserved[3]; // pad to 16 byte alignment
- // BYTE data[dataLength];
- // }
- // The guid parameter identifies the event. The data associated with the event follows the
- // structure (represented by the variable length BYTE data[dataLength] array).
- //
- // If guid is equal to CODECAPI_CHANGELISTS, then data is an array of GUIDs that changed as
- // a result of setting the parameter, as follows:
- // GUID changedGuids[ header.dataLength / sizeof(GUID) ]
- //
- // The current array is limited, so a driver may send multiple messages if the array size is
- // exceeded.
- //
- HRESULT
- RegisterForEvent (
- [in] const GUID *Api,
- [in] LONG_PTR userData
- );
-
- //
- // UnregisterForEvent():
- //
- // Disable event reporting for the given event GUID.
- //
- HRESULT
- UnregisterForEvent (
- [in] const GUID *Api
- );
-
- //
- // SetAllDefaults
- //
- HRESULT SetAllDefaults(void);
-
- //
- // Extended SetValue & SetAllDefaults:
- //
- // Changes the current value of a parameter and returns back an alteration list
- //
- // The secondary arguments return back a list of other settings
- // that changed as a result of the SetValue() call (for UI updates etc)
- // The client must free the buffer.
- //
- HRESULT
- SetValueWithNotify (
- [in] const GUID *Api,
- [in] VARIANT *Value,
- [out, size_is(,*ChangedParamCount)] GUID **ChangedParam,
- [out] ULONG *ChangedParamCount
- );
-
- //
- // SetAllDefaultsWithNotify
- //
- HRESULT SetAllDefaultsWithNotify(
- [out, size_is(,*ChangedParamCount)] GUID **ChangedParam,
- [out] ULONG *ChangedParamCount
- );
- //
- // GetAllSettings
- // Load the current settings from a stream
- //
- HRESULT GetAllSettings( [in] IStream* );
-
- //
- // SetAllSettings
- // Save the current settings to a stream
- //
- HRESULT SetAllSettings( [in] IStream* );
-
- //
- // SetAllSettingsWithNotify
- //
- HRESULT SetAllSettingsWithNotify( IStream*,
- [out, size_is(,*ChangedParamCount)] GUID **ChangedParam,
- [out] ULONG *ChangedParamCount );
-}
-
-[
- object,
- local,
- uuid(a8809222-07bb-48ea-951c-33158100625b),
- pointer_default(unique)
-]
-interface IGetCapabilitiesKey : IUnknown
-{
- HRESULT GetCapabilitiesKey( [out] HKEY* pHKey );
-};
-
-// -----------------------------------------------------------------------------------------
-// From this point on, this is retained for backwards compatiblity only
-// Do not use this for future encoders
-// -----------------------------------------------------------------------------------------
-[
- object,
- uuid(70423839-6ACC-4b23-B079-21DBF08156A5),
- pointer_default(unique)
-]
-interface IEncoderAPI : IUnknown
-{
- HRESULT IsSupported ( [in] const GUID *Api );
- HRESULT IsAvailable ( [in] const GUID *Api );
- HRESULT GetParameterRange ( [in] const GUID *Api,
- [out] VARIANT *ValueMin, [out] VARIANT *ValueMax,
- [out] VARIANT *SteppingDelta );
- HRESULT GetParameterValues ( [in] const GUID *Api,
- [out, size_is(,*ValuesCount)] VARIANT **Values,
- [out] ULONG *ValuesCount );
- HRESULT GetDefaultValue ( [in] const GUID *Api, [out] VARIANT *Value );
- HRESULT GetValue ( [in] const GUID *Api, [out] VARIANT *Value );
- HRESULT SetValue ( [in] const GUID *Api, [in] VARIANT *Value );
-}
-
-[
- object,
- uuid(02997C3B-8E1B-460e-9270-545E0DE9563E),
- pointer_default(unique)
-]
-interface IVideoEncoder : IEncoderAPI
-{
-}
-//---------------------------------------------------------------------
-//
-// Old Encoder API Interfaces
-//
-//---------------------------------------------------------------------
-
-cpp_quote ("#ifndef __ENCODER_API_DEFINES__")
-cpp_quote ("#define __ENCODER_API_DEFINES__")
-
-typedef enum {
-
- //
- // Bit rate used for encoding is constant
- //
- ConstantBitRate = 0,
-
- //
- // Bit rate used for encoding is variable with the specified bitrate used
- // as a guaranteed average over a specified window. The default window
- // size is considered to be 5 minutes.
- //
- VariableBitRateAverage,
-
- //
- // Bit rate used for encoding is variable with the specified bitrate used
- // as a peak rate over a specified window. The default window size
- // is considered to be 500ms (classically one GOP).
- //
- VariableBitRatePeak
-
-} VIDEOENCODER_BITRATE_MODE;
-
-cpp_quote ("#endif // __ENCODER_API_DEFINES__")
-
-cpp_quote("#define AM_GETDECODERCAP_QUERY_VMR_SUPPORT 0x00000001")
-cpp_quote("#define VMR_NOTSUPPORTED 0x00000000")
-cpp_quote("#define VMR_SUPPORTED 0x00000001")
-
-cpp_quote("#define AM_QUERY_DECODER_VMR_SUPPORT 0x00000001")
-cpp_quote("#define AM_QUERY_DECODER_DXVA_1_SUPPORT 0x00000002")
-
-cpp_quote("#define AM_QUERY_DECODER_DVD_SUPPORT 0x00000003")
-cpp_quote("#define AM_QUERY_DECODER_ATSC_SD_SUPPORT 0x00000004")
-cpp_quote("#define AM_QUERY_DECODER_ATSC_HD_SUPPORT 0x00000005")
-cpp_quote("#define AM_GETDECODERCAP_QUERY_VMR9_SUPPORT 0x00000006")
-
-cpp_quote("#define DECODER_CAP_NOTSUPPORTED 0x00000000")
-cpp_quote("#define DECODER_CAP_SUPPORTED 0x00000001")
-
-[
- object,
- local,
- uuid(c0dff467-d499-4986-972b-e1d9090fa941),
- pointer_default(unique)
-]
-interface IAMDecoderCaps : IUnknown
-{
- HRESULT GetDecoderCaps([in] DWORD dwCapIndex, [out] DWORD* lpdwCap);
-};
-
-///////////////////////////////////////////////////////////////////////////////
-//
-// IAMCertifiedOutputProtection
-//
-///////////////////////////////////////////////////////////////////////////////
-typedef struct _AMCOPPSignature {
- BYTE Signature[256];
-} AMCOPPSignature;
-
-typedef struct _AMCOPPCommand {
- GUID macKDI; // 16 bytes
- GUID guidCommandID; // 16 bytes
- DWORD dwSequence; // 4 bytes
- DWORD cbSizeData; // 4 bytes
- BYTE CommandData[4056]; // 4056 bytes (4056+4+4+16+16 = 4096)
-} AMCOPPCommand, *LPAMCOPPCommand;
-
-typedef struct _AMCOPPStatusInput {
- GUID rApp; // 16 bytes
- GUID guidStatusRequestID;// 16 bytes
- DWORD dwSequence; // 4 bytes
- DWORD cbSizeData; // 4 bytes
- BYTE StatusData[4056]; // 4056 bytes (4056+4+4+16+16 = 4096)
-} AMCOPPStatusInput, *LPAMCOPPStatusInput;
-
-typedef struct _AMCOPPStatusOutput {
- GUID macKDI; // 16 bytes
- DWORD cbSizeData; // 4 bytes
- BYTE COPPStatus[4076]; // 4076 bytes (4076+16+4 = 4096)
-} AMCOPPStatusOutput, *LPAMCOPPStatusOutput;
-
-
-[
- object,
- local,
- uuid(6feded3e-0ff1-4901-a2f1-43f7012c8515),
- pointer_default(unique)
-]
-interface IAMCertifiedOutputProtection : IUnknown
-{
- HRESULT KeyExchange (
- [out] GUID* pRandom, // 128-bit random number generated by Graphics Driver
- [out] BYTE** VarLenCertGH, // Graphics Hardware certificate, memory released by CoTaskMemFree
- [out] DWORD* pdwLengthCertGH); // Length of Graphics Hardware certificate
-
- HRESULT SessionSequenceStart(
- [in] AMCOPPSignature*pSig); // Concatenation of 128-bit random data security session key,
- // 128-bit random data integrity session key, 32-bit random
- // starting status sequence number and 32-bit random starting
- // command sequence number encrypted with the public key of
- // the graphic hardware. This value is 2048 bits long.
-
- HRESULT ProtectionCommand(
- [in] const AMCOPPCommand* cmd); // Encrypted command
-
- HRESULT ProtectionStatus(
- [in] const AMCOPPStatusInput* pStatusInput, // Encrypted Status request
- [out] AMCOPPStatusOutput* pStatusOutput); // Encrypted Status results
-};
-