Microsoft DirectX 9.0

ICaptureGraphBuilder2::CopyCaptureFile

The CopyCaptureFile method copies the valid media data from a capture file.

Syntax

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

Parameters

lpwstrOld

[in] Pointer to a wide-character string that contains the source file name.

lpwstrNew

[in] Pointer to a wide-character string that contains the destination file name. Valid data is copied to this file.

fAllowEscAbort

[in] Boolean value that specifies whether pressing the ESC key cancels the copy operation. If the value is TRUE and the user presses the ESC key, the operation halts. If the value is FALSE, the method ignores the ESC key.

pCallback

[in] Pointer to an IAMCopyCaptureFileProgress interface to display progress information, or NULL. See Remarks for more information.

Return Values

Returns an HRESULT value. Possible values include the following.

Return code Description
S_FALSE User canceled the operation before it completed.
S_OK Success.
E_FAIL Failure.
E_INVALIDARG Could not open the source file or destination file.
E_OUTOFMEMORY Insufficient memory.
E_POINTER NULL pointer argument.

Remarks

Typically, you will first capture to a large preallocated file. This method copies just the valid data to a new file. As a result, the new file can be much smaller than the original file.

The source and destination files must be AVI files. Other file types are not supported.

To display the progress of the copy operation, implement the IAMCopyCaptureFileProgress interface and pass a pointer to the interface in the pCallback parameter. If pCallback is non-NULL, this method periodically calls the IAMCopyCaptureFileProgress::Progress method with an integer between 0 and 100 that specifies the percentage complete.

See Also