다음을 통해 공유


CDynamicOutputPin.ChangeMediaType 메서드

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

메서드는 ChangeMediaType 연결의 미디어 형식을 동적으로 변경합니다. 필터 그래프가 실행되는 동안 변경이 발생할 수 있습니다. 이 메서드가 호출되면 이전 미디어 형식의 샘플을 배달할 수 없습니다. 호출자는 보류 중인 이전 샘플이 없는지 확인해야 합니다.

구문

HRESULT ChangeMediaType(
   const CMediaType *pmt
);

매개 변수

Pmt

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

반환 값

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

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

설명

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

이 메서드는 먼저 다운스트림 입력 핀이 다시 연결하지 않고 새 형식을 수락할 수 있는지 여부를 확인합니다. IPinConnection 인터페이스에 대한 입력 핀을 쿼리합니다. 입력 핀이 IPinConnection을 지원하는 경우 메서드는 제안된 미디어 형식으로 IPinConnection::D ynamicQueryAccept 메서드를 호출합니다. 입력 핀이 새 미디어 형식을 수락하는 경우 메서드는 IPin::ReceiveConnection 메서드를 호출하고 할당자 요구 사항을 재협상합니다.

반면, 다운스트림 핀이 IPinConnection을 지원하지 않거나 새 미디어 형식을 거부하는 경우 메서드는 CDynamicOutputPin::D ynamicReconnect 메서드를 호출하여 동적 다시 연결을 수행합니다.

요구 사항

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

추가 정보

CDynamicOutputPin 클래스