다음을 통해 공유


CDynamicOutputPin.ChangeOutputFormat 메서드

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

메서드는 ChangeOutputFormat 연결에 대한 미디어 형식을 동적으로 변경하고 새 세그먼트 정보를 제공합니다. 필터 그래프가 실행되는 동안 변경이 발생할 수 있습니다. 이 메서드가 호출되면 이전 미디어 형식의 샘플을 전달할 수 없습니다. 호출자는 보류 중인 이전 샘플이 없는지 확인해야 합니다.

구문

HRESULT ChangeOutputFormat(
   const AM_MEDIA_TYPE  *pmt,
         REFERENCE_TIME tSegmentStart,
         REFERENCE_TIME tSegmentStop,
         double         dSegmentRate
);

매개 변수

Pmt

미디어 형식을 지정하는 AM_MEDIA_TYPE 구조체에 대한 포인터입니다.

tSegmentStart

세그먼트의 시작 시간입니다.

tSegmentStop

세그먼트의 중지 시간입니다.

dSegmentRate

세그먼트 속도입니다.

반환 값

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

반환 코드 Description
S_OK
성공.
E_FAIL
실패. 소유 필터가 CDynamicOutputPin::SetConfigInfo를 호출하지 않았을 수 있습니다.
VFW_E_NOT_CONNECTED
핀이 연결되어 있지 않습니다.

설명

이 메서드는 필터가 실행되는 동안 형식 형식을 변경합니다. 다운스트림 핀이 새 형식을 수락하는 경우 다시 연결할 필요가 없습니다. 그렇지 않으면 메서드가 핀을 다시 연결하려고 시도합니다. 메서드가 형식을 성공적으로 변경하면 새 세그먼트 정보를 제공합니다. 이 메서드는 CDynamicOutputPin::ChangeMediaType 메서드를 호출하여 형식 변경을 수행합니다.

이 메서드를 호출하기 전에 CDynamicOutputPin::StartUsingOutputPin 메서드를 호출해야 합니다.

요구 사항

요구 사항
헤더
Amfilter.h(Streams.h 포함)
라이브러리
Strmbase.lib(소매 빌드);
Strmbasd.lib(디버그 빌드)

추가 정보

CDynamicOutputPin 클래스