다음을 통해 공유


IAMBufferNegotiation::SuggestAllocatorProperties 메서드(strmif.h)

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

메서드는 SuggestAllocatorProperties 애플리케이션의 기본 할당자 속성을 핀에 알릴 수 있습니다. 핀이 연결되기 전에 이 메서드를 호출합니다.

구문

HRESULT SuggestAllocatorProperties(
  [in] const ALLOCATOR_PROPERTIES *pprop
);

매개 변수

[in] pprop

요청된 속성을 포함하는 ALLOCATOR_PROPERTIES 구조체에 대한 포인터입니다. 멤버의 음수 값은 핀이 해당 속성에 대한 기본 설정을 사용해야 했음을 나타냅니다.

반환 값

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

반환 코드 Description
S_OK
성공.
E_FAIL
실패.
E_POINTER
NULL 포인터 인수입니다.
VFW_E_ALREADY_CONNECTED
핀이 이미 연결되어 있습니다.

설명

연결의 두 핀이 IAMBufferNegotiation 인터페이스를 노출하는 경우 각 핀에서 이 메서드를 호출하여 한 핀이 다른 핀을 재정의하지 않도록 합니다.

특정 수의 버퍼를 요청하려면 ALLOCATOR_PROPERTIES 구조체의 커퍼 멤버를 설정합니다. 특정 버퍼 크기를 요청하려면 cbBuffer 멤버를 설정합니다. 애플리케이션은 일반적으로 맞춤 또는 접두사를 지정하면 안 됩니다. 각 버퍼의 버퍼 수 또는 크기가 너무 작으면 필터 그래프가 샘플을 삭제할 수 있습니다.

예제

C++
ALLOCATOR_PROPERTIES AllocProp;
AllocProp.cbAlign = -1;  // -1 means no preference.
AllocProp.cbBuffer = dwBytesPerSec *  dwLatencyInMilliseconds / 1000;
AllocProp.cbPrefix = -1;
AllocProp.cBuffers = -1;
pIAMBufferNegotiation->SuggestAllocatorProperties(&AllocProp);

요구 사항

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

추가 정보

오류 및 성공 코드

IAMBufferNegotiation 인터페이스