自绘CProgressCtrl进度条控件,支持自定义显示文本和进程百分比信息

[cpp] view plain copy

  1. // CXProgressCtrl 头文件
  2. #pragma once
  3. // CXProgressCtrl
  4. class CXProgressCtrl : public CProgressCtrl
  5. {
  6. DECLARE_DYNAMIC(CXProgressCtrl)
  7. public:
  8. CXProgressCtrl();
  9. virtual ~CXProgressCtrl();
  10. typedef enum _ALIGN_TEXT_
  11. {
  12. ALIGN_LEFT = 0x00,
  13. ALIGN_CENTER,
  14. ALIGN_RIGHT
  15. }ALIGN_TEXT;
  16. public:
  17. inline void SetBarColor(COLORREF clr)
  18. {
  19. m_clrBarColor = clr;
  20. }
  21. inline COLORREF GetBarColor()
  22. {
  23. return m_clrBarColor;
  24. }
  25. inline void SetBarBkColor(COLORREF clr)
  26. {
  27. m_clrBarBkColor = clr;
  28. }
  29. inline COLORREF GetBarBkColor()
  30. {
  31. return m_clrBarBkColor;
  32. }
  33. inline void SetTextColor(COLORREF clr)
  34. {
  35. m_clrTextColor = clr;
  36. }
  37. inline COLORREF GetTextColor()
  38. {
  39. return m_clrTextColor;
  40. }
  41. inline void SetTextBkColor(COLORREF clr)
  42. {
  43. m_clrTextBkColor = clr;
  44. }
  45. inline COLORREF GetTextBkColor()
  46. {
  47. return m_clrTextBkColor;
  48. }
  49. inline void SetTextAlign(ALIGN_TEXT AlignText)
  50. {
  51. m_AlignText = AlignText;
  52. }
  53. inline ALIGN_TEXT GetTextAlign()
  54. {
  55. return m_AlignText;
  56. }
  57. inline void ShowPercent(BOOL bShowPercent = TRUE)
  58. {
  59. m_bShowPercent = bShowPercent;
  60. }
  61. inline BOOL IsShowPercent()
  62. {
  63. return m_bShowPercent;
  64. }
  65. protected:
  66. COLORREF m_clrBarColor;
  67. COLORREF m_clrBarBkColor;
  68. COLORREF m_clrTextColor;
  69. COLORREF m_clrTextBkColor;
  70. ALIGN_TEXT m_AlignText;
  71. BOOL m_bShowPercent;
  72. CFont m_font; // Only for vertical style
  73. protected:
  74. afx_msg BOOL OnEraseBkgnd(CDC* pDC);
  75. afx_msg void OnPaint();
  76. DECLARE_MESSAGE_MAP()
  77. };

