mirror of https://github.com/UMSKT/xpmgr.git
654 lines
25 KiB
Plaintext
654 lines
25 KiB
Plaintext
//------------------------------------------------------------------------------
|
|
// File: MFTransform.idl
|
|
//
|
|
// Desc: Define the interfaces for Media Foundation Transforms. This file will be
|
|
// processed by the MIDL tool to produce MFTransform.h and proxy-stub code.
|
|
//
|
|
// Copyright (c) 1999 - 2003, Microsoft Corporation. All rights reserved.
|
|
//------------------------------------------------------------------------------
|
|
|
|
import "mfobjects.idl";
|
|
|
|
// Per-buffer flags that apply to input buffers
|
|
enum _MFT_INPUT_DATA_BUFFER_FLAGS {
|
|
//
|
|
// Not carried over from DMO (IMediaObject), but should be
|
|
// reserved so no new MFT flag clashes with them:
|
|
//
|
|
// DMO_INPUT_DATA_BUFFER_SYNCPOINT = 0x00000001,
|
|
// DMO_INPUT_DATA_BUFFER_TIME = 0x00000002,
|
|
// DMO_INPUT_DATA_BUFFER_TIMELENGTH = 0x00000004
|
|
|
|
MFT_INPUT_DATA_BUFFER_PLACEHOLDER = 0xFFFFFFFF // right now there are no flags defined
|
|
};
|
|
|
|
// Per-buffer flags that apply to output buffers.
|
|
enum _MFT_OUTPUT_DATA_BUFFER_FLAGS {
|
|
//
|
|
// Not carried over from DMO (IMediaObject), but should be
|
|
// reserved so no new MFT flag clashes with them:
|
|
//
|
|
// DMO_OUTPUT_DATA_BUFFER_SYNCPOINT = 0x00000001,
|
|
// DMO_OUTPUT_DATA_BUFFER_TIME = 0x00000002,
|
|
// DMO_OUTPUT_DATA_BUFFER_TIMELENGTH = 0x00000004,
|
|
|
|
//
|
|
// This flag means the object can produce more samples without any more input.
|
|
//
|
|
MFT_OUTPUT_DATA_BUFFER_INCOMPLETE = 0x01000000,
|
|
|
|
//
|
|
// New for MFT
|
|
//
|
|
MFT_OUTPUT_DATA_BUFFER_FORMAT_CHANGE = 0x00000100,
|
|
MFT_OUTPUT_DATA_BUFFER_STREAM_END = 0x00000200,
|
|
MFT_OUTPUT_DATA_BUFFER_NO_SAMPLE = 0x00000300
|
|
|
|
};
|
|
|
|
// Flags returned by GetInputStatusFlags()
|
|
enum _MFT_INPUT_STATUS_FLAGS {
|
|
//
|
|
// Carried over from DMO (IMediaObject)
|
|
//
|
|
|
|
//
|
|
// ACCEPT_DATA indicates that the input stream is ready to accept
|
|
// new data via ProcessInput().
|
|
//
|
|
MFT_INPUT_STATUS_ACCEPT_DATA = 0x00000001
|
|
};
|
|
|
|
// Flags returned by GetOutputStatusFlags()
|
|
enum _MFT_OUTPUT_STATUS_FLAGS {
|
|
//
|
|
// New for MFT
|
|
//
|
|
|
|
//
|
|
// SAMPLE_READY indicates that a sample is available on at least one
|
|
// of the output streams, and a call to ProcessOutput will
|
|
// retrieve it.
|
|
//
|
|
MFT_OUTPUT_STATUS_SAMPLE_READY = 0x00000001
|
|
};
|
|
|
|
// Flags returned by GetInputStreamInfo()
|
|
enum _MFT_INPUT_STREAM_INFO_FLAGS {
|
|
//
|
|
// Carried over from DMO (IMediaObject)
|
|
//
|
|
MFT_INPUT_STREAM_WHOLE_SAMPLES = 0x00000001,
|
|
MFT_INPUT_STREAM_SINGLE_SAMPLE_PER_BUFFER = 0x00000002,
|
|
MFT_INPUT_STREAM_FIXED_SAMPLE_SIZE = 0x00000004,
|
|
MFT_INPUT_STREAM_HOLDS_BUFFERS = 0x00000008,
|
|
|
|
//
|
|
// New for MFT
|
|
//
|
|
MFT_INPUT_STREAM_DOES_NOT_ADDREF = 0x00000100,
|
|
MFT_INPUT_STREAM_REMOVABLE = 0x00000200,
|
|
MFT_INPUT_STREAM_OPTIONAL = 0x00000400,
|
|
MFT_INPUT_STREAM_PROCESSES_IN_PLACE = 0x00000800
|
|
};
|
|
|
|
// Flags returned by GetOutputStreamInfo()
|
|
enum _MFT_OUTPUT_STREAM_INFO_FLAGS {
|
|
//
|
|
// Carried over from DMO (IMediaObject)
|
|
//
|
|
MFT_OUTPUT_STREAM_WHOLE_SAMPLES = 0x00000001,
|
|
MFT_OUTPUT_STREAM_SINGLE_SAMPLE_PER_BUFFER = 0x00000002,
|
|
MFT_OUTPUT_STREAM_FIXED_SAMPLE_SIZE = 0x00000004,
|
|
MFT_OUTPUT_STREAM_DISCARDABLE = 0x00000008,
|
|
MFT_OUTPUT_STREAM_OPTIONAL = 0x00000010,
|
|
|
|
//
|
|
// New for MFT
|
|
//
|
|
MFT_OUTPUT_STREAM_PROVIDES_SAMPLES = 0x00000100,
|
|
MFT_OUTPUT_STREAM_CAN_PROVIDE_SAMPLES = 0x00000200,
|
|
MFT_OUTPUT_STREAM_LAZY_READ = 0x00000400,
|
|
MFT_OUTPUT_STREAM_REMOVABLE = 0x00000800
|
|
};
|
|
|
|
// SetType flags
|
|
enum _MFT_SET_TYPE_FLAGS {
|
|
//
|
|
// Carried over from DMO (IMediaObject)
|
|
//
|
|
MFT_SET_TYPE_TEST_ONLY = 0x00000001,// check but don't set
|
|
|
|
//
|
|
// not carried over from DMO - use NULL type to unset.
|
|
//
|
|
//MFT_SET_TYPE_CLEAR = 0x00000002 // unset
|
|
};
|
|
|
|
//
|
|
// ProcessOutput() dwFlags (signals from caller to MFT)
|
|
//
|
|
enum _MFT_PROCESS_OUTPUT_FLAGS {
|
|
//
|
|
// Carried over from DMO (IMediaObject)
|
|
//
|
|
MFT_PROCESS_OUTPUT_DISCARD_WHEN_NO_BUFFER = 0x00000001 // discard this sample if pSample ptr is NULL.
|
|
};
|
|
|
|
//
|
|
// ProcessOutput() pdwStatus (output from MFT to caller)
|
|
//
|
|
enum _MFT_PROCESS_OUTPUT_STATUS {
|
|
//
|
|
// new for MFT
|
|
//
|
|
MFT_PROCESS_OUTPUT_STATUS_NEW_STREAMS = 0x00000100 // Output flag
|
|
};
|
|
|
|
enum _MFT_DRAIN_TYPE {
|
|
MFT_DRAIN_PRODUCE_TAILS = 0x00000000,
|
|
MFT_DRAIN_NO_TAILS = 0x00000001
|
|
};
|
|
|
|
//
|
|
// used by GetStreamLimits - the transform returns it in *pdwInputMaximum or *pdwOutputMaximum
|
|
// to mean that the MFT has no theoretical stream limit.
|
|
//
|
|
cpp_quote( "#define MFT_STREAMS_UNLIMITED 0xFFFFFFFF" )
|
|
|
|
//
|
|
// Used by SetOutputBounds when the lower or upper limit are unbounded.
|
|
//
|
|
cpp_quote( "#define MFT_OUTPUT_BOUND_LOWER_UNBOUNDED MINLONGLONG" )
|
|
cpp_quote( "#define MFT_OUTPUT_BOUND_UPPER_UNBOUNDED MAXLONGLONG" )
|
|
|
|
typedef enum _MFT_MESSAGE_TYPE {
|
|
//
|
|
// commands - must be acted on
|
|
//
|
|
MFT_MESSAGE_COMMAND_FLUSH = 0x00000000,
|
|
MFT_MESSAGE_COMMAND_DRAIN = 0x00000001,
|
|
MFT_MESSAGE_SET_D3D_MANAGER = 0x00000002,
|
|
#if (WINVER >= _WIN32_WINNT_WIN7)
|
|
MFT_MESSAGE_DROP_SAMPLES = 0x00000003,
|
|
#endif // (WINVER >= _WIN32_WINNT_WIN7)
|
|
|
|
//
|
|
// notifications - no action required; effect is transform-dependent
|
|
//
|
|
MFT_MESSAGE_NOTIFY_BEGIN_STREAMING = 0x10000000,
|
|
MFT_MESSAGE_NOTIFY_END_STREAMING = 0x10000001,
|
|
MFT_MESSAGE_NOTIFY_END_OF_STREAM = 0x10000002,
|
|
|
|
//
|
|
// send by pipeline before processing the first sample
|
|
//
|
|
MFT_MESSAGE_NOTIFY_START_OF_STREAM = 0x10000003,
|
|
|
|
#if (WINVER >= _WIN32_WINNT_WIN7)
|
|
//
|
|
// commands (applicable to async MFTs only) - must be acted on
|
|
//
|
|
MFT_MESSAGE_COMMAND_MARKER = 0x20000000
|
|
#endif // (WINVER >= _WIN32_WINNT_WIN7)
|
|
|
|
} MFT_MESSAGE_TYPE;
|
|
|
|
typedef struct _MFT_INPUT_STREAM_INFO {
|
|
LONGLONG hnsMaxLatency; // maximum time latency in 100ns increments
|
|
DWORD dwFlags; // MFT_INPUT_STREAM_INFO_FLAGS
|
|
DWORD cbSize; // size of each sample's buffer
|
|
DWORD cbMaxLookahead; // max total bytes held
|
|
DWORD cbAlignment; // buffer alignment requirement
|
|
} MFT_INPUT_STREAM_INFO;
|
|
|
|
typedef struct _MFT_OUTPUT_STREAM_INFO {
|
|
DWORD dwFlags; // MFT_INPUT_STREAM_INFO_FLAGS
|
|
DWORD cbSize; // size of each sample's buffer
|
|
DWORD cbAlignment; // buffer alignment requirement
|
|
} MFT_OUTPUT_STREAM_INFO;
|
|
|
|
//
|
|
// Output buffer info structure: one of these must be passed in for each
|
|
// output stream with every ProcessOutput() call
|
|
// All [out] fields should be
|
|
// assumed undefined if ProcessOutput() failed
|
|
//
|
|
typedef struct _MFT_OUTPUT_DATA_BUFFER {
|
|
DWORD dwStreamID; // [in] which stream is this for
|
|
IMFSample * pSample; // [in/out] can be NULL
|
|
DWORD dwStatus; // [out] MFT_OUTPUT_DATA_BUFFER_FLAGS (INCOMPLETE, etc.)
|
|
IMFCollection * pEvents; // [out] Can be NULL. Zero or more events produced by the MFT
|
|
} MFT_OUTPUT_DATA_BUFFER, *PMFT_OUTPUT_DATA_BUFFER;
|
|
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// redefine all the method names to have MFT at the beginning so they don't class with DMO methods." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "#ifdef MFT_UNIQUE_METHOD_NAMES" )
|
|
cpp_quote( "#define GetStreamLimits MFTGetStreamLimits" )
|
|
cpp_quote( "#define GetStreamCount MFTGetStreamCount" )
|
|
cpp_quote( "#define GetStreamIDs MFTGetStreamIDs" )
|
|
cpp_quote( "#define GetInputStreamInfo MFTGetInputStreamInfo" )
|
|
cpp_quote( "#define GetOutputStreamInfo MFTGetOutputStreamInfo" )
|
|
cpp_quote( "#define DeleteInputStream MFTDeleteInputStream" )
|
|
cpp_quote( "#define AddInputStreams MFTAddInputStreams" )
|
|
cpp_quote( "#define GetInputAvailableType MFTGetInputAvailableType" )
|
|
cpp_quote( "#define GetOutputAvailableType MFTGetOutputAvailableType" )
|
|
cpp_quote( "#define SetInputType MFTSetInputType" )
|
|
cpp_quote( "#define SetOutputType MFTSetOutputType" )
|
|
cpp_quote( "#define GetInputCurrentType MFTGetInputCurrentType" )
|
|
cpp_quote( "#define GetOutputCurrentType MFTGetOutputCurrentType" )
|
|
cpp_quote( "#define GetInputStatus MFTGetInputStatus" )
|
|
cpp_quote( "#define GetOutputStatus MFTGetOutputStatus" )
|
|
cpp_quote( "#define SetOutputBounds MFTSetOutputBounds" )
|
|
cpp_quote( "#define ProcessEvent MFTProcessEvent" )
|
|
cpp_quote( "#define ProcessMessage MFTProcessMessage" )
|
|
cpp_quote( "#define ProcessInput MFTProcessInput" )
|
|
cpp_quote( "#define ProcessOutput MFTProcessOutput" )
|
|
cpp_quote( "#endif" )
|
|
|
|
// Interface supported by media objects
|
|
[
|
|
object,
|
|
uuid(bf94c121-5b05-4e6f-8000-ba598961414d)
|
|
]
|
|
interface IMFTransform : IUnknown
|
|
{
|
|
|
|
//
|
|
// Stream enumeration
|
|
//
|
|
HRESULT
|
|
GetStreamLimits(
|
|
[out] DWORD *pdwInputMinimum,
|
|
[out] DWORD *pdwInputMaximum,
|
|
[out] DWORD *pdwOutputMinimum,
|
|
[out] DWORD *pdwOutputMaximum
|
|
);
|
|
|
|
HRESULT
|
|
GetStreamCount(
|
|
[out] DWORD *pcInputStreams,
|
|
[out] DWORD *pcOutputStreams
|
|
);
|
|
|
|
HRESULT
|
|
GetStreamIDs(
|
|
DWORD dwInputIDArraySize,
|
|
[out,size_is(dwInputIDArraySize)] DWORD *pdwInputIDs,
|
|
DWORD dwOutputIDArraySize,
|
|
[out,size_is(dwOutputIDArraySize)] DWORD *pdwOutputIDs
|
|
);
|
|
|
|
HRESULT
|
|
GetInputStreamInfo(
|
|
DWORD dwInputStreamID,
|
|
[out] MFT_INPUT_STREAM_INFO * pStreamInfo
|
|
);
|
|
|
|
HRESULT
|
|
GetOutputStreamInfo(
|
|
DWORD dwOutputStreamID,
|
|
[out] MFT_OUTPUT_STREAM_INFO * pStreamInfo
|
|
);
|
|
|
|
HRESULT
|
|
GetAttributes(
|
|
[out] IMFAttributes** pAttributes
|
|
);
|
|
|
|
HRESULT
|
|
GetInputStreamAttributes(
|
|
DWORD dwInputStreamID,
|
|
[out] IMFAttributes** pAttributes
|
|
);
|
|
|
|
HRESULT
|
|
GetOutputStreamAttributes(
|
|
DWORD dwOutputStreamID,
|
|
[out] IMFAttributes** pAttributes
|
|
);
|
|
|
|
HRESULT
|
|
DeleteInputStream(
|
|
DWORD dwStreamID
|
|
);
|
|
|
|
HRESULT
|
|
AddInputStreams(
|
|
DWORD cStreams,
|
|
[in] DWORD * adwStreamIDs
|
|
);
|
|
|
|
|
|
//
|
|
// Mediatypes
|
|
//
|
|
//
|
|
// GetxxxAvailableType - iterate through media types supported by a stream.
|
|
//
|
|
HRESULT
|
|
GetInputAvailableType(
|
|
DWORD dwInputStreamID,
|
|
DWORD dwTypeIndex, // 0-based
|
|
[out] IMFMediaType ** ppType
|
|
);
|
|
HRESULT
|
|
GetOutputAvailableType(
|
|
DWORD dwOutputStreamID,
|
|
DWORD dwTypeIndex, // 0-based
|
|
[out] IMFMediaType ** ppType
|
|
);
|
|
|
|
//
|
|
// SetxxxType - tell the object the type of data it will work with.
|
|
//
|
|
HRESULT
|
|
SetInputType(
|
|
DWORD dwInputStreamID,
|
|
[in] IMFMediaType *pType,
|
|
DWORD dwFlags
|
|
);
|
|
HRESULT
|
|
SetOutputType(
|
|
DWORD dwOutputStreamID,
|
|
[in] IMFMediaType *pType,
|
|
DWORD dwFlags
|
|
);
|
|
|
|
//
|
|
// GetxxxCurrentType - get the current type set for the given stream index.
|
|
//
|
|
HRESULT
|
|
GetInputCurrentType(
|
|
DWORD dwInputStreamID,
|
|
[out] IMFMediaType ** ppType
|
|
);
|
|
HRESULT
|
|
GetOutputCurrentType(
|
|
DWORD dwOutputStreamID,
|
|
[out] IMFMediaType ** ppType
|
|
);
|
|
|
|
//
|
|
// Streaming / state methods
|
|
//
|
|
// GetInputStatus - the only flag defined right now is MFT_INPUT_STATUS_ACCEPT_DATA.
|
|
HRESULT
|
|
GetInputStatus(
|
|
DWORD dwInputStreamID,
|
|
[out] DWORD * pdwFlags // MFT_INPUT_STATUS_ACCEPT_DATA
|
|
);
|
|
|
|
// GetOutputStatus - the only flag defined right now is MFT_OUTPUT_STATUS_SAMPLE_READY.
|
|
HRESULT
|
|
GetOutputStatus(
|
|
[out] DWORD *pdwFlags
|
|
);
|
|
|
|
//
|
|
// SetOutputBounds - optional interface to tell transform the desired
|
|
// range of output times desired. Implementation is optional.
|
|
//
|
|
HRESULT
|
|
SetOutputBounds(
|
|
LONGLONG hnsLowerBound,
|
|
LONGLONG hnsUpperBound
|
|
);
|
|
|
|
HRESULT
|
|
ProcessEvent(
|
|
DWORD dwInputStreamID,
|
|
[in] IMFMediaEvent * pEvent
|
|
);
|
|
|
|
//
|
|
// ProcessMessage - used to send a notification or command to a transform
|
|
//
|
|
HRESULT
|
|
ProcessMessage(
|
|
MFT_MESSAGE_TYPE eMessage,
|
|
ULONG_PTR ulParam
|
|
);
|
|
|
|
//
|
|
// Pass one new buffer to an input stream
|
|
//
|
|
[local] HRESULT
|
|
ProcessInput(
|
|
DWORD dwInputStreamID,
|
|
IMFSample * pSample,
|
|
DWORD dwFlags
|
|
);
|
|
|
|
//
|
|
// ProcessOutput() - generate output for current input buffers
|
|
//
|
|
// Output stream specific status information is returned in the
|
|
// dwStatus member of each buffer wrapper structure.
|
|
//
|
|
[local] HRESULT
|
|
ProcessOutput(
|
|
DWORD dwFlags, // MFT_PROCESS_OUTPUT_FLAGS
|
|
DWORD cOutputBufferCount, // # returned by GetStreamCount()
|
|
[in,out,size_is(cOutputBufferCount)]
|
|
MFT_OUTPUT_DATA_BUFFER *pOutputSamples, // one per stream
|
|
[out] DWORD * pdwStatus // MFT_PROCESS_OUTPUT_XXX
|
|
);
|
|
|
|
};
|
|
|
|
cpp_quote("#if (WINVER >= _WIN32_WINNT_WIN7) ")
|
|
typedef struct _STREAM_MEDIUM
|
|
{
|
|
GUID gidMedium;
|
|
UINT32 unMediumInstance;
|
|
} STREAM_MEDIUM, *PSTREAM_MEDIUM;
|
|
cpp_quote("#endif // (WINVER >= _WIN32_WINNT_WIN7) ")
|
|
|
|
cpp_quote( "//" )
|
|
cpp_quote( "// Define the MFT methods back so we don't accidentally hose the IMediaObject interface." )
|
|
cpp_quote( "//" )
|
|
cpp_quote( "#ifdef MFT_UNIQUE_METHOD_NAMES" )
|
|
cpp_quote( "#undef GetStreamLimits " )
|
|
cpp_quote( "#undef GetStreamCount " )
|
|
cpp_quote( "#undef GetStreamIDs " )
|
|
cpp_quote( "#undef GetInputStreamInfo " )
|
|
cpp_quote( "#undef GetOutputStreamInfo " )
|
|
cpp_quote( "#undef DeleteInputStream " )
|
|
cpp_quote( "#undef AddInputStreams " )
|
|
cpp_quote( "#undef GetInputAvailableType " )
|
|
cpp_quote( "#undef GetOutputAvailableType " )
|
|
cpp_quote( "#undef SetInputType " )
|
|
cpp_quote( "#undef SetOutputType " )
|
|
cpp_quote( "#undef GetInputCurrentType " )
|
|
cpp_quote( "#undef GetOutputCurrentType " )
|
|
cpp_quote( "#undef GetInputStatus " )
|
|
cpp_quote( "#undef GetOutputStatus " )
|
|
cpp_quote( "#undef SetOutputBounds " )
|
|
cpp_quote( "#undef ProcessMessage " )
|
|
cpp_quote( "#undef ProcessInput " )
|
|
cpp_quote( "#undef ProcessOutput " )
|
|
cpp_quote( "#endif" )
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// GENERIC DMO PROPERTY KEYS
|
|
//
|
|
|
|
// All MFTs
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY PROPERTYKEY MFPKEY_CLSID = { { 0xc57a84c0, 0x1a80, 0x40a3, {0x97, 0xb5, 0x92, 0x72, 0xa4, 0x3, 0xc8, 0xae} }, 0x01 }; ")
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY PROPERTYKEY MFPKEY_CATEGORY = { { 0xc57a84c0, 0x1a80, 0x40a3, {0x97, 0xb5, 0x92, 0x72, 0xa4, 0x3, 0xc8, 0xae} }, 0x02 }; ")
|
|
|
|
// ExAttribute-supported MFTs
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY PROPERTYKEY MFPKEY_EXATTRIBUTE_SUPPORTED = { { 0x456fe843, 0x3c87, 0x40c0, {0x94, 0x9d, 0x14, 0x9, 0xc9, 0x7d, 0xab, 0x2c} }, 0x01 }; ")
|
|
|
|
// Audio Multichannel
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY PROPERTYKEY MFPKEY_MULTICHANNEL_CHANNEL_MASK = { { 0x58bdaf8c, 0x3224, 0x4692, { 0x86, 0xd0, 0x44, 0xd6, 0x5c, 0x5b, 0xf8, 0x2b } }, 0x01 }; ")
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// GENERIC MFT ATTRIBUTES
|
|
|
|
// MF_SA_D3D_AWARE
|
|
// Data type: UINT32
|
|
// If present and set to a nonzero value, indicates that this transform is
|
|
// D3D-aware and can accept a D3D manager via the MFT_MESSAGE_SET_D3D_MANAGER
|
|
// message.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_SA_D3D_AWARE = { 0xeaa35c29, 0x775e, 0x488e, { 0x9b, 0x61, 0xb3, 0x28, 0x3e, 0x49, 0x58, 0x3b } }; ")
|
|
|
|
// MF_SA_REQUIRED_SAMPLE_COUNT
|
|
// Data type: UINT32
|
|
// If present, indicates the number of samples that an MFT requires to be
|
|
// allocated. This value is used if the next node downstream has an
|
|
// IMFVideoSampleAllocator.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_SA_REQUIRED_SAMPLE_COUNT = { 0x18802c61, 0x324b, 0x4952, { 0xab, 0xd0, 0x17, 0x6f, 0xf5, 0xc6, 0x96, 0xff } };" )
|
|
|
|
cpp_quote("#if (WINVER >= _WIN32_WINNT_WIN7) ")
|
|
// MF_TRANSFORM_ASYNC
|
|
// Data type: UINT32
|
|
// If present and set to a nonzero value, indicates that this MFT functions
|
|
// as an asynchronous MFT. Only callers that understand how to call
|
|
// an asynchronous MFT can use this MFT; those callers need to set the
|
|
// MF_TRANSFORM_ASYNC_UNLOCK before making any IMFTransform calls.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_TRANSFORM_ASYNC = { 0xf81a699a, 0x649a, 0x497d, { 0x8c, 0x73, 0x29, 0xf8, 0xfe, 0xd6, 0xad, 0x7a } };" )
|
|
|
|
// MF_TRANSFORM_ASYNC_UNLOCK
|
|
// Data type: UINT32
|
|
// This attribute is set by the caller (not the MFT) on the MFT's attributes
|
|
// store. This is relevant only if the MFT has set the MF_TRANSFORM_ASYNC
|
|
// attribute to a nonzero value. Callers that plan to use such an MFT must
|
|
// first set this attribute to 1; otherwise all IMFTransform calls will fail
|
|
// with MF_E_TRANSFORM_ASYNC_LOCKED.
|
|
// The Media Foundation pipeline will set this attribute if appropriate;
|
|
// applications using this transform in a topology using the MF pipeline should
|
|
// not set it directly.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_TRANSFORM_ASYNC_UNLOCK = { 0xe5666d6b, 0x3422, 0x4eb6, { 0xa4, 0x21, 0xda, 0x7d, 0xb1, 0xf8, 0xe2, 0x7 } };" )
|
|
|
|
|
|
// MF_TRANSFORM_FLAGS_Attribute
|
|
// Data type: UINT32
|
|
// This attribute is set on the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_TRANSFORM_FLAGS_Attribute = { 0x9359bb7e, 0x6275, 0x46c4, { 0xa0, 0x25, 0x1c, 0x1, 0xe4, 0x5f, 0x1a, 0x86 } };" )
|
|
|
|
// MF_TRANSFORM_CATEGORY_Attribute
|
|
// Data type: GUID
|
|
// MFTEnumEx stores this on the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MF_TRANSFORM_CATEGORY_Attribute = { 0xceabba49, 0x506d, 0x4757, { 0xa6, 0xff, 0x66, 0xc1, 0x84, 0x98, 0x7e, 0x4e } };" )
|
|
|
|
// MFT_TRANSFORM_CLSID_Attribute
|
|
// Data type: GUID
|
|
// MFTEnumEx stores this in the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT. CMFTransformActivate's
|
|
// ActivateObject function creates an instance of the CoClass with this
|
|
// CLSID that implements the MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_TRANSFORM_CLSID_Attribute = { 0x6821c42b, 0x65a4, 0x4e82, { 0x99, 0xbc, 0x9a, 0x88, 0x20, 0x5e, 0xcd, 0xc } };" )
|
|
|
|
// MFT_INPUT_TYPES_Attributes
|
|
// Data type: BLOB
|
|
// MFTEnumEx stores this in the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT. This is a blob that contains
|
|
// Major and Subtype GUID paris for each type supported by the input pins of
|
|
// the MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_INPUT_TYPES_Attributes = { 0x4276c9b1, 0x759d, 0x4bf3, { 0x9c, 0xd0, 0xd, 0x72, 0x3d, 0x13, 0x8f, 0x96 } };" )
|
|
|
|
// MFT_OUTPUT_TYPES_Attributes
|
|
// Data type: BLOB
|
|
// MFTEnumEx stores this in the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT. This is a blob that contains
|
|
// Major and Subtype GUID paris for each type supported by the output pins of
|
|
// the MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_OUTPUT_TYPES_Attributes = { 0x8eae8cf3, 0xa44f, 0x4306, { 0xba, 0x5c, 0xbf, 0x5d, 0xda, 0x24, 0x28, 0x18 } };" )
|
|
|
|
// MFT_ENUM_HARDWARE_URL_Attribute
|
|
// Data type: WSTR
|
|
// MFTEnumEx stores this on the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT. Applications pass
|
|
// this attribute to source resolver to create media source that
|
|
// wraps a hardware.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_ENUM_HARDWARE_URL_Attribute = { 0x2fb866ac, 0xb078, 0x4942, { 0xab, 0x6c, 0x0, 0x3d, 0x5, 0xcd, 0xa6, 0x74 } };" )
|
|
|
|
// MFT_FRIENDLY_NAME_Attribute
|
|
// Data type: WSTR
|
|
// MFTEnumEx stores this on the attribute store of IMFActivate object
|
|
// that MFTEnumEx creates for every enumerated MFT. Applications
|
|
// use this attribute to display a readable name for the device
|
|
// represented by the HW MFT.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_FRIENDLY_NAME_Attribute = { 0x314ffbae, 0x5b41, 0x4c95, { 0x9c, 0x19, 0x4e, 0x7d, 0x58, 0x6f, 0xac, 0xe3 } };" )
|
|
|
|
// MFT_CONNECTED_STREAM_ATTRIBUTE
|
|
// Data type: IUnknown
|
|
// For hardware MFTs, this attribute on the output stream holds
|
|
// the IMFAttributes from the input stream. The MFT can query
|
|
// this object for information it needs to perform medium negotiation
|
|
// or other functions dependant on information from the downstream MFT
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_CONNECTED_STREAM_ATTRIBUTE = { 0x71eeb820, 0xa59f, 0x4de2, {0xbc, 0xec, 0x38, 0xdb, 0x1d, 0xd6, 0x11, 0xa4} };" )
|
|
// MFT_CONNECTED_TO_HW_STREAM
|
|
// Data type: UINT32
|
|
// When two hardware MFT streams get connected, this attribute would be set to TRUE.
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_CONNECTED_TO_HW_STREAM = { 0x34e6e728, 0x6d6, 0x4491, { 0xa5, 0x53, 0x47, 0x95, 0x65, 0xd, 0xb9, 0x12 } };" )
|
|
|
|
// MFT_PREFERRED_OUTPUTTYPE_Attribute
|
|
// Data type: IUnknown, which should be IMFMediaType
|
|
// Application uses this attribute to store
|
|
// the HW encoder MFT preferred output media type
|
|
// on the IMFActivate object that MFTEnumEx creates.
|
|
// When HW encoder is created, the media type will be
|
|
// set as its current output media type.
|
|
// {7E700499-396A-49ee-B1B4-F628021E8C9D}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_PREFERRED_OUTPUTTYPE_Attribute = { 0x7e700499, 0x396a, 0x49ee, { 0xb1, 0xb4, 0xf6, 0x28, 0x2, 0x1e, 0x8c, 0x9d } };" )
|
|
|
|
// MFT_PROCESS_LOCAL_Attribute
|
|
// Data type: UINT32, which should be a BOOL
|
|
// This attribute is stored with a value of TRUE in the IActivate object for in-process registered MFTs
|
|
// {543186E4-4649-4e65-B588-4AA352AFF379}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_PROCESS_LOCAL_Attribute = { 0x543186e4, 0x4649, 0x4e65, { 0xb5, 0x88, 0x4a, 0xa3, 0x52, 0xaf, 0xf3, 0x79 } };" )
|
|
|
|
// MFT_PREFERRED_ENCODER_PROFILE
|
|
// Data type: IUnknown
|
|
// The IUnknown is a pointer to IMFAttributes interface.
|
|
// This attribute store stores preferred encoder profile
|
|
// settings.
|
|
// {53004909-1EF5-46d7-A18E-5A75F8B5905F}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_PREFERRED_ENCODER_PROFILE = { 0x53004909, 0x1ef5, 0x46d7, { 0xa1, 0x8e, 0x5a, 0x75, 0xf8, 0xb5, 0x90, 0x5f } };" )
|
|
|
|
// MFT_HW_TIMESTAMP_WITH_QPC_Attribute
|
|
// Data type: BOOLEAN
|
|
// When this attribute is TRUE, it indicates to a hardware MFT to timestamp outgoing samples with system time (QueryPerformanceCounter value)
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_HW_TIMESTAMP_WITH_QPC_Attribute = { 0x8d030fb8, 0xcc43, 0x4258, { 0xa2, 0x2e, 0x92, 0x10, 0xbe, 0xf8, 0x9b, 0xe4 } };" )
|
|
|
|
// MFT_FIELDOFUSE_UNLOCK_Attribute
|
|
// Data type: IUnknown
|
|
// This attribute stores the interface to unlock the field-of-use MFTs.
|
|
// {8EC2E9FD-9148-410d-831E-702439461A8E}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_FIELDOFUSE_UNLOCK_Attribute = { 0x8ec2e9fd, 0x9148, 0x410d, { 0x83, 0x1e, 0x70, 0x24, 0x39, 0x46, 0x1a, 0x8e } };" )
|
|
|
|
// MFT_CODEC_MERIT_Attribute
|
|
// Data type: UINT32
|
|
// This attribute is attached to the MFT activator object and stores the merit if the MFT if it has one.
|
|
// {88a7cb15-7b07-4a34-9128-e64c6703c4d3}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_CODEC_MERIT_Attribute = { 0x88a7cb15, 0x7b07, 0x4a34, { 0x91, 0x28, 0xe6, 0x4c, 0x67, 0x3, 0xc4, 0xd3 } };" )
|
|
|
|
// MFT_ENUM_TRANSCODE_ONLY_ATTRIBUTE
|
|
// Data type: UINT32
|
|
// This attribute is attached to the MFT activator object and specifies if the MFT could be used in a transcode topology. If set to 1 then it
|
|
// should be used only in a transcode topology. If set to 0 then it could be used in transcode or playback topology. Currently this is used
|
|
// only by devproxy based HW MFTs.
|
|
// {111EA8CD-B62A-4bdb-89F6-67FFCDC2458B}
|
|
cpp_quote( "EXTERN_C const DECLSPEC_SELECTANY GUID MFT_ENUM_TRANSCODE_ONLY_ATTRIBUTE = { 0x111ea8cd, 0xb62a, 0x4bdb, { 0x89, 0xf6, 0x67, 0xff, 0xcd, 0xc2, 0x45, 0x8b } };" )
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Media Foundation MFT Activate creation functions
|
|
//
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
cpp_quote( "STDAPI" )
|
|
cpp_quote( "MFCreateTransformActivate(" )
|
|
cpp_quote( " __out IMFActivate** ppActivate" )
|
|
cpp_quote( " );" )
|
|
cpp_quote("#endif // (WINVER >= _WIN32_WINNT_WIN7) ")
|
|
|