• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

用PictureBox代替进度条

发布: 2007-7-14 20:28 | 作者: 佚名    | 来源: 网络转载     | 查看: 11次 | 进入软件测试论坛讨论

领测软件测试网 作者: 土人

本例演示如何用两个PictureBox在MMControl播放媒体文件时逼真地模拟进度条。

步骤一:在窗体上绘制一个PictureBox,按自己的喜爱设置其背景色并调整其宽度和长度,将其命名为picProgress;
步骤二:按如下所述绘制另一个PictureBox。右键单击picProgress,选取“复制”,在picProgress区域内再次单击右键,选取“粘贴”,在弹出的询问对话框中单击“否”。将新绘制的PictureBox更名为picFill,注意将其背景色设置成与picProgress不同的颜色,接着改变Appearance属性为0-Flat;
步骤三:缺省绘制一个Timer和一个MMControl控件;
步骤四:编写代码——

Option Explicit

Private Sub Form_Load()
Me.Caption = "单击窗体开始演示"
Timer1.Enabled = False
Timer1.Interval = 100
MMControl1.Visible = False
picFill.Move 0, 0, 0 '进度条初始状态
End Sub


Private Sub Form_Click()
Timer1.Enabled = True
With MMControl1
.FileName = "E:\Music\Midi\B&B.mid"'请更改此处
.Command = "Open"
.Command = "Play"
End With
End Sub

Private Sub Timer1_Timer()
Dim Max, Value, P, L
'Max和Value:进度条的最大值、进度值
'P和L:MMControl返回的长度和播放位置
Max = picProgress.Width
L = MMControl1.Length
P = MMControl1.Position
Value = (Max * P) / L
If MMControl1.Position = MMControl1.Length Then
picFill.Move 0, 0, 0 '复位
Timer1.Enabled = False
Else
picFill.Move 0, 0, Value '按进度值填充
End If
End Sub

Private Sub Form_Unload(Cancel As Integer)
MMControl1.Command = "Close"
End Sub

用PictureBox代替进度条至少有两个好处:一、可以改变进度条的背景色和填充色;二、减少发布程序的容量。为此笔者常用上述方法来制作自己的进度条。
如果你有什么问题或建议, 欢迎与笔者联系。 

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网