次の方法で共有


CBaseInputPin.ReceiveCanBlock メソッド

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

メソッドは ReceiveCanBlockIMemInputPin::Receive メソッドの呼び出しがブロックされる可能性があるかどうかを判断します。 このメソッドは、 IMemInputPin::ReceiveCanBlock メソッドを 実装します。

構文

HRESULT ReceiveCanBlock();

パラメーター

このメソッドにはパラメーターはありません。

戻り値

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

リターン コード 説明
S_FALSE
このピンは、 Receive の呼び出しではブロックされません。
S_OK
受信の呼び出しでピンがブロックされる場合があります。

解説

Receive メソッドの呼び出しがブロックされないことが保証されている場合は、S_FALSEを返します。 それ以外の場合は、S_OKまたはエラー コードを返します。 Receive メソッドがダウンストリーム ピンで Receive を呼び出すと、ダウンストリーム ピンがブロックされる可能性があります。ReceiveCanBlockは、その要素を考慮する必要があります。

アップストリーム フィルターでは、このメソッドを使用してスレッド戦略を決定できます。 Receive メソッドがブロックする可能性がある場合、アップストリーム フィルターは、データをバッファーするワーカー スレッドを使用することを決定する場合があります。 この戦略の実装については、 COutputQueue クラスを参照してください。

基底クラスでは、次のいずれかが当てはまる場合、このメソッドはS_OKを返します。

  • フィルターには出力ピンがありません。
  • このフィルターに接続された入力ピンは、ブロックする可能性があることを通知します。
  • このフィルターに接続されている入力ピンは 、IMemInputPin インターフェイスをサポートしていません。

要件

要件
ヘッダー
Amfilter.h (Streams.h を含む)
ライブラリ
Strmbase.lib (製品版ビルド);
Strmbasd.lib (デバッグ ビルド)

関連項目

CBaseInputPin クラス