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 |
---|---|
|
성공. |
|
NULL 포인터 인수입니다. |
|
핀이 이미 연결되어 있습니다. |
|
필터가 활성화되어 있고 핀이 동적 다시 연결을 지원하지 않습니다. |
|
지정된 미디어 형식은 허용되지 않습니다. |
설명
출력 핀은 입력 핀에서 이 메서드를 호출합니다. 입력 핀이 오류 코드를 반환하면 연결이 실패합니다.
기본 클래스에서 이 메서드는 다음 단계를 수행합니다.
- 핀이 이미 연결되어 있는지 확인합니다.
- 필터가 중지되었는지 여부를 확인합니다.
- CBasePin::CheckConnect 메서드를 호출하여 연결 핀이 적합한지 테스트합니다.
- CBasePin::CheckMediaType 메서드를 호출하여 미디어 형식이 허용되는지 여부를 테스트합니다.
이러한 모든 단계가 성공하면 메서드는 CBasePin::CompleteConnect 및 SetMediaType 메서드를 호출하여 연결을 완료합니다. 이러한 메서드는 미디어 형식과 출력 핀에 대한 포인터를 저장합니다.
CheckConnect 또는 CheckMediaType이 실패하면 기본 클래스는 CBasePin::BreakConnect 메서드를 호출하여 연결을 끊은 다음 에서 ReceiveConnection
오류 코드를 반환합니다.
요구 사항
요구 사항 | 값 |
---|---|
헤더 |
|
라이브러리 |
|