DrawItem

原文链接: http://blog.csdn.net/jiftlixu/article/details/4893505

今天从CButton派生了一个类CUIButton,主要用于自绘,按照基本的流程,重写DrawItem方法。

步骤如下:点击CUIButton按钮,在右键弹出菜单中选择“add windows message Handler",

找到DrawItem,为其添加消息映射,添加的代码如下:

void CUIButton::OnDrawItem(int nIDCtl, LPDRAWITEMSTRUCT lpDrawItemStruct)

结果在使用到CUIButton的地方用SubClassDlgItem就会出问题。

后来调试发现,不应该按照上面的添加此消息的映射,而是为CUIButton类重写DrawItem函数,添

加方法:

在类CUIButton右键,在弹出菜单中选择"Add Virtual Function",弹出的添加虚函数框中选

择"DrawItem",向导为我们生成的代码如下:

void CUIButton::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct)

在这里添加所需的自绘代码就ok了

附: how to implement control to self-draw

1、从CButton类派生自己的CUIControl类

2、借助于MFC向导生成工具,为期添加虚函数DrawItem()和OnEraseBkgnd()。

注意:DrawItem()是控件重定义的函数,不是OnDrawItem()。

3、在DrawItem()中近控件的自绘处理,这里给出一个实例代码,用于一个自定义Button,在

Button上面绘图:

void CUIButton::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct)
{
 // TODO: Add your message handler code here and/or call default
 
 //CButton::OnDrawItem(nIDCtl, lpDrawItemStruct);

int nCxIcon = ::GetSystemMetrics(SM_CXICON);
 int nCyIcon = ::GetSystemMetrics(SM_CYICON);
 CDC *pDC = CDC::FromHandle(lpDrawItemStruct->hDC);
 CBitmap bitmap;
 bitmap.CreateCompatibleBitmap(pDC,nCxIcon,nCyIcon);
 CDC dcMem;
 dcMem.CreateCompatibleDC(pDC);
 CBitmap *pOldBitmap = (CBitmap *)dcMem.SelectObject(bitmap);
 ASSERT(pOldBitmap);

HICON hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
 ASSERT(hIcon);

CRect rcClient;
 GetClientRect(&rcClient); // get the button‘s rect
 dcMem.StretchBlt(0,0,nCxIcon,nCyIcon,pDC,2,2,rcClient.Width() - CX_SHADOW - 4, 
  rcClient.Height() - CY_SHADOW - 4,SRCCOPY);
 
 dcMem.DrawIcon(0,0,hIcon);

// draw border around icon
 CPen pen;
 pen.CreateStockObject(BLACK_PEN);
 ASSERT(pDC != NULL);
 CPen* pPenOld = pDC->SelectObject(&pen);
 pDC->Rectangle(0, 0, rcClient.Width()-CX_SHADOW, rcClient.Height()-CY_SHADOW);
 if (pPenOld)
  pDC->SelectObject(pPenOld);

//pDC->StretchBlt(0,0,80,80,&dcMem,0,0,nCxIcon,nCyIcon,SRCCOPY);
 pDC->StretchBlt(2,2,rcClient.Width() - CX_SHADOW - 4,rcClient.Height() - CY_SHADOW - 4,&dcMem,0,0,nCxIcon,nCyIcon,SRCCOPY);

}

4、为OnEraseBkGround()添加代码。这里很简单,直接返回True即可:

BOOL CUIButton::OnEraseBkgnd(CDC* pDC) 
{
 // TODO: Add your message handler code here and/or call default
 return TRUE;
 //return CButton::OnEraseBkgnd(pDC);
}

5、在你的对话框中使用CUIButton按钮,首先在dialog资源中添加一个按钮(CButton)。

6、在对话框类的头文件中定义一个成员CUIButton m_CtlUIBtn;注意变量的类型是CUIButton而

不是CButton

7 、在OnInitDialog中用SubClass技术:

BOOL CAboutDlg::OnInitDialog() 
{
 CDialog::OnInitDialog(); 
 m_CtlUIButton.SubclassDlgItem(IDC_UI_BUTTON,this);
  return TRUE;  // return TRUE unless you set the focus to a control
               // EXCEPTION: OCX Property Pages should return FALSE
}

that is OK!

时间: 2024-10-12 12:53:36

DrawItem的相关文章

自绘CListCtrl类,重载虚函数DrawItem

[cpp] view plain copy //自绘CListCtrl类,重载虚函数DrawItem void CNewListCtrl::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct) { // TODO: Add your code to draw the specified item ASSERT(lpDrawItemStruct->CtlType == ODT_LISTVIEW); CDC dc; dc.Attach(lpDrawItemStruc

