CDynamicOutputPin.ChangeMediaType 메서드
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 ChangeMediaType
연결의 미디어 형식을 동적으로 변경합니다. 필터 그래프가 실행되는 동안 변경이 발생할 수 있습니다. 이 메서드가 호출되면 이전 미디어 형식의 샘플을 배달할 수 없습니다. 호출자는 보류 중인 이전 샘플이 없는지 확인해야 합니다.
구문
HRESULT ChangeMediaType(
const CMediaType *pmt
);
매개 변수
-
Pmt
-
미디어 형식을 지정하는 AM_MEDIA_TYPE 구조체에 대한 포인터입니다.
반환 값
HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.
반환 코드 | Description |
---|---|
|
성공. |
|
실패. 소유 필터가 CDynamicOutputPin::SetConfigInfo를 호출하지 않았을 수 있습니다. |
|
핀이 연결되어 있지 않습니다. |
설명
이 메서드를 호출하기 전에 CDynamicOutputPin::StartUsingOutputPin 메서드를 호출합니다.
이 메서드는 먼저 다운스트림 입력 핀이 다시 연결하지 않고 새 형식을 수락할 수 있는지 여부를 확인합니다. IPinConnection 인터페이스에 대한 입력 핀을 쿼리합니다. 입력 핀이 IPinConnection을 지원하는 경우 메서드는 제안된 미디어 형식으로 IPinConnection::D ynamicQueryAccept 메서드를 호출합니다. 입력 핀이 새 미디어 형식을 수락하는 경우 메서드는 IPin::ReceiveConnection 메서드를 호출하고 할당자 요구 사항을 재협상합니다.
반면, 다운스트림 핀이 IPinConnection을 지원하지 않거나 새 미디어 형식을 거부하는 경우 메서드는 CDynamicOutputPin::D ynamicReconnect 메서드를 호출하여 동적 다시 연결을 수행합니다.
요구 사항
요구 사항 | 값 |
---|---|
헤더 |
|
라이브러리 |
|