다음을 통해 공유


CBasePin.ReceiveConnection 메서드

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

메서드는 ReceiveConnection 다른 핀에서 연결을 허용합니다. 이 메서드는 IPin::ReceiveConnection 메서드를 구현합니다.

구문

HRESULT ReceiveConnection(
   IPin          *pConnector,
   AM_MEDIA_TYPE *pmt
);

매개 변수

pConnector

연결 핀의 IPin 인터페이스에 대한 포인터입니다.

Pmt

미디어 형식을 지정하는 AM_MEDIA_TYPE 구조체에 대한 포인터입니다.

반환 값

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

반환 코드 Description
S_OK
성공.
E_POINTER
NULL 포인터 인수입니다.
VFW_E_ALREADY_CONNECTED
핀이 이미 연결되어 있습니다.
VFW_E_NOT_STOPPED
필터가 활성화되어 있고 핀이 동적 다시 연결을 지원하지 않습니다.
VFW_E_TYPE_NOT_ACCEPTED
지정된 미디어 형식은 허용되지 않습니다.

설명

출력 핀은 입력 핀에서 이 메서드를 호출합니다. 입력 핀이 오류 코드를 반환하면 연결이 실패합니다.

기본 클래스에서 이 메서드는 다음 단계를 수행합니다.

  • 핀이 이미 연결되어 있는지 확인합니다.
  • 필터가 중지되었는지 여부를 확인합니다.
  • CBasePin::CheckConnect 메서드를 호출하여 연결 핀이 적합한지 테스트합니다.
  • CBasePin::CheckMediaType 메서드를 호출하여 미디어 형식이 허용되는지 여부를 테스트합니다.

이러한 모든 단계가 성공하면 메서드는 CBasePin::CompleteConnectSetMediaType 메서드를 호출하여 연결을 완료합니다. 이러한 메서드는 미디어 형식과 출력 핀에 대한 포인터를 저장합니다.

CheckConnect 또는 CheckMediaType이 실패하면 기본 클래스는 CBasePin::BreakConnect 메서드를 호출하여 연결을 끊은 다음 에서 ReceiveConnection오류 코드를 반환합니다.

요구 사항

요구 사항
헤더
Amfilter.h(Streams.h 포함)
라이브러리
Strmbase.lib(소매 빌드);
Strmbasd.lib(디버그 빌드)

추가 정보

CBasePin 클래스