다음을 통해 공유


IMediaControl::StopWhenReady 메서드(control.h)

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

메서드는 StopWhenReady 필터 그래프를 일시 중지하여 필터가 데이터를 큐에 추가하도록 허용한 다음 필터 그래프를 중지합니다.

구문

HRESULT StopWhenReady();

반환 값

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

반환 코드 Description
S_OK
성공.
S_FALSE
메서드가 반환되었을 때 그래프가 일시 중지된 상태로 전환되었습니다.

설명

이 메서드는 그래프가 중지되는 동안 필터 그래프를 찾으려는 경우에 유용합니다. 필터 그래프가 중지되는 한 현재 위치의 변경 내용은 비디오 창을 새 프레임으로 다시 칠하지 않습니다. 따라서 IMediaSeeking::SetPositions 를 호출해도 비디오 창이 업데이트되지 않습니다. 검색 작업 후 창을 업데이트하려면 를 호출합니다 StopWhenReady. 이 메서드는 그래프를 일시 중지된 상태로 전환하고 일시 중지 작업이 완료될 때까지 기다린 다음 그래프를 중지됨으로 다시 전환합니다. 일시 중지 작업은 비디오 렌더러가 새 프레임을 수신하고 표시할 수 있도록 그래프의 데이터를 큐에 대기합니다.

이 메서드는 비동기적이며, 일시 중지가 완료되기 위해 별도의 스레드에서 대기합니다. 호출 스레드는 차단되지 않으므로 애플리케이션이 사용자 입력에 응답할 수 있습니다. 메서드가 반환되면 일시 중지 작업이 완료되기 전에도 그래프의 논리적 상태가 중지됩니다. 이 시점에서 IMediaControl::GetState 메서드를 호출하면 State_Stopped 반환됩니다.

일시 중지 작업이 완료되기 전에 애플리케이션이 다른 상태 변경 명령(예: 일시 중지, 실행 또는 검색)을 실행하는 경우 새 명령은 보류 중인 중지 명령을 취소합니다. 일시 중지 작업이 완료되지만 그래프는 중지되지 않습니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IMediaControl 인터페이스