在MFC的button控件上贴图,按键在热点效果时显示不同的图片

在MFC的button控件上贴图:
1、在资源管理器中添加一个button控件,该控件的ID为IDC_BUTTON1。
2、在button的属性中,将其中的Owner Draw设置为TRUE。(设置为用户自绘控件)。
3、在该对话框的代码中的头文件中添加CBitmapButton 类对象 m_BitmapButton。
4、在窗口的初始化函数中,为该类的对象添加图片,m_BitmapButton.LoadBitmaps(IDB_BITMAP1);
5、将该类与当前拥有控件的窗口绑定起来,m_BitmapButton.SubclassDlgItem(IDC_BUTTON1,this);
6、将控件的大小转换到和图片大小一样,m_BitmapButton.SizeToContent();


按键在热点效果时显示不同的图片

1:新建一个类。

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第1张图片

 

 

 

 

 

2Base class 选择CButton(继承CButton类)

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第2张图片

 

 

 

 

 

3:插入图片用于热点和非热点图片资源。

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第3张图片

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第4张图片

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第5张图片

 

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第6张图片

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第7张图片

 

 

 

4:在CBmpButton的头文件中声明保存按钮在热点和非热点时显示的图片资源、自定义声明SetHBitmap()函数用来设置按钮显示的图片资源。

 

 

 

在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第8张图片

 

 

 

5:在CBmpButton的头文件中声明WM_MOUSEMOVE事件处理函数OnMouseMove捕捉鼠标的位置—当鼠标在按钮上时显示热点图片,否则显示非热点图片。

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第9张图片

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第10张图片

 

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第11张图片

 

 

 

6 CBmpButton的头文件为

#if !defined(AFX_BMPBUTTON_H__F5347CC7_F08E_47AB_A1D2_AEAFF74DA65C__INCLUDED_)

#define AFX_BMPBUTTON_H__F5347CC7_F08E_47AB_A1D2_AEAFF74DA65C__INCLUDED_

 

#if _MSC_VER > 1000

#pragma once

#endif // _MSC_VER > 1000

// BmpButton.h : header file

//

 

/////////////////////////////////////////////////////////////////////////////

// CBmpButton window

 

class CBmpButton : public CButton

{

// Construction

public:

         CBmpButton();

         HBITMAP m_Hbitmap1;   //m_Hbitmap1保存按钮在热点时显示的图片资源

         HBITMAP m_Hbitmap2;   //m_Hbitmap2保存按钮在非热点时显示的图片资源

 

// Attributes

public:

 

// Operations

public:

 

         void SetHBitmap(HBITMAP m_Hbitmap1,HBITMAP m_Hbitmap2) ;  //用来保存按钮显示的图片资源

 

// Overrides

         // ClassWizard generated virtual function overrides

         //{{AFX_VIRTUAL(CBmpButton)

         //}}AFX_VIRTUAL

// Implementation

public:

         virtual ~CBmpButton();

 

         // Generated message map functions

protected:

         //{{AFX_MSG(CBmpButton)

         afx_msg void OnMouseMove(UINT nFlags, CPoint point);

         //}}AFX_MSG

 

         DECLARE_MESSAGE_MAP()

};

/////////////////////////////////////////////////////////////////////////////

//{{AFX_INSERT_LOCATION}}

// Microsoft Visual C++ will insert additional declarations immediately before the previous line.

#endif // !defined(AFX_BMPBUTTON_H__F5347CC7_F08E_47AB_A1D2_AEAFF74DA65C__INCLUDED_)

 

 

 

 

 

 

7:写SetHBitmap()函数中的代码

void CBmpButton::SetHBitmap(HBITMAP m_hbmap1,HBITMAP m_hbmap2)

{

         m_Hbitmap1=m_hbmap1;  //将图片资源保存到变量中

         m_Hbitmap2=m_hbmap2;  //将图片资源保存到变量中

}

 

 

 

 

 

8:写OnMouseMove()函数代码

void CBmpButton::OnMouseMove(UINT nFlags, CPoint point)

{

         // TODO: Add your message handler code here and/or call default

         CButton::OnMouseMove(nFlags, point);  //获取鼠标移动的坐标位置

    CRect rect;

         GetClientRect(&rect);        //获取按钮的矩形区域

         if(rect.PtInRect(point))       //判断鼠标移动的坐标位置是否在按钮的矩形区域当中

      {

                   SetCapture();

                   SetBitmap(m_Hbitmap1);

         }

         else

         {

                   ReleaseCapture();

                   SetBitmap(m_Hbitmap2);

         }

}

 

 

 

 

 

 

9:设置按钮属性

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第12张图片

 

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第13张图片

 

 

 

 

为按钮关联变量

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第14张图片

 

 

 

 

10:在包含按钮的窗口类的初始化窗口函数(OnInitDialog()

BOOL CLogin::OnInitDialog()

{

         CDialog::OnInitDialog();

        

         // TODO: Add extra initialization here

         //当初始化窗口时,先载入的图片

     m_test.SetBitmap(LoadBitmap(AfxGetInstanceHandle(),MAKEINTRESOURCE(IDB_HOU)));

    //当鼠标移动到按钮范围内时变IDB_QIAN,移出按钮范围后还原IDB_HOU

         m_test.SetHBitmap(LoadBitmap(AfxGetInstanceHandle(),MAKEINTRESOURCE(IDB_QIAN)),

                           LoadBitmap(AfxGetInstanceHandle(),MAKEINTRESOURCE(IDB_HOU)));

        

         return TRUE;  // return TRUE unless you set the focus to a control

                       // EXCEPTION: OCX Property Pages should return FALSE

}

 

 

 

11:鼠标无法抓屏鼠标直接画出

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第15张图片

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第16张图片

 

 

 

 在MFC的button控件上贴图,按键在热点效果时显示不同的图片_第17张图片

你可能感兴趣的:(在MFC的button控件上贴图,按键在热点效果时显示不同的图片)