다음을 통해 공유


IAsyncReader::SyncReadAligned 메서드(strmif.h)

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

메서드는 SyncReadAligned 동기 읽기를 수행합니다. 메서드는 요청이 완료될 때까지 차단합니다. 파일 위치와 버퍼 주소를 정렬해야 합니다. 필요한 맞춤에 대한 할당자 속성을 검사.

구문

HRESULT SyncReadAligned(
  IMediaSample *pSample
);

매개 변수

pSample

호출자가 제공하는 미디어 샘플의 IMediaSample 인터페이스에 대한 포인터입니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.

반환 코드 설명
VFW_E_BADALIGN
맞춤이 잘못되었습니다.
S_FALSE
요청된 것보다 적은 바이트를 검색했습니다. (파일의 끝에 도달했을 수 있습니다.)
S_OK
성공.

설명

이 메서드를 호출하기 전에 핀의 할당자에서 미디어 샘플을 검색합니다. 요청하는 바이트 오프셋이 있는 샘플 타임스탬프(첫 번째 및 마지막 포함)에 10,000,000을 곱합니다. 바이트 오프셋은 스트림의 시작을 기준으로 합니다.

시작 및 중지 위치는 핀이 연결되었을 때 결정된 맞춤과 일치해야 합니다. 그렇지 않으면 메서드는 VFW_E_BADALIGN 반환합니다. 합의된 맞춤이 스트림의 실제 맞춤보다 거친 경우 중지 위치가 실제 기간을 초과할 수 있습니다. 이 경우 메서드는 중지 위치를 실제 맞춤으로 반올림합니다.

이 메서드는 버퍼되지 않은 읽기를 수행하므로 IAsyncReader::SyncRead 메서드보다 더 빠를 수 있습니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

IAsyncReader 인터페이스