ICaptureGraphBuilder2::CopyCaptureFile 方法 (strmif.h)

[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式碼盡可能重寫為使用新的 API。

方法 CopyCaptureFile 會從擷取檔案複製有效的媒體資料。

語法

HRESULT CopyCaptureFile(
  [in] LPOLESTR                   lpwstrOld,
  [in] LPOLESTR                   lpwstrNew,
  [in] int                        fAllowEscAbort,
  [in] IAMCopyCaptureFileProgress *pCallback
);

參數

[in] lpwstrOld

包含來原始檔案名的寬字元字串指標。

[in] lpwstrNew

包含目的地檔案名的寬字元字串指標。 有效的資料會複製到此檔案。

[in] fAllowEscAbort

布林值,指定按下 ESC 鍵是否取消複製作業。 如果值為 TRUE ,且使用者按下 ESC 鍵,作業就會停止。 如果值為 FALSE,則方法會忽略 ESC 鍵。

[in] pCallback

IAMCopyCaptureFileProgress介面的指標,以顯示進度資訊或Null。 如需詳細資訊,請參閱「備註」。

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 Description
S_FALSE
使用者已在作業完成之前取消作業。
S_OK
成功。
E_FAIL
失敗。
E_INVALIDARG
無法開啟原始程式檔或目的地檔案。
E_OUTOFMEMORY
記憶體不足。
E_POINTER
Null 指標引數。

備註

一般而言,您必須先擷取至大型預先配置檔案。 這個方法只會將有效的資料複製到新的檔案。 因此,新檔案可能比原始檔案小很多。

來源和目的地檔案必須是 AVI 檔案。 不支援其他檔案類型。

若要顯示覆製作業的進度,請實作 IAMCopyCaptureFileProgress 介面,並將指標傳遞至 pCallback 參數中的介面。 如果 pCallback 不是Null,這個方法會定期呼叫 IAMCopyCaptureFileProgress::P rogress 方法,其整數介於 0 到 100 之間,指定完成百分比。

規格需求

   
最低支援的用戶端 Windows 2000 專業版 [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

錯誤和成功碼

ICaptureGraphBuilder2 介面