用PictureBox代替进度条

发表于:2007-07-14来源:作者:点击数: 标签:
作者: 土人 本例演示如何用两个PictureBox在MMControl播放媒体文件时逼真地模拟进度条。 步骤一:在窗体上绘制一个PictureBox,按自己的喜爱设置其背景色并调整其宽度和长度,将其命名为picProgress; 步骤二:按如下所述绘制另一个PictureBox。右键单击picP
作者: 土人

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

原文转自:http://www.ltesting.net