Как загрузить несколько файлов в VB6 с индикатором выполнения? - PullRequest
5 голосов
/ 11 февраля 2009

Я хочу загрузить несколько файлов (в основном изображений) из приложения VB6. В настоящее время я использую URLDownloadToFile, но он позволяет только один файл за раз, и нет индикатора выполнения. Я хочу скачать несколько файлов и с индикатором выполнения. пожалуйста помоги. заранее спасибо.

мой настоящий код:

Dim lngRetVal As Long
lngRetVal = URLDownloadToFile(0, URL, LocalFilename, 0, 0)
If lngRetVal = 0 Then DownloadFile = True

Ответы [ 2 ]

4 голосов
/ 11 февраля 2009

Вы хотите загрузить файл асинхронно, чтобы ваш код VB продолжал выполняться, пока происходит загрузка. - это малоизвестный способ сделать это с собственным VB6, использующий метод AsyncRead объектов UserControl и UserDocument - не нужно никаких вызовов API

Вот отличное объяснение и код VB6 для нескольких одновременных загрузок , от известного гуру VB6 Карла Петерсона . Событие AsyncReadProgress предоставляет вам BytesRead и BytesMax, которые позволят вам отображать индикатор выполнения.

2 голосов
/ 11 февраля 2009

Вы надеетесь на ответ VB, но это не тривиально.

Большая часть следующего поступает от http://www.experts -exchange.com / Программирование / Языки / Visual_Basic / Q_20571958.html

Интерфейс IBindStatusCallback не является напрямую доступны из VB. Это должно быть введенным в совместимый тип библиотека.

Вы можете найти библиотеку типов olelib.tlb в разделе: http://www.domaindlx.com/e_morcillo/scripts/type/default.asp Имя zip-файла для загрузки: tl_ole.zip

Вы также найдете примеры того, как использовать его в комплекте. Не уверен ли ты Вы найдете конкретный пример на IBindStatusCallback нет, но это Стоит попробовать.

Вы можете написать свою собственную функцию, чтобы получить данные в строку, которая даст вам полный контроль над всем:

Option Explicit

Public Const INTERNET_OPEN_TYPE_PRECONFIG = 0
Public Const INTERNET_DEFAULT_HTTP_PORT = 80
Public Const INTERNET_SERVICE_HTTP = 3
Public Const INTERNET_FLAG_RELOAD = &H80000000
Public Const HTTP_QUERY_STATUS_CODE = 19
Public Const HTTP_ADDREQ_FLAG_ADD = &H20000000

Public Declare Function InternetOpen Lib "wininet.dll" Alias "InternetOpenA" (ByVal sAgent As String, ByVal lAccessType As Long, ByVal sProxyName As String, ByVal sProxyBypass As String, ByVal lFlags As Long) As Long
Public Declare Function InternetConnect Lib "wininet.dll" Alias "InternetConnectA" (ByVal hInternetSession As Long, ByVal sServerName As String, ByVal nServerPort As Integer, ByVal sUsername As String, ByVal sPassword As String, ByVal lService As Long, ByVal lFlags As Long, ByVal lContext As Long) As Long
Public Declare Function HttpOpenRequest Lib "wininet.dll" Alias "HttpOpenRequestA" (ByVal hHttpSession As Long, ByVal sVerb As String, ByVal sObjectName As String, ByVal sVersion As String, ByVal sReferer As String, ByVal something As Long, ByVal lFlags As Long, ByVal lContext As Long) As Long
Public Declare Function HttpSendRequest Lib "wininet.dll" Alias "HttpSendRequestA" (ByVal hHttpRequest As Long, ByVal sHeaders As String, ByVal lHeadersLength As Long, ByVal sOptional As String, ByVal lOptionalLength As Long) As Long
Public Declare Function HttpQueryInfo Lib "wininet.dll" Alias "HttpQueryInfoA" (ByVal hHttpRequest As Long, ByVal lInfoLevel As Long, ByRef sBuffer As Any, ByRef lBufferLength As Long, ByRef lIndex As Long) As Long
Public Declare Function InternetCloseHandle Lib "wininet.dll" (ByVal hInet As Long) As Integer
Public Declare Function HttpAddRequestHeaders Lib "wininet.dll" Alias "HttpAddRequestHeadersA" (ByVal hHttpRequest As Long, ByVal sHeaders As String, ByVal lHeadersLength As Long, ByVal lModifiers As Long) As Integer
Public Declare Function InternetReadFile Lib "wininet.dll" (ByVal hFile As Long, ByVal sBuffer As String, ByVal lNumberOfBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
Public Declare Function InternetOpenUrl Lib "wininet.dll" Alias "InternetOpenUrlA" (ByVal hInternet&, ByVal lpszUrl As String, ByVal lpszHeaders As String, ByVal dwHeadersLength&, ByVal dwFlags&, ByVal dwContext&) As Long
Public Declare Function InternetQueryDataAvailable Lib "wininet.dll" (ByVal hFile As Long, lpdwNumberOfBytesAvailable As Long, ByVal dwFlags As Long, ByVal dwContext As Long) As Long

Public Function GetHTML(strURL As String) As String
Const BufferSize = 16384
Dim hSession&, hURL&, lRet&, lBytesAvail&
Dim Buffer As String * BufferSize
Dim BufferLen&, sResult$
    hSession = InternetOpen(vbNullString, INTERNET_OPEN_TYPE_PRECONFIG, vbNullString, vbNullString, 0)
    hURL = InternetOpenUrl(hSession, strURL, vbNullString, ByVal 0&, INTERNET_FLAG_RELOAD, ByVal 0&)
    sResult = ""
    Do
        InternetReadFile hURL, Buffer, Len(Buffer), BufferLen
        If BufferLen > 0 Then sResult = sResult & Left(Buffer, BufferLen)
    Loop Until BufferLen = 0
    GetHTML = sResult
    InternetCloseHandle hURL
    InternetCloseHandle hSession
End Function

Здесь вы найдете дополнительные ресурсы для выполнения метода обратного вызова (прокрутите вниз):

http://www.experts -exchange.com / Программирование / Языки / .NET / Visual_Basic.NET / Q_21763861.html

http://www.experts -exchange.com / Программирование / Языки / .NET / Visual_Basic.NET / Q_21746456.html

Но, честно говоря, я думаю, что вам лучше создать собственную функцию загрузки, если вы хотите больше контролировать ее. TCP / IP в VB очень прост.

-Adam

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...