导航

VB 在指定的进度条和标签中显示文件复制进度

Posted on 2008-06-15 18:23  pegger  阅读(1655)  评论(1编辑  收藏  举报
Private Const PROGRESS_CANCEL = 1
Private Const PROGRESS_CONTINUE = 0
Private Const PROGRESS_QUIET = 3
Private Const PROGRESS_STOP = 2
Private Const COPY_FILE_FAIL_IF_EXISTS = &H1
Private Const COPY_FILE_RESTARTABLE = &H2

'// 此 API 在 WIN9X 下不能使用
Private Declare Function CopyFileEx Lib "kernel32.dll" Alias "CopyFileExA" (ByVal lpExistingFileName As StringByVal lpNewFileName As StringByVal lpProgressRoutine As Long, lpData As Any, ByRef pbCancel As LongByVal dwCopyFlags As LongAs Long

Private mlngCancel             As Long
Private mprgState             As Object
Private mlblState             As Object

Public Function CopyProgressRoutine(ByVal TotalFileSize As Currency, _
                        
ByVal TotalBytesTransferred As Currency, _
                        
ByVal StreamSize As Currency, _
                        
ByVal StreamBytesTransferred As Currency, _
                        
ByVal dwStreamNumber As Long, _
                        
ByVal dwCallbackReason As Long, _
                        
ByVal hSourceFile As Long, _
                        
ByVal hDestinationFile As Long, _
                        
ByVal lpData As LongAs Long
  
'// 显示进度
  mprgState.Value = CLng((100 / TotalFileSize) * TotalBytesTransferred)
  mlblState.Caption 
= "已完成: " & FormatPercent(mprgState.Value / 1000)
  
'
  DoEvents
  
'// 继续复制
  CopyProgressRoutine = PROGRESS_CONTINUE
End Function


'************************************************
'
** 函数名称: uCopyFile
'
** 函数功能: 复制文件
'
** 参数说明:
'
**         strFrom         源文件
'
**         strTo           目标文件
'
**         prgState         进度条控件
'
**         lblState         用来显示进度的 Label
'
** 函数返回:
'
**         Boolean 类型
'
**         True           复制成功
'
**         False           复制失败
'
** 参考实例:
'
**
'
**         blnReturn = uCopyFile("c:\test.exe", "d:\test.exe", prgState, lblState)
'
************************************************
Public Function uCopyFile(ByVal strFrom As String, _
                
ByVal strTo As String, _
                
ByRef prgState As Object, _
                
ByRef lblState As ObjectAs Boolean
  
Dim lngReturn             As Long
  
  
Set mprgState = prgState
  
Set mlblState = lblState
  
'// 开始复制
  lngReturn = CopyFileEx(strFrom, strTo, _
                
AddressOf CopyProgressRoutine, ByVal 0&, mlngCancel, COPY_FILE_RESTARTABLE)

  
If lngReturn = 0 Then
    uCopyFile 
= False
  
Else
    uCopyFile 
= True
  
End If
End Function

河南恒友科贸有限公司 
电话 :0371-53733453    传真:0371-65388972
地址:郑州市郑花路8号 E-mail:hengyousoft@QQ.com