次の方法で共有


IPin::BeginFlush メソッド (strmif.h)

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

メソッドは BeginFlush フラッシュ操作を開始します。

アプリケーションでは、このメソッドを呼び出さないでください。 このメソッドは、グラフからデータをフラッシュするために、他のフィルターによって呼び出されます。

構文

HRESULT BeginFlush();

戻り値

HRESULT 値を返します。 使用可能な値は次のとおりです。

リターン コード 説明
S_OK
正常終了しました。
E_UNEXPECTED
ピンは出力ピンです。

注釈

入力ピンでのみこのメソッドを呼び出します。 出力ピンはE_UNEXPECTEDを返します。

フラッシュ操作では、フィルターは処理していたデータを破棄します。 フラッシュが完了するまで、新しいデータが拒否されます。 アップストリーム ピンが IPin::EndFlush メソッドを呼び出すと、フラッシュが完了します。 フラッシュを使用すると、イベントによって通常のデータ フローが変更されたときに、フィルター グラフの応答性が向上します。 たとえば、フラッシュはシーク中に発生します。

が呼び出されると BeginFlush 、フィルターは次の手順を実行します。

  1. 呼び出しをダウンストリームに IPin::BeginFlush 渡します。
  2. IMemInputPin::Receive など、すべてのデータ ストリーミング メソッドが失敗する内部フラグを設定します。
  3. Receive メソッドへのブロックされた呼び出しからを返します。
通知が BeginFlush レンダラー フィルターに到達すると、レンダラーは保持しているサンプルをすべて解放します。

が呼び出された後 BeginFlush 、ピンは IPin::EndFlush メソッドが呼び出されるまで、S_FALSEの戻り値を持つアップストリームのすべてのサンプルを拒否します。

要件

要件
サポートされている最小のクライアント Windows 2000 Professional [デスクトップ アプリのみ]
サポートされている最小のサーバー Windows 2000 Server [デスクトップ アプリのみ]
対象プラットフォーム Windows
ヘッダー strmif.h (Dshow.h を含む)
Library Strmiids.lib

こちらもご覧ください

フィルター グラフのData Flow

エラーコードと成功コード

IPin インターフェイス