次の方法で共有


IEnumFilters::Next メソッド (strmif.h)

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

メソッドは Next 、列挙シーケンス内の指定された数のフィルターを取得します。

構文

HRESULT Next(
  [in]  ULONG       cFilters,
  [out] IBaseFilter **ppFilter,
  [out] ULONG       *pcFetched
);

パラメーター

[in] cFilters

取得するフィルターの数。

[out] ppFilter

IBaseFilter インターフェイス ポインターで埋められたサイズ cFilter の配列。 呼び出し元はインターフェイスを解放する必要があります。

[out] pcFetched

取得したフィルターの数を受け取ります。 cFilters が 1 の場合は NULL を指定できます。

戻り値

説明
S_FALSE 要求された数のフィルターを取得しませんでした。
S_OK 正常終了しました。
E_INVALIDARG 引数が無効です。
E_POINTER NULL ポインター引数。
VFW_E_ENUM_OUT_OF_SYNC グラフが変更され、列挙子と矛盾するようになりました。

注釈

メソッドが成功した場合、 IBaseFilter ポインターはすべて未処理の参照カウントを持ちます。 完了したら、必ず解放してください。

フィルター グラフが変更された場合 (たとえば、アプリケーションがフィルターを削除した場合)、列挙子はグラフと一致しなくなり、メソッドは VFW_E_ENUM_OUT_OF_SYNCを返します。 列挙子に対する以前の呼び出しから取得したデータは無効である可能性があるため、破棄します。 IEnumFilters::Reset メソッドを呼び出して列挙子を更新します。 その後、 メソッドを安全に Next 呼び出すことができます。

要件

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

こちらもご覧ください

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

IEnumFilters インターフェイス