다음을 통해 공유


CSourceStream.DoBufferProcessingLoop 메서드

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

메서드는 DoBufferProcessingLoop 미디어 데이터를 생성하고 다운스트림 입력 핀에 전달합니다.

구문

virtual HRESULT DoBufferProcessingLoop();

매개 변수

이 메서드에는 매개 변수가 없습니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.

반환 코드 설명
S_FALSE
스레드가 중지 요청을 받았습니다.
S_OK
스트림이 종료되거나 다운스트림 필터가 샘플을 허용하지 않습니다.

설명

이 메서드는 데이터를 처리하고 다운스트림으로 제공하는 기본 루프를 구현합니다. 루프를 통해 매번 메서드는 할당자에서 빈 미디어 샘플을 검색합니다. 샘플을 CSourceStream::FillBuffer 메서드에 전달합니다. 파생 클래스가 구현해야 하는 FillBuffer 메서드는 미디어 데이터를 생성하고 샘플 버퍼에 배치합니다.

루프는 다음 중 어느 것이라도 발생하면 종료됩니다.

  • 입력 핀의 IMemInputPin::Receive 메서드는 샘플을 거부합니다.
  • FillBuffer 메서드는 스트림의 끝을 나타내는 S_FALSE 반환하거나 오류 코드를 반환합니다.
  • 스레드는 CSourceStream::Stop 요청을 받습니다.

메서드는 DoBufferProcessingLoop 스트림 종료 알림을 처리합니다. 오류가 발생하면 필터 그래프 관리자에 EC_ERRORABORT 이벤트를 보냅니다.

요구 사항

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

추가 정보

CSourceStream 클래스