进度条介绍
“进度条控件”是一个窗口,应用程序可以使用这个窗口来表明一个冗长操作的进度。它由一个从左到右,用系统高亮色逐渐填充的矩形组成。
CProgressCtrl类提供了Windows通用进度条控件的机能。这个控件(也就是CProgressCtrl类)只有对运行在Windows 95和Windows NT 3.51或更高版本下的程序才是有效的。
进度条控件具有一个范围和一个当前位置。范围代表了操作的整个期间,当前位置代表了应用程序为完成操作已经做完的部分。窗口进程用范围和当前位置来确定用高亮色填充进度条的百分比,以及确定在进度条中所显示的文本(如果有的话)。由于范围和当前位置值是用有符号整数表示的,所以可能的当前位置值的范围是从-214783648到214783647 (-2^16 ~ + 2^16)。
类成员
CProgressCtrl类成员
Construction CProgressCtrl 构造一个CProgressCtrl对象
Create 创建一个进度条控件并将它与一个CProgressCtrl对象连接
Attributes SetRange 为进度条控件设置范围的最小值和最大值,并重画进度条来反映新的范围
SetRange32 为进度条控件设置范围的最小值和最大值,并重画进度条来反映新的范围
GetRange 获取进度条控件范围的下限和上限
GetPos 获取进度条的当前位置
SetPos 设置进度条的当前位置并重画进度条来反映新的位置
OffsetPos 用一个指定的增量来增加进度条控件的当前位置,并重画此进度条来反映新的位置
SetStep 为一个进度条控件指定每一步的增量
Operations StepIt 用每一步的增量(参见SetStep)来增加一个进度条控件的当前位置,并重画此进度条来反映新的位置
///////////////////////////////////////// 简单进度条的实例
CFile file;
if(!file.Open(m_strPath, CFile::modeRead | CFile::typeBinary))
{
AfxMessageBox(_T("文件打开失败"));
senSo.Close();
return ;
}
m_ctrlProgress.SetRange32(0, m_dwFileSize);
int nSize = 0, nLen = 0;
DWORD dwCount = 0;
char buf[BLOCKSIZE] = {0};
file.Seek(0, CFile::begin);
//开始传送文件
for(;;)
{
//一次读取BLOCKSIZE大小的文件内容
nLen = file.Read(buf, BLOCKSIZE);
if(nLen == 0)
break;
//发送文件内容
nSize = senSo.Send(buf, nLen);
dwCount += nSize;
m_ctrlProgress.SetPos(dwCount);
CString strTransfersSize;
strTransfersSize.Format("%ld 字节", dwCount);
if(m_bIsStop)
{
m_bIsStop = FALSE;
break;
}
if(nSize == SOCKET_ERROR)
break;
}
//关闭文件
file.Close();
//关闭套接字
senSo.Close();
if(m_dwFileSize == dwCount)
AfxMessageBox(_T("文件发送成功"));
else
AfxMessageBox(_T("文件发送失败"));
m_ctrlProgress.SetPos(0); //置0