次の方法で共有


CSourceStream.DoBufferProcessingLoop メソッド

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

メソッドは DoBufferProcessingLoop メディア データを生成し、ダウンストリーム入力ピンに配信します。

構文

virtual HRESULT DoBufferProcessingLoop();

パラメーター

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

戻り値

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

リターン コード 説明
S_FALSE
スレッドが停止要求を受信しました。
S_OK
ストリームが終了したか、ダウンストリーム フィルターがサンプルを受け入れていません。

解説

このメソッドは、データを処理してダウンストリームに配信するメイン ループを実装します。 ループを経るたびに、 メソッドはアロケーターから空のメディア サンプルを取得します。 サンプルを CSourceStream::FillBuffer メソッドに渡します。 派生クラスが実装する必要がある FillBuffer メソッドは、メディア データを生成し、サンプル バッファーに配置します。

ループは、次のいずれかが発生すると終了します。

  • 入力ピンの IMemInputPin::Receive メソッドはサンプルを拒否します。
  • FillBuffer メソッドは、ストリームの末尾を示すS_FALSEを返すか、エラー コードを返します。
  • スレッドは CSourceStream::Stop 要求を受け取ります。

メソッドは DoBufferProcessingLoop 、ストリームの終了通知を処理します。 エラーが発生すると、フィルター グラフ マネージャーに EC_ERRORABORT イベントが送信されます。

要件

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

関連項目

CSourceStream クラス