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 |
---|---|
|
성공. |
|
실패. 소유 필터가 CDynamicOutputPin::SetConfigInfo를 호출하지 않았을 수 있습니다. |
|
핀이 연결되어 있지 않습니다. |
설명
이 메서드는 필터가 실행되는 동안 형식 형식을 변경합니다. 다운스트림 핀이 새 형식을 수락하는 경우 다시 연결할 필요가 없습니다. 그렇지 않으면 메서드가 핀을 다시 연결하려고 시도합니다. 메서드가 형식을 성공적으로 변경하면 새 세그먼트 정보를 제공합니다. 이 메서드는 CDynamicOutputPin::ChangeMediaType 메서드를 호출하여 형식 변경을 수행합니다.
이 메서드를 호출하기 전에 CDynamicOutputPin::StartUsingOutputPin 메서드를 호출해야 합니다.
요구 사항
요구 사항 | 값 |
---|---|
헤더 |
|
라이브러리 |
|