WM_DRAWITEM与DrawItem()的讨论(自绘)

http://blog.csdn.net/FlowShell/archive/2009/10/10/4648800.aspx 我在学习中经常遇到要重写DrawItem()的情况,但又有一个WM_DRAWITEM消息,它们是什么样的关系呢. 如果我们要重写一个CButton取名为CMyButton,我们可以重写CMyButton的DrawItem()函数来实现我们的 需求,但CMyButton::DrawItem()是在什么时候调用呢?它是在它的宿主类的OnDrawItem()中被调用, OnDr

简单的自绘CListBox,重载虚MeasureItem和DrawItem这两个虚函数

[cpp] view plain copy //例如CNewListBox继承自CListBox,重载虚MeasureItem和DrawItem这两个虚函数,代码如下: void CNewListBox::DrawItem(LPDRAWITEMSTRUCT lpDrawItemStruct) { // TODO: Add your code to draw the specified item ASSERT(lpDrawItemStruct->CtlType == ODT_LISTBOX); L

[00008]-[2015-08-21]-[00]-[Windows 程序设计 --- OnEraseBkGnd() OnPaint() DrawItem() 绘图处理]

问题是这样产生的.在OnEraseBkGnd中,如果你不调用原来缺省的OnEraseBkGnd只是重画背景则不会有闪烁.而在OnPaint里面,由于它隐含的调用了OnEraseBkGnd,而你又没有处理OnEraseBkGnd函数,这时就和窗口缺省的背景刷相关了.缺省的OnEraseBkGnd操作使用窗口的缺省背景刷刷新背景(一般情况下是白刷),而随后你又自己重画背景造成屏幕闪动.另外一个问题是OnEraseBkGnd不是每次都会被调用的.如果你调用Invalidate的时候参数为TRUE,那么

CListCtrl

CCmdTarget     └CListCtrl CListCtrl类封装"列表视图控件"功能,显示每个包含图标(列表视图中)和标签的收集.除图标和标签外,每一项还能有显示在图标和标签的右边的列中的信息. 视图 列表视图控件可用四种不同方式显示其内容,称为"视图". . 图标视图每一项以全尺寸图标(32×32像素)出现,下面有一个标签.用户可在列表视图窗口拖动项到任意位置. · 小图标视图每一项以小图标(16×16像素)出现,右边有一个标签.用户可在列表视图窗口拖

QStyle

转贴: http://hi.baidu.com/yjj2008/blog/item/6cd4a1892ef0d4b60f2444a5.html 本文介绍了如何使用qt提供的接口来设计自己的GUI风格(look and feel),并通过一个具体的例子(使QSpinBox垂直显示)来详细说明过程.运行环境:redhat 9.0,qt-x11-free-3 1.Qt的风格 a) Qt简介 Qt是一个跨平台的C++图形用户界面应用程序开发库,使用Qt可以开发出高质量的图形用户接口,它是完全面向对象的.

MFC控件使用技巧:List Control

1)每列内容过长,显示不完整 只有加载数据的情况下,才会出现水平滚动条 解决方案: 可以添加如下一个空的内容项: m_List.InsertItem(0,NULL);//为了显示进度条 2)不允许点击修改第一列(当然最多能够让我们改动的也只有他了) MFC默认情况下可以修改第一列,其他的不允许修改(需要定制DrawItem) 解决方案: Edit Labels 属性设置为 False 3)报表的形式表示 View 属性设置为 Report 4)注意:不要和列表框控件混淆(英文名: List Bo

界面美化.CStatic控件的美化(好多系列文章)

http://www.cnblogs.com/20090802/archive/2010/09/17/1829283.html 静态控件也是比较常用的控件,在VS开发环境中用的应该挺频繁的吧. 其实mfc中实现对窗口美化,主要依赖于重绘.static控件也是个窗口,windows为其留有自绘的权利,可以设置其样式为SS_OWNERDRAW,Windows就会把其绘制权利交给我们的代码,怎么绘制就看我们的代码了.mfc中更好的一种方式就是消息反射,省的自己来做这一步操作了,我们重载CStatic中

MFCC常用类介绍

http://www.cnblogs.com/lzmfywz/archive/2012/04/22/2465069.html CStatic CObject └CCmdTarget └CWnd └CStatic CStatic类提供了一个Windows静态控件的性能.一个静态控件用来显示一个文本字符串,框,矩形,图标,光标,位图,或增强的图元文件.它可以被用来作为标签,框,或用来分隔其它的控件.一个静态控件不接收输入,也不提供输出:但是,如果它是用SS_NOTIFY风格创建的,则它可以通知其父有