IGraphBuilder::RenderFile 메서드(strmif.h)
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 RenderFile
지정된 파일을 렌더링하는 필터 그래프를 작성합니다.
구문
HRESULT RenderFile(
[in] LPCWSTR lpcwstrFile,
[in] LPCWSTR lpcwstrPlayList
);
매개 변수
[in] lpcwstrFile
미디어 파일의 이름을 포함하는 와이드 문자열을 지정합니다.
[in] lpcwstrPlayList
예약되어 있습니다. NULL이어야 합니다.
반환 값
HRESULT를 반환합니다. 가능한 값은 다음과 같습니다.
반환 코드 | Description |
---|---|
|
성공. |
|
부분 성공; 오디오가 렌더링되지 않았습니다. |
|
성공; 필터 그래프 관리자가 중복을 방지하기 위해 필터 이름을 수정했습니다. |
|
이 영화의 일부 스트림은 지원되지 않는 형식입니다. |
|
부분 성공; 이 영화의 일부 스트림은 지원되지 않는 형식입니다. |
|
작업이 중단되었습니다. |
|
실패. |
|
인수가 잘못되었습니다. |
|
메모리가 부족합니다. |
|
NULL 포인터 인수입니다. |
|
연결을 위해 중간 필터 조합을 찾을 수 없습니다. |
|
이 파일의 원본 필터를 로드할 수 없습니다. |
|
스트림을 렌더링하는 필터 조합을 찾을 수 없습니다. |
|
파일 형식이 잘못되었습니다. |
|
개체 또는 이름을 찾을 수 없습니다. |
|
이 파일의 미디어 형식이 인식되지 않습니다. |
|
파일을 재생할 수 없습니다. 형식은 지원되지 않습니다. |
설명
lpwstrFile 매개 변수가 미디어 파일을 지정하는 경우 메서드는 기본 재생을 위한 필터 그래프를 작성합니다. 먼저 IGraphBuilder::AddSourceFilter 메서드와 동일한 프로세스를 사용하여 파일을 읽을 수 있는 원본 필터를 추가합니다. 그런 다음 필요한 경우 중간 필터를 추가하여 원본 필터에 출력 핀을 렌더링합니다. IGraphBuilder::Connect 메서드와 동일한 순서로 필터를 시도합니다.
연결 프로세스 중에 필터 그래프 관리자는 핀 이름이 타일(~)로 시작하는 경우 중간 필터의 핀을 무시합니다. 자세한 내용은 PIN_INFO 참조하세요.
메서드는 RenderFile
그래프에서 필터를 제거하지 않습니다. 두 번 호출 RenderFile
하는 경우 두 번째 호출은 단순히 그래프에 더 많은 필터를 추가합니다. 그래프를 실행하면 두 원본이 동시에 재생됩니다.
예제
다음 예제에서는 기본 재생을 위해 AVI 파일을 렌더링합니다.
C++ |
---|
hr = pGraph->RenderFile(L"C:\\Media\\Example.avi", 0); |
C++ |
---|
hr = pGraph->RenderFile(L"http://example.microsoft.com/Example.avi", 0); |
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | strmif.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |