다음을 통해 공유


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

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

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

애플리케이션에서 이 메서드를 호출하면 안 됩니다. 이 메서드는 그래프에서 데이터를 플러시하기 위해 다른 필터에 의해 호출됩니다.

구문

HRESULT BeginFlush();

반환 값

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

반환 코드 Description
S_OK
성공.
E_UNEXPECTED
핀은 출력 핀입니다.

설명

입력 핀에서만 이 메서드를 호출합니다. 출력 핀은 E_UNEXPECTED 반환합니다.

플러시 작업에서 필터는 처리 중인 데이터를 모두 삭제합니다. 플러시가 완료될 때까지 새 데이터를 거부합니다. 업스트림 핀이 IPin::EndFlush 메서드를 호출하면 플러시가 완료됩니다. 플러시를 사용하면 이벤트가 일반 데이터 흐름을 변경할 때 필터 그래프의 응답성이 높아질 수 있습니다. 예를 들어 검색 중에 플러시가 발생합니다.

BeginFlush 가 호출되면 필터는 다음 단계를 수행합니다.

  1. 호출 다운스트림을 IPin::BeginFlush 전달합니다.
  2. IMemInputPin::Receive와 같은 모든 데이터 스트리밍 메서드가 실패하도록 하는 내부 플래그를 설정합니다.
  3. Receive 메서드에 대한 차단된 호출에서 를 반환합니다.
알림이 BeginFlush 렌더러 필터에 도달하면 렌더러는 해당 필터가 보유한 샘플을 해제합니다.

가 호출된 후 BeginFlush 핀은 IPin::EndFlush 메서드가 호출될 때까지 반환 값이 S_FALSE 업스트림 모든 샘플을 거부합니다.

요구 사항

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

추가 정보

필터 그래프의 Data Flow

오류 및 성공 코드

IPin 인터페이스