次の方法で共有


IMediaControl::P ause メソッド (control.h)

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

メソッドは Pause 、フィルター グラフ内のすべてのフィルターを一時停止します。

構文

HRESULT Pause();

戻り値

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

リターン コード 説明
S_FALSE
グラフは正常に一時停止しましたが、一部のフィルターでは状態遷移が完了していません。
S_OK
グラフ内のすべてのフィルターは、一時停止状態への移行を完了しました。

注釈

フィルター グラフを一時停止すると、グラフが次に実行されるときに、グラフがすぐにレンダリングされます。 グラフが一時停止されている間、フィルターはデータを処理しますが、レンダリングは行いません。 データはグラフを介してプッシュされ、バッファリングが許可されている限り変換フィルターによって処理されますが、レンダラー フィルターではデータはレンダリングされません。 ただし、ビデオ レンダラーでは、最初のサンプルの静的ポスター フレームが表示されます。

メソッドがS_FALSEを返す場合は、IMediaControl::GetState メソッドを呼び出して状態遷移が完了するまで待機するか、切り替えが完了した場合にチェックします。 を呼び出 Pause してビデオ ファイルの最初のフレームを表示する場合は、常に GetState の呼び出しですぐにフォローし、状態遷移が完了したことを確認します。 これを行わないと、ビデオの四角形が黒に塗りつぶされる可能性があります。

メソッドが失敗した場合、返される前にグラフが停止します。

要件

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

こちらもご覧ください

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

IMediaControl インターフェイス

IMediaControl::StopWhenReady