다음을 통해 공유


CRenderedInputPin.EndOfStream 메서드

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

메서드는 EndOfStream 필터에 새 실행 명령이 실행될 때까지 추가 데이터가 필요하지 않음을 핀에 알릴 수 있습니다. 이 메서드는 IPin::EndOfStream 메서드를 구현합니다.

구문

HRESULT EndOfStream();

매개 변수

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

반환 값

성공하면 S_OK 반환하고, 그렇지 않으면 오류 코드를 반환합니다.

설명

필터가 실행 중인 경우 이 메서드는 필터 그래프 관리자에 EC_COMPLETE 이벤트를 보냅니다. 그렇지 않으면 는 필터가 다음에 실행되면 EC_COMPLETE 이벤트가 전송되도록 플래그를 설정합니다. 필터를 플러시하면 플래그가 지워지게 됩니다.

핀의 스트리밍 잠금을 유지하려면 이 메서드를 재정의해야 합니다.

class CMyInputPin : public CRenderedInputPin
{
private:
    CCritSec * const m_pReceiveLock; // Streaming lock.
public:
    STDMETHODIMP EndOfStream(void);

    /* (Remainder of the class declaration not shown.) */
};

STDMETHODIMP CMyInputPin::EndOfStream(void)
{
    CAutoLock lock(m_pReceiveLock);  
    return CRenderedInputPin::EndOfStream();
} 

또한 필터가 Receive 호출을 비동기적으로 처리하는 경우 핀은 필터가 보류 중인 모든 샘플을 처리할 때까지 EC_COMPLETE 이벤트를 보낼 때까지 기다려야 합니다.

요구 사항

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

추가 정보

CRenderedInputPin 클래스