打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
自绘按钮中注意的问题(DrawItem)

今天从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!

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
如何给button等按钮和控件加背景色或者图片?还有dialog如何增加背景色和图片背景,...
按钮加载位图
用VC++实现自绘按钮控制
白乔原创:VC之美化界面篇
设置listctrl行高
VC改变对话框按钮字体颜色和背景的解决方案
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服