次の方法で共有


CTransInPlaceFilter.Receive メソッド

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

メソッドは Receive 、メディア サンプルを受け取り、それを処理し、ダウンストリーム フィルターに配信します。

構文

HRESULT Receive(
   IMediaSample *pSample
);

パラメーター

pSample

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

戻り値

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

リターン コード 説明
S_OK
Success
E_UNEXPECTED
予期しないエラーが発生しました。

解説

フィルターの入力ピンは、サンプルを受信したときにこのメソッドを呼び出します。 フィルターは、派生クラスが実装する必要がある Transform メソッドを呼び出します。 Transform メソッドはデータを処理します。 フィルターが 1 つのアロケーターのみを使用している場合は、 pSampleTransform メソッドに直接渡します。 それ以外の場合は、 pSample をコピーし、コピーを渡します。

Transform メソッドが S_FALSEを返す場合、メソッドはReceiveサンプルを削除します。 最初にドロップされたサンプルでは、フィルターは EC_QUALITY_CHANGE イベントをフィルター グラフ マネージャーに送信します。 それ以外の場合、 Transform メソッドが S_OKを返す場合、フィルターは出力サンプルを配信します。 これを行うには、ダウンストリーム入力ピンで IMemInputPin::Receive メソッドを呼び出します。

要件

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

関連項目

CTransInPlaceFilter クラス