Share via


ICreateDevEnum::CreateClassEnumerator 메서드(strmif.h)

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

CreateClassEnumerator 메서드는 지정된 디바이스 범주에 대한 열거자를 만듭니다.

구문

HRESULT CreateClassEnumerator(
  [in]  REFCLSID     clsidDeviceClass,
  [out] IEnumMoniker **ppEnumMoniker,
  [in]  DWORD        dwFlags
);

매개 변수

[in] clsidDeviceClass

디바이스 범주의 CLSID(클래스 식별자)를 지정합니다. 필터 범주를 참조하세요.

[out] ppEnumMoniker

IEnumMoniker 인터페이스에 대한 포인터를 받습니다. 호출자는 인터페이스를 해제해야 합니다.

[in] dwFlags

0개 이상의 플래그의 비트 조합입니다. 0이면 메서드는 범주의 모든 필터를 열거합니다. 플래그가 설정된 경우 열거형에는 지정된 플래그와 일치하는 필터만 포함됩니다. 다음 플래그가 정의됩니다.

플래그 설명
CDEF_DEVMON_CMGR_DEVICE ACM(오디오 압축 관리자) 또는 VCM(비디오 압축 관리자)을 사용하여 오디오 또는 비디오 코덱을 열거합니다.
CDEF_DEVMON_DMO DMO(DirectX Media Objects)를 열거합니다.
CDEF_DEVMON_FILTER 네이티브 DirectShow 필터를 열거합니다.
CDEF_DEVMON_PNP_DEVICE 플러그 앤 플레이 하드웨어 디바이스를 열거합니다.

반환 값

다음 HRESULT 값 중 하나를 반환합니다.

반환 코드 Description
S_OK
성공.
E_OUTOFMEMORY
메모리가 부족합니다.
S_FALSE
clsidDeviceClass로 지정된 범주가 없거나 비어 있습니다.
E_POINTER
NULL 포인터 인수입니다.

설명

범주가 없거나 비어 있으면 반환 값이 S_FALSE ppEnumMoniker 매개 변수는 NULL 값을 받습니다. 따라서 SUCCEEDED 매크로를 사용하는 대신 반환 값 S_OK 테스트합니다.

C++
IEnumMoniker *pEnum = NULL;
hr = pSysDevEnum->CreateClassEnumerator(
    CLSID_VideoCompressorCategory, &pEnum, 0);
if (hr == S_OK) 
{
    // Safe to dereference pEnum.
    pEnum->Release();
}
IEnumMoniker 인터페이스를 사용하여 디바이스 범주의 필터를 나타내는 모니커를 열거합니다. 모니커는 IMoniker 인터페이스를 지원합니다. CreateClassEnumerator에서 만든 모니커도 IGetCapabilitiesKey 인터페이스를 지원합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

ICreateDevEnum 인터페이스