다음을 통해 공유


필터 정보 선언

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

첫 번째 단계는 필요한 경우 필터 정보를 선언하는 것입니다. DirectShow는 필터, 핀 및 미디어 유형을 설명하는 다음 구조를 정의합니다.

구조체 설명
AMOVIESETUP_FILTER 필터를 설명합니다.
AMOVIESETUP_PIN 핀에 대해 설명합니다.
AMOVIESETUP_MEDIATYPE 미디어 형식을 설명합니다.

 

이러한 구조체는 중첩됩니다. AMOVEIESETUP_FILTER 구조체에는 AMOVIESETUP_PIN 구조체의 배열에 대한 포인터가 있으며, 각 구조체에는 AMOVEIESETUP_MEDIATYPE 구조체 배열에 대한 포인터가 있습니다. 이러한 구조를 종합하면 IFilterMapper2 인터페이스가 필터를 찾을 수 있는 충분한 정보를 제공합니다. 필터에 대한 전체 설명이 아닙니다. 예를 들어 필터가 동일한 핀의 여러 인스턴스를 만드는 경우 해당 핀에 대해 하나의 AMOVIESETUP_PIN 구조만 선언해야 합니다. 또한 필터는 등록하는 미디어 형식의 모든 조합을 지원할 필요가 없습니다. 지원되는 모든 미디어 형식을 등록하는 데 도 필요하지 않습니다.

DLL 내에서 설정 구조를 전역 변수로 선언합니다. 다음 예제에서는 하나의 출력 핀이 있는 필터를 보여줍니다.

static const WCHAR g_wszName[] = L"Some Filter";

AMOVIESETUP_MEDIATYPE sudMediaTypes[] = {
    { &MEDIATYPE_Video, &MEDIASUBTYPE_RGB24 },
    { &MEDIATYPE_Video, &MEDIASUBTYPE_RGB32 },
};

AMOVIESETUP_PIN sudOutputPin = {
    L"",            // Obsolete, not used.
    FALSE,          // Is this pin rendered?
    TRUE,           // Is it an output pin?
    FALSE,          // Can the filter create zero instances?
    FALSE,          // Does the filter create multiple instances?
    &GUID_NULL,     // Obsolete.
    NULL,           // Obsolete.
    2,              // Number of media types.
    sudMediaTypes   // Pointer to media types.
};

AMOVIESETUP_FILTER sudFilterReg = {
    &CLSID_SomeFilter,      // Filter CLSID.
    g_wszName,              // Filter name.
    MERIT_NORMAL,           // Merit.
    1,                      // Number of pin types.
    &sudOutputPin           // Pointer to pin information.
};

필터 이름은 다른 곳에서 다시 사용되므로 정적 전역 변수로 선언됩니다.

DirectShow 필터를 등록하는 방법