IAMStreamConfig::GetStreamCaps 메서드(strmif.h)

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

GetStreamCaps 메서드는 형식 기능 집합을 검색합니다.

구문

HRESULT GetStreamCaps(
  [in]  int           iIndex,
  [out] AM_MEDIA_TYPE **ppmt,
  [out] BYTE          *pSCC
);

매개 변수

[in] iIndex

0에서 인덱싱된 검색할 형식 기능을 지정합니다. 핀이 지원하는 기능 수를 확인하려면 IAMStreamConfig::GetNumberOfCapabilities 메서드를 호출합니다.

[out] ppmt

AM_MEDIA_TYPE 구조체에 대한 포인터의 주소입니다. 메서드는 구조를 할당하고 미디어 형식으로 채웁니다.

[out] pSCC

호출자가 할당한 바이트 배열에 대한 포인터입니다. 비디오의 경우 VIDEO_STREAM_CONFIG_CAPS 구조를 사용합니다(설명 참조). 오디오의 경우 AUDIO_STREAM_CONFIG_CAPS 구조를 사용합니다. 배열의 필요한 크기를 확인하려면 GetNumberOfCapabilities 메서드를 호출합니다. 크기는 piSize 매개 변수에 반환됩니다.

반환 값

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

반환 코드 설명
S_FALSE
지정한 인덱스가 너무 높습니다.
S_OK
성공.
E_INVALIDARG
인덱스가 잘못되었습니다.
E_OUTOFMEMORY
메모리가 부족합니다.
E_POINTER
NULL 포인터 값입니다.
VFW_E_NOT_CONNECTED
입력 핀이 연결되어 있지 않습니다.

설명

이 메서드는 다음 두 가지 정보를 반환합니다.

  • pmt 매개 변수는 지원되는 하나의 출력 형식을 설명하는 채워진 AM_MEDIA_TYPE 구조를 받습니다.
  • pSCC 매개 변수는 추가 형식 정보를 포함하는 구조를 받습니다. 비디오의 경우 pSCCVIDEO_STREAM_CONFIG_CAPS 구조를 받습니다. 오디오의 경우 AUDIO_STREAM_CONFIG_CAPS 구조를 받습니다.
참고VIDEO_STREAM_CONFIG_CAPS 구조를 사용하여 비디오 디바이스를 구성하는 것은 더 이상 사용되지 않습니다. 호출자는 버퍼를 할당해야 하지만 메서드가 반환된 후 내용을 무시해야 합니다. 캡처 디바이스는 pmt 매개 변수를 통해 지원되는 형식을 반환합니다.
 
이 형식을 사용하도록 출력 핀을 구성하려면 IAMStreamConfig::SetFormat 메서드를 호출하고 pmt 값을 전달합니다.

SetFormat을 호출하기 전에 pSCC의 정보를 사용하여 pmtAM_MEDIA_TYPE 구조를 수정할 수 있습니다. 예를 들어 오디오 핀은 pmt 매개 변수에서 기본 미디어 형식인 44kHz, 16비트 스테레오를 반환할 수 있습니다. AUDIO_STREAM_CONFIG_CAPS 구조에서 반환된 값에 따라 SetFormat을 호출하기 전에 이 형식을 8비트 모노로 변경할 수 있습니다.

메서드는 pmt 매개 변수에 반환되는 AM_MEDIA_TYPE 구조체에 대한 메모리를 할당합니다. 호출자는 형식 블록을 포함하여 메모리를 해제해야 합니다. 기본 클래스 라이브러리에서 DeleteMediaType 도우미 함수를 사용할 수 있습니다. 호출자는 pSCC 매개 변수에 대한 메모리를 할당해야 합니다.

일부 압축 필터에서는 필터의 입력 핀이 연결되지 않은 경우 이 메서드가 실패합니다.

필터 개발자: 이 메서드를 구현하는 방법에 대한 자세한 내용은 캡처 및 압축 형식 노출을 참조하세요.

예제

다음 예제에서는 비디오 출력 핀에서 지원되는 첫 번째 형식(인덱스 0)을 검색한 다음 핀에서 이 형식을 설정합니다.

C++
int iCount, iSize; BYTE *pSCC = NULL; AM_MEDIA_TYPE *pmt;

hr = pConfig-GetNumberOfCapabilities>(&iCount, &iSize);

pSCC = new BYTE[iSize]; if (pSCC == NULL) { // TODO: 메모리 부족 오류입니다. }

// Get the first format. hr = pConfig->GetStreamCaps(0, &pmt, pSCC)); if (hr == S_OK) { // TODO: Examine the format. If it's not suitable for some // reason, call GetStreamCaps with the next index value (up // to iCount). Otherwise, set the format: hr = pConfig->SetFormat(pmt); if (FAILED(hr)) { // TODO: Error handling. } DeleteMediaType(pmt); } delete [] pSCC;

요구 사항

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

추가 정보

오류 및 성공 코드

IAMStreamConfig 인터페이스