次の方法で共有


CBaseRenderer.PrepareReceive メソッド

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayerIMFMediaEngine、および Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、従来の API を使用する既存のコードを、可能であれば新しい API を使用するように書き直すよう提案しています。]

メソッドは PrepareReceive 、サンプルをレンダリングするためにフィルターを準備します。

構文

virtual HRESULT PrepareReceive(
   IMediaSample *pMediaSample
);

パラメーター

pMediaSample

サンプルの IMediaSample インターフェイスへのポインター。

戻り値

HRESULT 値を返します。 次の表に示す値を指定できます。

リターン コード 説明
S_OK
成功しました。
E_FAIL
失敗。
E_UNEXPECTED
予期しないエラー。
VFW_E_SAMPLE_REJECTED
フィルターは、このサンプルを削除しています。

解説

フィルターは、サンプルをレンダリングする前に、 CBaseRenderer::Receive メソッド内からこのメソッドを呼び出します。 フィルターが実行されている場合、このメソッドはサンプルのレンダリングをスケジュールします。

フィルターに既に保留中のサンプルがある場合、またはストリームの終了に既に達している場合、メソッドは E_UNEXPECTEDを返します。 アップストリーム フィルターがストリーミング呼び出しを正しくシリアル化していない可能性があります。

スケジュール アルゴリズムによってサンプルを削除する必要があると判断された場合 ( CBaseRenderer::ScheduleSample を参照)、メソッドは VFW_E_SAMPLE_REJECTEDを返します。 ただし、サンプルのドロップはエラーではないので、入力ピンの IMemInputPin::Receive メソッドはアップストリーム フィルターにこのエラー コードを渡しません。

要件

要件
ヘッダー
Renbase.h (include Streams.h)
ライブラリ
Strmbase.lib (小売ビルド);
Strmbasd.lib (デバッグ ビルド)

関連項目

CBaseRenderer クラス