IQueueCommand::InvokeAtStreamTime 메서드(control.h)
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드가 DirectShow 대신 Media Foundation에서 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 InvokeAtStreamTime
지정된 스트림 시간(즉, 현재 스트림 시간 오프셋을 기준으로 하는 프레젠테이션 시간)에 실행하기 위해 메서드 또는 속성 변경을 큐에 대기합니다.
구문
HRESULT InvokeAtStreamTime(
[out] IDeferredCommand **pCmd,
[in] REFTIME time,
[in] GUID *iid,
[in] long dispidMethod,
[in] short wFlags,
[in] long cArgs,
[in] VARIANT *pDispParams,
[in, out] VARIANT *pvarResult,
[out] short *puArgErr
);
매개 변수
[out] pCmd
IDeferredCommand 인터페이스 포인터를 수신하는 변수의 주소입니다.
[in] time
명령을 호출할 시간입니다.
[in] iid
인터페이스의 IID(인터페이스 식별자)에 대한 포인터입니다.
[in] dispidMethod
인터페이스에서 메서드 또는 속성의 DISPID(디스패치 식별자)입니다. IDispatch::Invoke 메서드의 dispIdMember 매개 변수와 동일합니다.
[in] wFlags
호출의 컨텍스트를 설명하는 플래그입니다. IDispatch::Invoke 메서드의 wFlags 매개 변수와 동일합니다.
[in] cArgs
pDispParams의 인수 수입니다. DISPPARAMS 구조체의 cArgs 멤버에 해당합니다.
[in] pDispParams
인수를 포함하는 배열에 대한 포인터입니다. DISPPARAMS 구조체의 rgvarg 멤버에 해당합니다.
[in, out] pvarResult
결과를 수신하는 VARIANT에 대한 포인터입니다. IDispatch::Invoke 메서드의 pVarResult 매개 변수와 동일합니다.
[out] puArgErr
오류가 있는 첫 번째 인수의 인덱스를 받는 변수에 대한 포인터입니다. IDispatch::Invoke 메서드의 puArgErr 매개 변수와 동일합니다.
반환 값
HRESULT 값을 반환합니다.
설명
IDispatch::GetIDsOfNames 메서드를 사용하여 dispidMember 매개 변수에 대한 DISPID를 검색합니다.
예제
다음 예제에서는 IMediaControl::Stop 명령을 3.0초 동안 큐에 대기합니다.
IQueueCommand *pQ = 0;
IMediaControl *pControl = 0;
// Query for IQueueCommand.
pGraph->QueryInterface(IID_IQueueCommand, reinterpret_cast<void**>(&pQ));
// Query for IMediaControl.
pGraph->QueryInterface(IID_IMediaControl, reinterpret_cast<void**>(&pControl));
// Find the DISPID of the IMediaControl::Stop method.
OLECHAR *szMethod = OLESTR("Stop");
long dispid;
hr = pControl->GetIDsOfNames(IID_NULL, &szMethod, 1, 0, &dispid);
// Invoke the command.
IDeferredCommand *pCmd = 0;
hr = pQ->InvokeAtPresentationTime(&pCmd, 3.0,
const_cast<GUID*>(&IID_IMediaControl), dispid, DISPATCH_METHOD,
0, 0, 0, 0);
if (SUCCEEDED(hr))
{
pControl->Run();
pCmd->Release();
}
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | control.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |