INET下载网络进度条的问题

Dgsmile 2007-02-25 06:34:39
我用Inet下载的进度条有时候会停止响应,比如网络断的时候一直显示“请等待..”

我想设定一个超时时间,在一定时间没响应就显示:超时更新失败!

代码如下请高手指点!
Private Sub Inet1_StateChanged(ByVal State As Integer)
Dim binBuffer() As Byte
Dim sngProgerssValue As Single
Dim iBlock As Long

On Error Resume Next
iBlock = 0

Select Case State

Case icResponseCompleted
Command2.Enabled = False
'打开文件供写入
Open App.Path & "\" & FileName For Binary Access Write As #1

Do '从缓冲区读取数据
DoEvents

binBuffer = Inet1.GetChunk(512, icByteArray)
'strText = strText & strBuffer
iBlock = iBlock + 1
If m_lngDocSize > 0 Then
'获得进度百分比值
sngProgerssValue = Int((iBlock * 512 / m_lngDocSize) * 100)
'更新进度标签显示内容
lblProgressInfo.Caption = "已下载 " & CStr(iBlock * 512) & " 字节 (" & CStr(sngProgerssValue) & "%)"
'用新值更新进度条控件
ProgressBar1.Value = sngProgerssValue
'写入文件
Put #1, , binBuffer()
End If

Loop Until iBlock * 512 >= m_lngDocSize
'关闭文件
Close #1
'MsgBox "图片更新完成", vbOKOnly Or vbInformation, "在线更新"
lblProgressInfo.Caption = "更新完成!"
re = SystemParametersInfo(SPI_SETDESKWALLPAPER, 0, "beijin.bmp", 0)
Command2.Enabled = True
' End
Case icResponseReceived

If m_lngDocSize = 0 Then

'读取页面文件大小
If Len(Inet1.GetHeader("Content-Length")) > 0 Then
m_lngDocSize = CLng(Inet1.GetHeader("Content-Length"))
If (m_lngDocSize = 0) Then
' MsgBox "读取远程数据出错", vbOKOnly Or vbExclamation, "在线升级"
lblProgressInfo.Caption = ""
Call start
End If

Else 'NOT LEN(INET1.GETHEADER("CONTENT-LENGTH"))...
'MsgBox "ERROR!", vbOKOnly Or vbExclamation, "在线升级"
lblProgressInfo.Caption = ""
Call start
End If

End If

Case icError
'MsgBox "与主机通信出错", vbOKOnly Or vbExclamation, "在线升级"
lblProgressInfo.Caption = ""
Call start
Case icResolvingHost
lblProgressInfo.Caption = "正在查找主机..."

Case icHostResolved
lblProgressInfo.Caption = "已经找到主机"

Case icConnecting
lblProgressInfo.Caption = "正在联系主机"

Case icConnected
lblProgressInfo.Caption = "已经连接到主机"

Case icRequesting
lblProgressInfo.Caption = "正在发送请求..."

Case icRequestSent
lblProgressInfo.Caption = "成功发送请求"

Case icReceivingResponse
lblProgressInfo.Caption = "正在接收回应..."

Case icDisconnecting
lblProgressInfo.Caption = "正在断开连接..."

Case icDisconnected
lblProgressInfo.Caption = "已经断开连接"

End Select
' End
End Sub
Sub start()
'文件大小值复位

m_lngDocSize = 0

'复位进度条控件
ProgressBar1.Value = 0.001

'显示进度的标签内容设为空
lblProgressInfo.Caption = ""

'定义ITC控件使用的协议为HTTP协议
Inet1.Protocol = icHTTP

'调用Execute方法向Web服务器发送HTTP请求
Inet1.Execute Trim$(strURL), "GET"
lblProgressInfo.Caption = "请等待..."
're = SystemParametersInfo(SPI_SETDESKWALLPAPER, 0, "E:\serverpic\beijin.bmp", 0)
End Sub
...全文
342 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
目 录 第1部分 API函数调用 实例1 使用动态链接库扩展PowerBuilder 实例2 任务状态区图标的创建 实例3 使用API 函数的磁盘卷标 实例4 透明图像的绘制 实例5 用PowerBuilder实现拨号 实例6 无标题栏窗口的拖动 实例7 PowerBuilder加载控制面板应用程序 实例8 PowerBuilder打开Windows标准对话框 实例9 Power Builder实现位图菜单 第2部分 用户界面设计 实例10 PowerBuilder的日期录入 实例11 在 PowerBuilder窗体中使用ActiveX控件 实例12 阴历日期转换实现 实例13 渐变的Splash窗体实现 实例14 XP风格的按钮实现 实例15 拾色器的实现 实例16 XP风格的进度条 实例17 位图按钮 实例18 文件操作 实例19 MSN风格消息框 实例20 Microsoft Agent 控件使用 实例21 渐变色类的实现 实例22 抓图工具的实现 实例23 MP3播放器的实现 实例24 AVI播放器的实现 实例25 CD播放器的实现 实例26 透明窗口的实现 实例27 状态栏的使用 实例28 日期时间控件使用 实例29 使用ActiveBar创建用户界面 实例30 OutlookBar 界面实现 实例31 界面设计综合举例 第3部分 辅助程序功能设计 实例32 使用API函数实现辅助功能 实例33 CRC校验码的使用 实例34 输入法的枚举 实例35 人民币大小写金额的转换 实例36 数据的压缩和解压缩 实例37 图像扫描实现 实例38 Flash动画的应用 实例39 键盘模拟器的实现 实例40 AresButtonPro控件的使用 第4部分 网络和通信开发 实例41 局域网短消息的发送 实例42 Ping的实现 实例43 FTP客户端的实现 实例44 FAX的发送 实例45 PowerTCP 控件的使用 实例46 使用Windows API实现串行通信 实例47 PowerBuilder实现的邮件发送和接收 实例48 INet对象和WebBrowser控件的使用 实例49 使用MediaPlayer和RealPlayerG2播放流媒体 第5部分 数据窗口 实例50 数据库排序 实例51 数据库与图像的存取 实例52 数据库下拉树控件的实现 实例53 数据窗口导入到Excel表中 实例54 人民币声音拼写检查 实例55 数据窗口中回车键的处理 实例56 使用模板实现数据窗口输出到word文档 实例57 PSR浏览器的实现 实例58 使用PowerBuilder实现ODBC的自动配置 实例59 条形码在PowerBuilder中的应用 实例60 在PowerBuilder中使用数据管道 实例61 数据窗口与图表处理 实例62 实现数据窗口输出到HTML网页中 实例63 游标的使用 实例64 动态创建数据窗口 实例65 数据窗口间的数据传递

1,502

社区成员

发帖
与我相关
我的任务
社区描述
VB 网络编程
社区管理员
  • 网络编程
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