다음을 통해 공유


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

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

메서드는 Run 필터 그래프의 모든 필터를 실행합니다. 그래프가 실행되는 동안 데이터가 그래프를 통해 이동하고 렌더링됩니다.

구문

HRESULT Run();

반환 값

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

반환 코드 설명
S_FALSE
그래프가 실행을 준비하고 있지만 일부 필터가 실행 중 상태로의 전환을 완료하지 못했습니다.
S_OK
그래프의 모든 필터는 실행 중 상태로의 전환을 완료했습니다.

설명

필터 그래프가 중지되면 이 메서드는 실행하기 전에 그래프를 일시 중지합니다. 그래프가 이미 실행 중인 경우 메서드는 S_OK 반환하지만 아무런 효과가 없습니다.

그래프는 애플리케이션이 IMediaControl::P ause 또는 IMediaControl::Stop 메서드를 호출할 때까지 실행됩니다. 재생이 스트림의 끝에 도달하면 그래프가 계속 실행되지만 필터는 더 이상 데이터를 스트리밍하지 않습니다. 이 시점에서 애플리케이션은 그래프를 일시 중지하거나 중지할 수 있습니다. 스트림 종료 이벤트에 대한 자세한 내용은 IMediaControl::P auseEC_COMPLETE 참조하세요.

이 메서드는 스트림의 시작을 검색하지 않습니다. 따라서 그래프를 실행하고 일시 중지한 다음 다시 실행하면 일시 중지된 위치에서 재생이 다시 시작됩니다. 스트림의 끝에 도달한 후 그래프를 실행하면 아무 것도 렌더링되지 않습니다. 그래프를 찾으려면 IMediaSeeking 인터페이스를 사용합니다.

메서드가 S_FALSE 반환하는 경우 모든 필터가 실행 중 상태로 전환되기 전에 메서드가 반환됨을 의미합니다. 필터는 메서드가 반환된 후 전환을 완료합니다. 필요에 따라 시간 제한 값으로 IMediaControl::GetState 메서드를 호출하여 전환이 완료되기를 기다릴 수 있습니다. 그러나 반드시 이렇게 해야 하는 것은 아닙니다.

Run 메서드가 오류 코드를 반환하는 경우 하나 이상의 필터를 실행하지 못했음을 의미합니다. 그러나 일부 필터가 실행 중 상태일 수 있습니다. 다중 스트림 그래프에서 전체 스트림이 성공적으로 재생될 수 있습니다. 일반적으로 애플리케이션은 그래프를 분해하고 이 경우 오류를 보고합니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IMediaControl 인터페이스