[cpp] view plain copy

  1. // CXProgressCtrl .CPP文件
  2. // XProgressCtrl.cpp : implementation file
  3. //
  4. #include "stdafx.h"
  5. #include "Demo.h"
  6. #include "XProgressCtrl.h"
  7. // CXProgressCtrl
  8. IMPLEMENT_DYNAMIC(CXProgressCtrl, CProgressCtrl)
  9. CXProgressCtrl::CXProgressCtrl() : m_clrTextColor(RGB(0, 0, 0)),
  10. m_clrTextBkColor(RGB(255, 255, 255)),
  11. m_clrBarColor(RGB(128, 128, 255)),
  12. m_clrBarBkColor(RGB(235, 235, 235)),
  13. m_AlignText(ALIGN_CENTER),
  14. m_bShowPercent(TRUE)
  15. {
  16. }
  17. CXProgressCtrl::~CXProgressCtrl()
  18. {
  19. if(m_font.GetSafeHandle())
  20. {
  21. m_font.DeleteObject();
  22. }
  23. }
  24. BEGIN_MESSAGE_MAP(CXProgressCtrl, CProgressCtrl)
  25. ON_WM_ERASEBKGND()
  26. ON_WM_PAINT()
  27. END_MESSAGE_MAP()
  28. // CXProgressCtrl message handlers
  29. BOOL CXProgressCtrl::OnEraseBkgnd(CDC *pDC)
  30. {
  31. return TRUE;
  32. }
  33. void CXProgressCtrl::OnPaint()
  34. {
  35. CPaintDC paintDC(this);
  36. int nMin = 0;
  37. int nMax = 0;
  38. GetRange(nMin, nMax);
  39. ASSERT(nMin <= nMax);
  40. int nPos = GetPos();
  41. ASSERT(nPos >= nMin && nPos <= nMax);
  42. DWORD dwStyle = GetStyle();
  43. BOOL bVertical = FALSE;
  44. if(dwStyle & PBS_VERTICAL)
  45. {
  46. bVertical = TRUE;
  47. }
  48. CDC dc;
  49. dc.CreateCompatibleDC(&paintDC);
  50. ASSERT(dc.GetSafeHdc());
  51. CRect rect;
  52. GetClientRect(&rect);
  53. CBitmap bmp;
  54. bmp.CreateCompatibleBitmap(&paintDC, rect.Width(), rect.Height());
  55. ASSERT(bmp.GetSafeHandle());
  56. CBitmap* pOldBitmap = (CBitmap*)dc.SelectObject(&bmp);
  57. CFont* pOldFont = NULL;
  58. CWnd* pParent = GetParent();
  59. ASSERT(pParent);
  60. CFont* pFont = pParent->GetFont();
  61. ASSERT(pFont);
  62. if(bVertical)
  63. {
  64. if(NULL == m_font.GetSafeHandle())
  65. {
  66. LOGFONT lf = {0};
  67. pFont->GetLogFont(&lf);
  68. lf.lfEscapement = 900;
  69. m_font.CreateFontIndirect(&lf);
  70. }
  71. ASSERT(m_font.GetSafeHandle());
  72. pOldFont = (CFont*)dc.SelectObject(&m_font);
  73. }
  74. else
  75. {
  76. pOldFont = (CFont*)dc.SelectObject(pFont);
  77. }
  78. double dPercent = (double)(nPos - nMin) / ((double)(nMax - nMin));
  79. dc.DrawEdge(rect, EDGE_SUNKEN, BF_RECT | BF_FLAT);
  80. CRect rc(rect);
  81. rc.DeflateRect(CSize(2, 2));
  82. dc.FillSolidRect(&rc, m_clrBarBkColor);
  83. CString strText(_T(""));
  84. GetWindowText(strText);
  85. if(m_bShowPercent)
  86. {
  87. strText.AppendFormat(_T("%d%% "), static_cast<int>((dPercent * 100.0) + 0.5));
  88. }
  89. dc.SetBkMode(TRANSPARENT);
  90. dc.SetTextColor(m_clrTextColor);
  91. CPoint pt(0, 0);
  92. CSize size = dc.GetOutputTextExtent(strText);
  93. if(!bVertical)
  94. {
  95. switch(m_AlignText)
  96. {
  97. case ALIGN_LEFT:
  98. pt.x = rc.left;
  99. break;
  100. case ALIGN_RIGHT:
  101. pt.x = rc.right - size.cx;
  102. break;
  103. case ALIGN_CENTER:
  104. default:
  105. pt.x = rc.left + (rc.Width() - size.cx) / 2;
  106. break;
  107. }
  108. pt.y = rc.top + (rc.Height() - size.cy) / 2;
  109. CRect rcPos(rc);
  110. rcPos.right = rcPos.left + (int)(dPercent * rcPos.Width());
  111. dc.FillSolidRect(rcPos, m_clrBarColor);
  112. dc.SetTextColor(m_clrTextColor);
  113. dc.ExtTextOut(pt.x, pt.y, ETO_OPAQUE, rcPos, strText, NULL);
  114. dc.SetTextColor(m_clrTextBkColor);
  115. dc.ExtTextOut(pt.x, pt.y, ETO_CLIPPED, &rcPos, strText, NULL);
  116. }
  117. else
  118. {
  119. switch(m_AlignText)
  120. {
  121. case ALIGN_LEFT:
  122. pt.y = rc.bottom;
  123. break;
  124. case ALIGN_RIGHT:
  125. pt.y = rc.top + size.cx;
  126. break;
  127. case ALIGN_CENTER:
  128. default:
  129. pt.y = rc.bottom - (rc.Height() - size.cx) / 2;
  130. break;
  131. }
  132. pt.x = rc.left + (rc.Width() - size.cy) / 2;
  133. CRect rcPos(rc);
  134. rcPos.top = rcPos.bottom - (int)(dPercent * rcPos.Height());
  135. dc.FillSolidRect(rcPos, m_clrBarColor);
  136. dc.SetTextColor(m_clrTextColor);
  137. dc.ExtTextOut(pt.x, pt.y, ETO_OPAQUE, rcPos, strText, NULL);
  138. dc.SetTextColor(m_clrTextBkColor);
  139. dc.ExtTextOut(pt.x, pt.y, ETO_CLIPPED, &rcPos, strText, NULL);
  140. }
  141. paintDC.BitBlt(rect.left, rect.top ,rect.Width(), rect.Height(), &dc, 0, 0, SRCCOPY);
  142. dc.SelectObject(pOldFont);
  143. dc.SelectObject(pOldBitmap);
  144. bmp.DeleteObject();
  145. dc.DeleteDC();
  146. }

