다음을 통해 공유


IEnumFilters::Next 메서드(strmif.h)

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 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일 수 있습니다.

반환 값

Description
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 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

IEnumFilters 인터페이스