다음을 통해 공유


CBaseRenderer.GetSampleTimes 메서드

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia 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
샘플은 타임스탬프를 기준으로 렌더링되도록 예약되어야 합니다.
E_FAIL
이 샘플을 렌더링하지 마세요.
VFW_E_START_TIME_AFTER_END
잘못된 타임스탬프는 종료 시간이 시작 시간보다 빠를 때입니다.

설명

필터는 이 메서드를 호출하여 샘플을 처리하는 방법을 결정합니다. 반환 값이 S_OK 필터는 샘플을 즉시 렌더링합니다. 반환 값이 S_FALSE 필터는 타임스탬프를 기준으로 렌더링 샘플을 예약합니다. 반환 값이 오류 코드인 경우 필터는 샘플을 거부합니다.

이 메서드는 샘플에 타임스탬프를 포함하지 않거나 필터에 참조 클록이 없는 경우 S_OK 반환합니다. 그렇지 않으면 CBaseRenderer::ShouldDrawSampleNow 메서드의 값을 반환합니다. 기본 클래스에서 ShouldDrawSampleNow는 항상 S_FALSE 반환합니다. 파생 클래스는 이 동작을 재정의할 수 있습니다. 예를 들어 파생 클래스가 품질 제어 관리를 구현하는 경우 E_FAIL 반환하여 샘플을 삭제할 수 있습니다.

요구 사항

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

추가 정보

CBaseRenderer 클래스