다음을 통해 공유


ICaptureGraphBuilder2::AllocCapFile 메서드(strmif.h)

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

메서드는 AllocCapFile 캡처 파일을 지정된 크기로 미리 할당합니다. 최상의 결과를 얻으려면 항상 캡처 데이터의 크기보다 큰 조각 모음되고 미리 할당된 캡처 파일로 캡처합니다.

구문

HRESULT AllocCapFile(
  [in] LPCOLESTR lpstr,
  [in] DWORDLONG dwlSize
);

매개 변수

[in] lpstr

만들거나 크기를 조정할 파일의 이름을 포함하는 와이드 문자열에 대한 포인터입니다.

[in] dwlSize

할당할 파일의 크기(바이트)입니다.

반환 값

메서드가 성공하면 S_OK를 반환하고, 그러지 않으면 HRESULT 오류 코드를 반환합니다.

설명

파일이 읽기 전용이면 이 메서드가 실패합니다.

필요한 것보다 많은 공간을 할당하는 것이 가장 좋습니다. 그러나 이로 인해 비교적 적은 데이터가 포함된 매우 큰 파일이 발생할 수 있습니다. 예를 들어 1GB(기가바이트) 캡처 파일에는 캡처된 비디오의 몇 메가바이트가 포함될 수 있습니다. ICaptureGraphBuilder2::CopyCaptureFile 메서드를 사용하여 데이터를 새 파일로 복사합니다. 해당 메서드는 데이터만 복사하고 원래 파일의 빈 부분을 무시합니다.

이 메서드를 사용하여 파일을 미리 할당하는 경우 값이 0인 파일 작성기 필터에서 IFileSinkFilter2::SetMode 를 호출합니다. 필터가 AM_FILE_OVERWRITE 설정되면 미리 할당된 파일이 삭제됩니다. 일부 파일 작성기 필터는 모드 0을 지원하지 않습니다.

요구 사항

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

추가 정보

오류 및 성공 코드

ICaptureGraphBuilder2 인터페이스