CProgressCtrl 进度条的使用

进度条介绍  

“进度条控件”是一个窗口,应用程序可以使用这个窗口来表明一个冗长操作的进度。它由一个从左到右,用系统高亮色逐渐填充的矩形组成。

  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

 

你可能感兴趣的:(VC,MFC,软件工程,计算机,construction,attributes,windows,socket)