IMFSourceResolver::BeginCreateObjectFromByteStream メソッド (mfidl.h)
バイト ストリームからメディア ソースを作成するための非同期要求を開始します。
構文
HRESULT BeginCreateObjectFromByteStream(
[in] IMFByteStream *pByteStream,
[in] LPCWSTR pwszURL,
[in] DWORD dwFlags,
[in] IPropertyStore *pProps,
[out] IUnknown **ppIUnknownCancelCookie,
[in] IMFAsyncCallback *pCallback,
[in] IUnknown *punkState
);
パラメーター
[in] pByteStream
バイト ストリームの IMFByteStream インターフェイスへのポインター。
[in] pwszURL
バイト ストリームの元の URL を含む null で終わる文字列。 このパラメーターは、NULL でもかまいません。
[in] dwFlags
1 つ以上のフラグのビットごとの OR 。 「ソース リゾルバー フラグ」を参照してください。
[in] pProps
プロパティ ストアの IPropertyStore インターフェイスへのポインター。 メソッドは、プロパティ ストアをバイト ストリーム ハンドラーに渡します。 バイト ストリーム ハンドラーは、 プロパティ ストアを使用してメディア ソースを構成できます。 このパラメーターは、NULL でもかまいません。 詳細については、「 メディア ソースの構成」を参照してください。
[out] ppIUnknownCancelCookie
IUnknown ポインターまたは値 NULL を受け取ります。 値が NULL でない場合は、このポインターを IMFSourceResolver::CancelObjectCreation メソッドに渡すことで、非同期操作を取り消すことができます。 呼び出し元はインターフェイスを解放する必要があります。 このパラメーターは、NULL でもかまいません。
[in] pCallback
コールバック オブジェクトの IMFAsyncCallback インターフェイスへのポインター。 呼び出し元は、このインターフェイスを実装する必要があります。
[in] punkState
呼び出し元によって定義された状態オブジェクトの IUnknown インターフェイスへのポインター。 このパラメーターは、NULL でもかまいません。 このオブジェクトを使用して、状態情報を保持できます。 コールバックが呼び出されると、オブジェクトが呼び出し元に返されます。
戻り値
このメソッドは HRESULT を返します。 有効な値を次の表に示しますが、これ以外にもあります。
リターン コード | 説明 |
---|---|
|
メソッドが成功しました。 |
|
dwFlags パラメーターには、相互に排他的なフラグが含まれています。 |
|
バイト ストリームはサポートされていません。 |
|
バイト ストリームはシークをサポートしていません。 |
解説
dwFlags パラメーターには、MF_RESOLUTION_MEDIASOURCE フラグを含める必要があり、MF_RESOLUTION_BYTESTREAM フラグを含めてはいけません。
ソース リゾルバーは、URL のファイル名拡張子、またはバイト ストリームの MIME の種類 (またはその両方) に基づいて、バイト ストリームの 1 つ以上のバイト ストリーム ハンドラーの検索を試みます。 URL は省略可能な pwszURL パラメーターで指定され、MIME の種類はバイト ストリームの MF_BYTESTREAM_CONTENT_TYPE 属性で指定できます。 バイト ストリーム ハンドラーは、「 スキーム ハンドラーと Byte-Stream ハンドラー」で説明されているように、ファイル名拡張子または MIME の種類、またはその両方によって登録されます。 呼び出し元は、これらの値の少なくとも 1 つを指定する必要があります。
操作が完了すると、ソース リゾルバーは IMFAsyncCallback::Invoke メソッドを 呼び出します。 Invoke メソッドは、メディア ソースへのポインターを取得するために、IMFSourceResolver::EndCreateObjectFromByteStream を呼び出す必要があります。
要件
サポートされている最小のクライアント | Windows Vista [デスクトップ アプリのみ | UWP アプリ] |
サポートされている最小のサーバー | Windows Server 2008 [デスクトップ アプリ | UWP アプリ] |
対象プラットフォーム | Windows |
ヘッダー | mfidl.h |
Library | Mfuuid.lib |