다음을 통해 공유


IFilterGraph2::ReconnectEx 메서드(strmif.h)

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

메서드는 ReconnectEx 기존 핀 연결을 끊고 지정된 미디어 형식을 사용하여 동일한 핀에 다시 연결합니다.

애플리케이션에서 이 메서드를 호출하면 안 됩니다. 그래프 작성 프로세스 중에 필터에 의해 호출됩니다.

구문

HRESULT ReconnectEx(
  [in] IPin                *ppin,
  [in] const AM_MEDIA_TYPE *pmt
);

매개 변수

[in] ppin

연결을 끊고 다시 연결할 핀에 대한 포인터입니다.

[in] pmt

다시 연결할 미디어 형식에 대한 포인터입니다. 기존 미디어 형식을 사용하도록 NULL 을 지정합니다.

반환 값

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

반환 코드 Description
S_OK
성공.
S_FALSE
핀이 연결되지 않았습니다. 오류가 없습니다.
E_FAIL
실패.
E_POINTER
NULL 포인터 인수입니다.
VFW_E_NOT_STOPPED
필터는 중지되지 않지만 실행 중인 상태에서는 다시 연결을 지원하지 않습니다.

설명

필터는 핀 연결을 재협상하기 위해 이 메서드를 호출할 수 있습니다. 메서드는 별도의 스레드에서 실행됩니다. 이 메서드를 호출하기 전에 다른 핀에서 IPin::QueryAccept 를 호출하여 다시 연결 시도가 성공하는지 확인합니다. QueryAccept가 S_OK 반환하지 않는 한 이 메서드를 호출하지 마세요. 그렇지 않으면 다시 연결이 비동기적으로 수행되므로 메서드가 성공하더라도 ReconnectEx 다시 연결이 실패하여 필터 그래프가 일관되지 않은 상태로 남을 수 있습니다.

이 메서드는 미디어 형식을 지정하여 IFilterGraph::Reconnect 메서드를 개선합니다. 이렇게 하면 다시 연결이 성공할 가능성이 높아집니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IFilterGraph2 인터페이스

핀 다시 연결