다음을 통해 공유


IFilterMapper2::RegisterFilter 메서드(strmif.h)

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

메서드는 RegisterFilter 레지스트리에 필터 정보를 추가합니다.

구문

HRESULT RegisterFilter(
  [in]      REFCLSID         clsidFilter,
  [in]      LPCWSTR          Name,
  [in, out] IMoniker         **ppMoniker,
  [in]      const CLSID      *pclsidCategory,
  [in]      LPCOLESTR        szInstance,
  [in]      const REGFILTER2 *prf2
);

매개 변수

[in] clsidFilter

필터의 CLSID(클래스 식별자)입니다.

[in] Name

필터의 설명이 포함된 이름입니다.

[in, out] ppMoniker

이 필터의 데이터를 쓸 위치를 결정하는 디바이스 모니커에 대한 포인터의 주소입니다. NULL일 수 있습니다.

[in] pclsidCategory

필터의 필터 범주에 대한 포인터입니다. NULL이면 기본 범주가 CLSID_ActiveMovieFilters. ( 필터 범주를 참조하세요.)

[in] szInstance

디바이스 모니커의 표시 이름을 생성하기 위한 인스턴스 데이터입니다. 식별 이름 또는 필터 CLSID의 문자열 표현일 수 있습니다. NULL인 경우 는 기본적으로 CLSID 필터로 설정됩니다.

[in] prf2

필터 정보를 포함하는 REGFILTER2 구조체에 대한 포인터입니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.

반환 코드 Description
S_OK
성공.
VFW_E_BAD_KEY
레지스트리 키를 가져올 수 없습니다.

설명

이 메서드는 지정된 필터 범주의 레지스트리 항목 아래에 있는 레지스트리에 필터에 대한 정보를 추가합니다. 필터를 만드는 프로세스 내 서버(일반적으로 DLL)는 등록하지 않습니다. 서버를 등록하려면 AMovieDllRegisterServer2 함수를 호출할 수 있습니다.

ppMoniker 매개 변수의 경우 다음 중 하나를 사용합니다.

  • 기존 디바이스 모 니커에 대한 IMoniker 인터페이스 포인터의 주소
  • NULLIMoniker 인터페이스 포인터의 주소
  • NULL
WDM(Windows 드라이버 모델) 또는 플러그 앤 플레이 디바이스에 대한 필터를 등록하는 경우 기존 디바이스 모니커의 주소를 전달합니다. 필터는 이 모니커를 사용하여 등록됩니다. 메서드가 반환되면 *ppMonikerNULL로 설정됩니다.

그렇지 않으면 메서드는 새 모니커를 만듭니다. ppMonikerNULL이 아닌 경우 메서드는 *ppMoniker를 새 모니커를 가리키도록 설정합니다. 애플리케이션은 이 모니커를 사용하여 속성 모음에 추가 프라이빗 값을 쓸 수 있습니다. 인터페이스를 해제해야 합니다.

모니커를 제공하거나 받지 않으려면 ppMonikerNULL 로 설정합니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IFilterMapper2 인터페이스