mirror of
				https://github.com/halpz/re3.git
				synced 2025-10-24 23:47:19 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			5170 lines
		
	
	
		
			171 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			5170 lines
		
	
	
		
			171 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // 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
 | |
| };
 | |
| 
 |