IEnumMediaTypes::Next 메서드(strmif.h)
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드가 DirectShow 대신 Media Foundation에서 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
Next 메서드는 지정된 수의 미디어 형식을 검색합니다.
구문
HRESULT Next(
[in] ULONG cMediaTypes,
[out] AM_MEDIA_TYPE **ppMediaTypes,
[out] ULONG *pcFetched
);
매개 변수
[in] cMediaTypes
검색할 미디어 형식의 수입니다.
[out] ppMediaTypes
AM_MEDIA_TYPE 포인터 배열의 주소입니다. 배열의 요소 수는 cMediaTypes 매개 변수에 제공됩니다.
[out] pcFetched
ppMediaTypes에서 반환된 미디어 형식의 수를 받습니다. cMediaTypes가 1인 경우 이 매개 변수는 NULL일 수 있습니다.
반환 값
다음 HRESULT 값 중 하나를 반환합니다.
반환 코드 | 설명 |
---|---|
|
요청된 만큼 많은 미디어 형식을 검색하지 않았습니다. |
|
성공. |
|
인수가 잘못되었습니다. |
|
NULL 포인터 인수입니다. |
|
핀의 상태가 변경되었으며 이제 열거자와 일치하지 않습니다. |
설명
호출자는 ppMediaTypes에서 AM_MEDIA_TYPE 포인터 배열을 전달합니다. 메서드는 cMediaTypes와 같은 개수 AM_MEDIA_TYPE 구조체 또는 열거형에 남아 있는 미디어 형식의 수에 할당합니다. 할당된 구조체의 수는 pcFetched에 반환됩니다. DeleteMediaType 함수를 호출하여 각 구조를 삭제합니다.
미디어 형식 집합이 변경되면 열거자가 소유 핀과 일치하지 않게 됩니다. 이 경우 메서드는 VFW_E_ENUM_OUT_OF_SYNC 반환합니다. 열거자에 대한 이전 호출에서 얻은 모든 데이터는 유효하지 않을 수 있으므로 삭제합니다. IEnumMediaTypes::Reset 메서드를 호출하여 열거자를 업데이트합니다. 그런 다음 Next 메서드를 안전하게 호출할 수 있습니다.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | strmif.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |