다음을 통해 공유


IVideoFrameStep::Step 메서드(strmif.h)

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

메서드를 Step 사용하면 필터 그래프가 지정된 프레임 수만큼 앞으로 이동합니다.

구문

HRESULT Step(
  DWORD    dwFrames,
  IUnknown *pStepObject
);

매개 변수

dwFrames

건너뛸 프레임 수를 지정합니다. dwFrames가 1이면 그래프가 한 프레임 앞으로 이동합니다. dwFrames가 1보다 큰 숫자 n인 경우 그래프는 n -1 프레임을 건너뛰고 n번째 프레임을 표시합니다.

pStepObject

단계별 작업 또는 NULL을 제어할 필터의 인터페이스에 대한 포인터입니다. 그래프에서 렌더러 필터를 사용하여 프레임 스테핑을 수행하려면 NULL 을 지정합니다. NULL이 아닌 경우 개체는 IKsPropertySet 인터페이스를 구현하고 AM_KSPROPSETID_FrameStep 속성을 지원해야 합니다. (자세한 내용은 Frame Stepping 속성 집합을 참조하세요.) 그래프에 프레임 스테핑을 구현하는 사용자 지정 필터가 포함된 경우 pStepObject 는 해당 필터에 대한 포인터를 지정할 수 있습니다.

반환 값

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

반환 코드 Description
S_OK
성공.
VFW_E_FRAME_STEP_UNSUPPORTED
프레임 스테핑은 지원되지 않습니다.
E_INVALIDARG
pStepObject 매개 변수가 잘못되었습니다.

설명

단계 작업이 완료되면 이 메서드는 필터 그래프 관리자에 EC_STEP_COMPLETE 이벤트 알림을 보내 애플리케이션의 이벤트 루프에 전달하고 필터 그래프를 일시 중지된 상태로 설정합니다.

프레임은 실시간으로 진행됩니다. 즉, 동영상이 초당 30프레임으로 재생되는 경우 dwFrames가 60으로 설정된 IVideoFrameStep::Step을 호출하면 실행하는 데 2초가 걸립니다. 이 인터페이스의 모든 메서드는 비동기이므로 컨트롤이 애플리케이션에 즉시 반환됩니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IVideoFrameStep 인터페이스