次の方法で共有


CBaseRenderer.SendEndOfStream メソッド

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

ストリームの終了に達した場合、メソッドは SendEndOfStream フィルター グラフ マネージャーのEC_COMPLETE イベントをスケジュールします。

構文

virtual HRESULT SendEndOfStream();

パラメーター

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

戻り値

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

リターン コード 説明
S_FALSE
フィルター グラフ マネージャーがイベント通知を受け入れていません。
S_OK
成功しました。

解説

フィルターは、現在のサンプルの停止時間の前にストリームの終了通知を受け取る場合があります。 その場合、フィルターは、フィルター グラフ マネージャーに EC_COMPLETE 通知を投稿する前に待機する必要があります。

そのため、次のようになります。

  • フィルターが早期ストリーム終了 (EOS) 通知を受信した場合、このメソッドはタイマー イベントをスケジュールします。 タイマー イベントがアクティブ化されると、フィルターによって EC_COMPLETE イベントがポストされます。
  • フィルターが早期ではない EOS 通知を受信した場合、このメソッドは EC_COMPLETE イベントを直ちにポストします。
  • フィルターに保留中の EOS 通知がない場合、メソッドは何もせずに を返します。

タイマー コールバック メソッドは CBaseRenderer::TimerCallback です。 EC_COMPLETE イベントを配信するために、フィルターは CBaseRenderer::NotifyEndOfStream メソッドを 呼び出します。

要件

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

関連項目

CBaseRenderer クラス