다음을 통해 공유


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

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

메서드는 BeginFlush 플러시 작업을 시작합니다.

구문

HRESULT BeginFlush();

반환 값

성공하면 S_OK 반환하거나, 그렇지 않으면 S_FALSE.

설명

이 메서드는 보류 중인 모든 읽기 요청을 중단합니다. 핀이 플러시되는 동안 IAsyncReader::Request 메서드가 실패하고 IAsyncReader::WaitForNext 메서드는 반환 코드가 VFW_E_TIMEOUT 즉시 반환됩니다.

다운스트림 입력 핀은 다운스트림 필터가 필터 그래프를 플러시할 때마다 이 메서드를 호출해야 합니다. 이 메서드를 호출한 후 ppSample 매개 변수에서 NULL을 반환할 때까지 WaitForNext 메서드를 호출하여 보류 중인 샘플의 큐를 지웁니다. 오류 코드를 무시하고 각 샘플을 해제합니다. 그런 다음 , IAsyncReader::EndFlush 메서드를 호출하여 플러시 작업을 종료합니다.

자세한 내용은 플러시를 참조하세요.

예제

다음 예제에서는 다운스트림 입력 핀이 이 메서드를 호출하는 방법을 보여줍니다.

C++
m_pReader->BeginFlush(); 
while (1) {
    IMediaSample *pSample;
    DWORD_PTR dwUnused;
    m_pReader->WaitForNext(0, &pSample, &dwUnused);
    if(pSample) { 
        pSample->Release();  
    } 
    else {  // No more samples.
        break;
    }
}
m_pReader->EndFlush();

요구 사항

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

추가 정보

오류 및 성공 코드

IAsyncReader 인터페이스