다음을 통해 공유


IMediaEvent::GetEvent 메서드(control.h)

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

메서드는 GetEvent 이벤트 큐에서 다음 이벤트 알림을 검색합니다.

구문

HRESULT GetEvent(
  [out] long     *lEventCode,
  [out] LONG_PTR *lParam1,
  [out] LONG_PTR *lParam2,
  [in]  long     msTimeout
);

매개 변수

[out] lEventCode

이벤트 코드를 수신하는 변수에 대한 포인터입니다.

[out] lParam1

첫 번째 이벤트 매개 변수를 수신하는 변수에 대한 포인터입니다.

[out] lParam2

두 번째 이벤트 매개 변수를 수신하는 변수에 대한 포인터입니다.

[in] msTimeout

시간 제한 간격(밀리초)입니다. INFINITE를 사용하여 이벤트가 있을 때까지 차단합니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.

반환 코드 설명
S_OK
성공.
E_ABORT
제한 시간이 만료되었습니다.

설명

큐에 이벤트가 없으면 이 메서드는 이벤트가 도착할 때까지 msTimeout 밀리초까지 기다립니다. 스레드가 에서 GetEvent대기하는 동안 메시지를 처리할 수 없으므로 INFINITE의 제한 시간 간격을 사용하지 마세요. Windows 메시지를 처리하는 동일한 스레드에서 를 호출 GetEvent 하는 경우 사용자 입력에 계속 응답하기 위해 작은 대기 시간만 지정합니다.

를 호출 GetEvent한 후 IMediaEvent::FreeEventParams 메서드를 호출하여 이벤트 매개 변수에 할당된 모든 리소스를 해제합니다.

알림 코드 및 이벤트 매개 변수 값 목록은 이벤트 알림 코드를 참조하세요.

이 메서드는 필터 그래프 이벤트 큐에서 이벤트를 제거하므로 여러 클라이언트가 동일한 그래프에서 이벤트를 모니터링할 수 있는 방법은 없습니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IMediaEvent 인터페이스

IMediaEventEx