다음을 통해 공유


CTransInPlaceInputPin.NotifyAllocator 메서드

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

메서드는 NotifyAllocator 연결에 대한 할당자를 지정합니다. 이 메서드는 IMemInputPin::NotifyAllocator 메서드를 구현합니다.

구문

HRESULT NotifyAllocator(
   IMemAllocator *pAllocator,
   BOOL          bReadOnly
);

매개 변수

pAllocator

할당자의 IMemAllocator 인터페이스에 대한 포인터입니다.

bReadOnly

이 할당자의 샘플이 읽기 전용인지 여부를 지정하는 플래그입니다. TRUE이면 샘플이 읽기 전용입니다.

반환 값

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

반환 코드 Description
S_OK
Success
E_FAIL
실패
E_POINTER
NULL 포인터 인수

설명

필터는 두 핀 연결에 대해 동일한 할당자를 사용하려고 시도합니다.

  • 출력 핀이 연결되지 않은 경우 입력 핀은 할당자를 자동으로 수락합니다. 출력 핀이 연결되면 필터가 입력 핀을 다시 연결합니다. 이 시점에서 필터는 단일 할당자를 사용하려고 다시 시도합니다.
  • 출력 핀이 연결된 경우 입력 핀은 할당자를 허용합니다. 출력 핀도 동일한 할당자를 사용합니다. 다운스트림 입력 핀에서 를 호출 NotifyAllocator 합니다.

이전 사례에는 다음과 같은 예외가 있습니다.

  • 제안된 할당자가 읽기 전용이고(즉, bReadOnly 매개 변수가 TRUE임) 필터가 샘플을 수정해야 하는 경우 필터는 두 개의 서로 다른 할당자를 사용해야 합니다. 이 경우 업스트림 필터가 다운스트림 필터의 할당자를 사용하도록 제안하는 경우 메서드는 E_FAIL 반환합니다.

요구 사항

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

추가 정보

CTransInPlaceInputPin 클래스