ICaptureGraphBuilder::ControlStream メソッド (strmif.h)
[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayer、IMFMediaEngine、Audio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ API を使用する既存のコードを、可能であれば新しい API を使用するように書き換えるよう提案しています。]
構文
HRESULT ControlStream(
[in] const GUID *pCategory,
[in] IBaseFilter *pFilter,
[in] REFERENCE_TIME *pstart,
[in] REFERENCE_TIME *pstop,
[in] WORD wStartCookie,
[in] WORD wStopCookie
);
パラメーター
[in] pCategory
出力ピン カテゴリを指定する GUID へのポインター。 すべてのピン カテゴリの一覧については、「 Pin プロパティ セット 」を参照してください。 この値を NULL にすることはできません。
[in] pFilter
制御するフィルターの IBaseFilter インターフェイスへのポインター。 NULL を指定すると、グラフ内のすべてのキャプチャ フィルターが制御されます。 キャプチャ フィルターごとに 1 つの通知が表示されます。
[in] pstart
キャプチャの開始時刻へのポインター。 NULL は、今すぐ開始を意味します。 MAX_TIME は、前の要求を取り消すか、以前の要求がない場合は何も行いません。
[in] pstop
キャプチャの停止時間へのポインター。 NULL は、今すぐ停止を意味します。 MAX_TIME は、前の要求を取り消すか、以前の要求がない場合は何も行いません。
[in] wStartCookie
開始時に送信される特定の値を指定します。
[in] wStopCookie
停止が発生したときに送信される特定の値を指定します。
戻り値
キャプチャ フィルターによって送信された最後のサンプルがレンダリングされる前に停止通知が送信された場合はS_FALSEを返し、それ以外の場合はS_OKを返します。
このメソッドがS_FALSEを返す場合、アプリケーションはフィルター グラフを停止する前に待機して、すべてのサンプルがグラフを通過してレンダリングできるようにする場合があります。 そうしないと、サンプルが失われる可能性があります。
指定した説明に一致するピンがない場合、または指定されたすべてのピンでストリーム 制御をサポートできない場合、この関数はエラー コードを返します。
解説
フレーム精度のキャプチャ、またはキャプチャとプレビューの個々の制御には、このメソッドを使用します。 たとえば、キャプチャしたイメージのみをプレビューする場合は、キャプチャしたイメージのディスクへの書き込みをオフにすることができます。
このメソッドでは、ピンで IAMStreamControl インターフェイスを使用します。
このメソッドは、指定したカテゴリのピンで検出されたフィルターごとに 1 つの通知を送信します。
要件
対象プラットフォーム | Windows |
ヘッダー | strmif.h (Dshow.h を含む) |