没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|其它|编辑:郝浩|2004-03-10 10:41:00.000|阅读 1399 次
概述:
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
用vb6的ActiveX控件实现异步下载
序:笔者(airon,softWorker)注意到,在VB6中,要实现文件下载,一般用和方法都是使用第三方控件,比如IE控件呀,winscok呀,但在本文中,不用添加任何控件,也不引用任何object,就可实现文件下载,而且程序不支持文件下载进度,捕获下载错误,激活下载完成事件等。
具体方法:
1.新建一VB6工程(默认有一个Form1窗体)
2.选择工程菜单的“添加用户控件”来添加一个用户控件。
3.更改Activex用户控件的名称,更改为
Downloader (此项可省) 。
4.输入代码:(在用户控件的代码窗口中)
Option Explicit
Event
DownloadProgress(CurBytes As Long, MaxBytes As Long, SaveFile As
String)
Event DownloadError(SaveFile As String)
Event
DownloadComplete(MaxBytes As Long, SaveFile As String)
'Public downStat As
Boolean
Public Function CancelAsyncRead() As
Boolean
On Error Resume Next
UserControl.CancelAsyncRead
End Function
'Private Sub
Timer1_Timer()
' If Not downStat
Then
' Timer1.Enabled =
False
' Exit
Sub
' End If
' Static Cs As
Integer
' If Cs > 2 Then Cs = 0
'
UserControl.Picture = P1(Cs).Picture
' Cs = Cs +
1
' DoEvents
'End Sub
Private Sub
UserControl_AsyncReadComplete(AsyncProp As AsyncProperty)
On Error Resume Next
Dim f() As Byte, fn As
Long
If AsyncProp.BytesMax <> 0
Then
fn =
FreeFile
f =
AsyncProp.Value
Open
AsyncProp.PropertyName For Binary Access Write As
#fn
Put #fn, ,
f
Close #fn
Else
RaiseEvent
DownloadError(AsyncProp.PropertyName)
End
If
RaiseEvent DownloadComplete(CLng(AsyncProp.BytesMax),
AsyncProp.PropertyName)
downStat = False
End
Sub
Private Sub UserControl_AsyncReadProgress(AsyncProp As
AsyncProperty)
On Error Resume Next
If AsyncProp.BytesMax <> 0
Then
RaiseEvent
DownloadProgress(CLng(AsyncProp.BytesRead), CLng(AsyncProp.BytesMax),
AsyncProp.PropertyName)
downStat =
True: Timer1.Enabled = True
End If
End Sub
'Private
Sub UserControl_Resize()
' SizeIt
'End Sub
Public Sub
BeginDownload(url As String, SaveFile As String)
On Error
GoTo ErrorBeginDownload
downStat =
True
UserControl.AsyncRead url, vbAsyncTypeByteArray,
SaveFile, vbAsyncReadForceUpdate
Timer1.Enabled =
True
Exit Sub
ErrorBeginDownload:
downStat = False
MsgBox Err & "开始下载数据失败!"
_
& vbCrLf & vbCrLf & "错误:" &
Err.Description, vbCritical, "错误"
End Sub
'Public Sub
SizeIt()
' On Error GoTo ErrorSizeIt
'
With UserControl
' .Width =
ScaleX(32, vbPixels, vbTwips)
'
.Height = ScaleY(32, vbPixels, vbTwips)
' End
With
' Exit Sub
'ErrorSizeIt:
'End Sub
'Public Sub
kill()
' downStat = False
' Dim m As
AsyncProperty
' MsgBox m.Value
'End
Sub
-----------------------------------------------------
程序说明:
本文采取VB6中OCX中的 异步获取方法来下载文件。
用到 AsyncRead(异步读取)
文中带注解的部分为下载界面控制,在下载时,会有像
FlashGet一样的有动画图标在动,要添加此功能,请在用户控件上添加三个image,(image上要带图片)
-----------------------------------------------------
4.关闭用户控件的代码与设置窗口,回到 Form1
5.这时你会看到在左边的工具栏下多了一用户控件,把它添加到窗体上。命名为
Downloader1
6.在窗体上添加一 command 控钮,命名为 Command1
7.在窗体 Form1的代码窗口输入代码:
Option
Explicit
'============================================
'
'
程序编写, airon,softWoker 2004-02-20
' vborg@sohu.com airon888@hotmail.com
' Http://www.eyes3.net/
'
'============================================
Private Sub
Command1_Click()
Downloader1.BeginDownload url,
SaveFile
'请把 URL 替代为 Http://文件路径
'请把
savefile 替代为下载到本地文件的路径与名称。
End Sub
Private Sub
Downloader1_DownloadComplete(MaxBytes As Long, SaveFile As
String)
MsgBox "文件下载完成,保存文件名为:" & SaveFile,
vbInformation Or vbOKOnly, "提示:"
End Sub
Private Sub Downloader1_DownloadError(SaveFile As
String)
MsgBox "下载发生错误!", vbExclamation Or vbOKOnly,
"错误:"
End Sub
Private Sub Downloader1_DownloadProgress(CurBytes
As Long, MaxBytes As Long, SaveFile As String)
'在这里添加进度第的代码
End Sub
最后申明: 本文为 airon,softWorker 原作,未经本人同意,不作出版,(CSDN
除外),但可以转载,转载时请注明作者。 如需在源程序的请mail联系我, vbprg@sohu.com 。希望本文能给广大读者带来帮助。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号