zl程序教程

您现在的位置是:首页 >  其它

当前栏目

VC ListCtrl中嵌入进度条

vc 进度条 嵌入
2023-09-27 14:28:16 时间
其实要实现这个非常容易,以下是自绘ListCtrl的代码,首先继承CListCtrl,然后增加函数OnCustomDraw: void CProcessList::OnCustomDraw(NMHDR *pNMHDR, LRESULT *pResult) {  //draw each item.

 

其实要实现这个非常容易,以下是自绘ListCtrl的代码,首先继承CListCtrl,然后增加函数OnCustomDraw: void CProcessList::OnCustomDraw(NMHDR *pNMHDR, LRESULT *pResult) {  //draw each item.set txt color,bkcolor....  NMLVCUSTOMDRAW* pLVCD = reinterpret_cast NMLVCUSTOMDRAW* (pNMHDR);    // Take the default processing unless we set this to something else below.  *pResult = CDRF_DODEFAULT;    // First thing - check the draw stage. If it’s the control’s prepaint  // stage, then tell Windows we want messages for every item.    if (pLVCD- nmcd.dwDrawStage == CDDS_PREPAINT)  {   *pResult = CDRF_NOTIFYITEMDRAW;  }  else if (pLVCD- nmcd.dwDrawStage == CDDS_ITEMPREPAINT)  {   // This is the notification message for an item.  We’ll request   // notifications before each subitem’s prepaint stage.      *pResult = CDRF_NOTIFYSUBITEMDRAW;  }  else if (pLVCD- nmcd.dwDrawStage == (CDDS_ITEMPREPAINT | CDDS_SUBITEM))  {   // This is the prepaint stage for a subitem. Here’s where we set the   // item’s text and background colors. Our return value will tell   // Windows to draw the subitem itself, but it will use the new colors   // we set here.      int nItem = static_cast int (pLVCD- nmcd.dwItemSpec);   int nSubItem = pLVCD- iSubItem;      if(nSubItem != 2)//这里我只重绘第二列    return;

  COLORREF crText  = ::GetSysColor(COLOR_WINDOWFRAME);   COLORREF crBkgnd = ::GetSysColor(COLOR_WINDOW);      CDC* pDC = CDC::FromHandle(pLVCD- nmcd.hdc);   CRect rect;   GetSubItemRect(nItem, nSubItem, LVIR_BOUNDS, rect);   if (GetItemState(nItem, LVIS_SELECTED))    DrawText(nItem, nSubItem, pDC, ::GetSysColor(COLOR_HIGHLIGHT),     ::GetSysColor(COLOR_HIGHLIGHT), rect);   else    DrawText(nItem, nSubItem, pDC, crText, crBkgnd, rect);

  *pResult = CDRF_SKIPDEFAULT; // We’ve painted everything.  } }

然后为该函数增加消息映射(#add 其实是消息反射): ON_NOTIFY_REFLECT(NM_CUSTOMDRAW, OnCustomDraw) 最后我们为画进度条而努力,这里程序中把进度存在ItemData中。 void CProcessList::DrawText(int nItem,          int nSubItem,          CDC *pDC,          COLORREF crText,          COLORREF crBkgnd,          CRect rect) {  ASSERT(pDC);  pDC- FillSolidRect( rect, crBkgnd);    int nProcess = GetItemData(nItem);  CRect procRect = rect;  pDC- Rectangle(procRect);

 procRect.left += 1;  procRect.bottom -= 1;  procRect.top += 1;  procRect.right = procRect.left + rect.Width() * nProcess / 100;  CBrush brush(RGB(255,0,0));  pDC- FillRect( procRect, brush);    CString str;  str.Format("%d%%", nProcess);    if (!str.IsEmpty())  {   UINT nFormat = DT_VCENTER | DT_SINGLELINE | DT_CENTER;      pDC- SetBkMode(TRANSPARENT);   pDC- SetTextColor(crText);   pDC- SetBkColor(crBkgnd);   pDC- DrawText(str, rect, nFormat);  } }

 

 

上面用到一个结构,是存放于ItemData中用来表示进度和步长的: typedef struct _ProcessLCI_Data_ {             int  nProportion;            int  nStep; } PLCIDATA, *LPPLCIDATA;

接下来就是在容器中使用继承的ListCtrl了,这里使用对话框,在一个定时器中模拟进度的变化(其它的初始化和清除就不罗嗦了):

void CListCtrlProcessDlg::OnTimer(UINT nIDEvent) {       if(nIDEvent == TIMER_PROCESS)       {                     BOOL bPaint = FALSE;          for(int i = 0; i m_listProcess.GetItemCount(); ++i)           {                      LPPLCIDATA pIData = (LPPLCIDATA)m_listProcess.GetItemData(i);                      if(pIData- nProportion = 100)                               continue;                      bPaint = TRUE;                      if(pIData- nProportion + pIData- nStep 100)                      {                                pIData- nProportion = 100;                      }                      else                      {                                pIData- nProportion += pIData- nStep;                      }            }            if(bPaint)                      m_listProcess.Invalidate(FALSE);      }      CDialog::OnTimer(nIDEvent); }

   这里有个奇怪的问题,在VC6中不调上面的Invalidate(),只要TIMMER发生,进度条都会自动刷新。但在VC71上编译,如果不调Invalidate(),根本不刷新???不解!!!    从运行的结果看,效果还不错。VC6编译的就是满100%后进度条还是不停的闪烁;而VC71就不会了,因为没有调Invalidate()???

 

怎么样?很简单吧,其实使用VC开发界面也非常迅速的,虽然还是觉得MFC的封装有JAVA界面库封装得那么好该多好啊


Qt编写自定义控件27-颜色按钮面板 颜色按钮面板主要用在提供一个颜色按钮面板,用户单击某个按钮,然后拿到对应的颜色值,用户可以预先设定常用的颜色集合,传入到控件中,自动生成面板颜色集合按钮,每当滑过按钮的时候,按钮边缘高亮提示当前所在颜色的按钮,当选中某个按钮时,右侧颜色条显示当前选中的颜色,此控件功能极其简单,直接采用动态生成按钮的方式,设置按钮的样式表来设置对应的颜色和高亮边框等,单击按钮发出颜色改变信号即可,对外提供该信号就行,非常适合初学者学习。
Qt编写自定义控件28-颜色滑块面板 相比于上一个颜色按钮面板,此控件就要难很多,颜色值有三种表示形式,除了程序员最常用的RGB以外,还有HSB和CMY方式。RGB色彩模式是工业界的一种颜色标准,是通过对红(R)、绿(G)、蓝(B)三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB即是代表红、绿、蓝三个通道的颜色,这个标准几乎包括了人类视力所能感知的所有颜色,是目前运用最广的颜色系统之一。
Qt编写自定义控件2-进度条标尺 一、前言 进度条标尺控件的应用场景一般是需要手动拉动进度,上面有标尺可以看到当前进度,类似于qslider控件,其实就是qslider+qprogressbar的杂交版本,不过我才用的是纯qpainter绘制的方式,这样非常灵活可靠,继承自qwidget,这个控件属于标尺类控件中的一个,就是在刻度尺控件基础上增加了鼠标按下拖动进度的功能。
Qt 控件随窗口缩放 在Qt的界面设计中,我们有时候希望窗口在最大化的时候,上面的控件也跟着缩放,那么我们就需要调整控件的SizePolicy属性,关于这个属性的讲解请参见我之前的博客Qt SizePolicy 属性,由于窗口的拉伸,会导致控件的拉伸,有时候我们只需要某一个或者某几个控件被拉伸,那么我们可以将需要拉伸的控件的Horizontal Policy设为Minimum,表示可以放大不能缩小,然后将不希望拉伸的设为Fixed,设置好了之后,我们在空白处点击鼠标右键,选择Lay Out,选择其中的Lay Out in a Grid,如果有不合理的地方继续进行调整即可。
VC轻松实现CTreeCtrl控件双击响应 这个陌生的指针类型常使初用树控件的编程者陷入迷茫之中。实际上我们完全不理会它,也可以实现树控件的双击响应,即在OnDblClkTree( )函数中调用树控件的成员函数CTreeCtrl::GetSelectedItem( )以获取树控件的子项句柄HTREEITEM,得到此句柄后,我们便可用下列成员函...
通过前两节内容,我们实现了自定义窗体的移动,以及自定义标题栏-用来显示窗体的图标、标题,以及控制窗体最小化、最大化、关闭。 在这之后,我们还缺少窗体的缩放-当鼠标移动到窗体的边框-左、上、右、下、左上角、左下角、右上角、右下角时候,鼠标变为相应的样式,并且窗体可以随着鼠标拖动而进行放大、缩小。