CBaseRenderer.GetSampleTimes 메서드
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 GetSampleTimes
샘플에서 타임스탬프를 검색합니다.
구문
virtual HRESULT GetSampleTimes(
IMediaSample *pMediaSample,
REFERENCE_TIME *pStartTime,
REFERENCE_TIME *pEndTime
);
매개 변수
-
pMediaSample
-
샘플의 IMediaSample 인터페이스에 대한 포인터입니다.
-
pStartTime
-
시작 시간을 수신하는 변수에 대한 포인터입니다.
-
pEndTime
-
종료 시간을 수신하는 변수에 대한 포인터입니다.
반환 값
HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.
반환 코드 | Description |
---|---|
|
샘플을 즉시 렌더링해야 합니다. |
|
샘플은 타임스탬프를 기준으로 렌더링되도록 예약되어야 합니다. |
|
이 샘플을 렌더링하지 마세요. |
|
잘못된 타임스탬프는 종료 시간이 시작 시간보다 빠를 때입니다. |
설명
필터는 이 메서드를 호출하여 샘플을 처리하는 방법을 결정합니다. 반환 값이 S_OK 필터는 샘플을 즉시 렌더링합니다. 반환 값이 S_FALSE 필터는 타임스탬프를 기준으로 렌더링 샘플을 예약합니다. 반환 값이 오류 코드인 경우 필터는 샘플을 거부합니다.
이 메서드는 샘플에 타임스탬프를 포함하지 않거나 필터에 참조 클록이 없는 경우 S_OK 반환합니다. 그렇지 않으면 CBaseRenderer::ShouldDrawSampleNow 메서드의 값을 반환합니다. 기본 클래스에서 ShouldDrawSampleNow는 항상 S_FALSE 반환합니다. 파생 클래스는 이 동작을 재정의할 수 있습니다. 예를 들어 파생 클래스가 품질 제어 관리를 구현하는 경우 E_FAIL 반환하여 샘플을 삭제할 수 있습니다.
요구 사항
요구 사항 | 값 |
---|---|
헤더 |
|
라이브러리 |
|