效果图如下所示:

http://blog.csdn.net/visualeleven/article/details/6165007

时间: 2024-10-10 10:19:21

自绘CProgressCtrl进度条控件,支持自定义显示文本和进程百分比信息的相关文章

进度条控件CProgressCtrl实现进度滚动效果

关于CProgressCtrl 控件的基本操作网上有很多资料,可我想实现进度条中进度滚动效果,即很多时候程序出现的等待或启动画面,如下图: 实现这个效果的函数为SetMarquee(_In_ BOOL fMarqueeMode, _In_ int nInterval),第一个参数为开关,第二个参数指定滚动时间.且控件应该包含 PBS_MARQUEE风格,eg:m_ProgressCtl.Create(WS_CHILD|WS_VISIBLE|PBS_MARQUEE,CRect(100,200,25

为OLED屏增加GUI支持6:进度条控件

本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明. 环境: 主机:WIN10 开发环境:MDK5.13 MCU:STM32F103 源代码: gui_widget_progbar.h /** * Copyright (c), 2015-2025 * @file gui_widget_progbar.h * @brief 文本控件头文件 * @author jdh * @date 2015/11/22 */ #ifndef _GUI_WIDGET_PRO

为OLED屏添加GUI支持6:进度条控件

本文博客链接:http://blog.csdn.net/jdh99,作者:jdh,转载请注明. 环境: 主机:WIN10 开发环境:MDK5.13 MCU:STM32F103 源码: gui_widget_progbar.h /** * Copyright (c), 2015-2025 * @file gui_widget_progbar.h * @brief 文本控件头文件 * @author jdh * @date 2015/11/22 */ #ifndef _GUI_WIDGET_PROG

CProgressCtrl进度条控

CProgressCtrl常用属性 CProgressCtrl类常用成员函数 CProgressCtrl代码示例   一.CProgressCtrl控件属性 当我们在处理大程序时,常常需要耗很长时间(比如搜索内存,复制大文件),为了不让用户错误的认为系统已经死机,我们要给程序添加进度条. vertical :是否垂直显示. smooth :平滑过度,不显示进度方块.可以显示更细致. 二.CProgressCtrl类常用成员函数   SetRange void SetRange( short nL

Photoshop和WPF双剑配合,打造炫酷个性的进度条控件

现在如果想打造一款专业的App,UI的设计和操作的简便性相当重要.UI设计可以借助Photoshop或者AI等设计工具,之前了解到WPF设计工具Expression Blend可以直接导入PSD文件或者AI设计文件(当然不是全部特征支持),最近研究了一下,也废了一番周折,好在最后实现了预期的效果.下面将step by step用示例说明如何先用PS构建一个矢量图形模板,然后用Expression Blend导入PSD文件,并获取PATH的Data值,为打造一款炫酷的个性进度条控件构建美观UI.

HslControls组件库 工业控件库 曲线控件 时间控件 管道控件 温度计控件 阀门控件 传送带控件 进度条控件 电池控件 数码管控件等等

本篇博客主要对 HslControls 组件做一个大概的总览介绍,更详细的内容可以参照页面里的子链接,还有github上的源代码,然后进行相关的学习,和使用. Prepare 先从nuget下载到组件,然后就可以使用组件里的各种组件信息了. 在Visual Studio 中的NuGet管理器中可以下载安装,也可以直接在NuGet控制台输入下面的指令安装: Install-Package HslControls NuGet安装教程  http://www.cnblogs.com/dathlin/p

进度条控件基本使用

进度条控件基本使用 一.简介 二.方法 三.代码实例 四.注意点 五.易错点

用 CALayer 定制下载进度条控件

// // RPProgressView.h // CALayer定制下载进度条控件 // // Created by RinpeChen on 16/1/2. // Copyright © 2016年 rinpe. All rights reserved. // #import <UIKit/UIKit.h> @interface RPProgressView : UIView @property (nonatomic, assign) CGFloat progressValue; // 进

iOS:进度条控件的详细使用

进度条控件:UIProcessView:UIView 功能:顾名思义,用来显示下载进度或者传输数据进度. 属性: @property(nonatomic) UIProgressViewStyle progressViewStyle; //风格类型 @property(nonatomic) float progress;                                   //当前进度 @property(nonatomic, retain) UIColor* progressTi