CBitmapButton实现图形按钮

在编程中,经常要用到按钮控件,大部分情况下,文字按钮就OK了,但有时为了更好的效果,需要用到图形按钮。

在MFC中,应用CBitmapButton就可以实现图形按钮。CBitmapButton类继承自CButton类。你可以为图形按钮指定四张图片,分别对应按钮的四种不同状态:

正常显示(Up),鼠标按下(Down),获得焦点(Focused),不可用(Disabled)。

正常显示(Up)状态的图片是必须的,其他三张图片是可选的。

还有,按钮的Style必须指定为BS_OWNERDRAW.。

以下是利用CBitmapButton实现图形按钮的实例:

第一种方法:

(一)在VC6下新建一对话框工程,在对话框界面上拉出一按钮控件

指定按钮的Style为Owner Draw,即程式中得BS_OWNERDRAW样式。

利用ClassWizard为按钮关联CButton类变量,然后将CButton类型手动改为CBitmapButton。

(二)导入指定按钮四种状态的图片

以下只导入了3张图片,分别对应Up,Down,Focused

(三)在对话框的OnInitDialog函数中添加如下代码

LoadBitmaps加载状态图片,注意顺序为Up,Down,Focused,Disabled。

1 // TODO: Add extra initialization here  
2 m_btnBitmap.LoadBitmaps(IDB_UP, IDB_DOWN, IDB_FOCUSED); //Disabled状态的图片没有制作
3 m_btnBitmap.SizeToContent(); //调整按钮大小为图片大小

第二种方法:利用SubclassDlgItem

在界面中拉出一按钮控件后,不用关联变量,指定按钮的Style为Owner Draw,然后同上一样导入四张状态图片。创建CBitmapButton对象(注意不要创建函数的局部变量,否则在函数执行完毕时就销毁了),最好创建为对话框的成员变量,在对话框的OnInitDialog初始化函数中用LoadBitmaps加载图片,再利用SubclassDlgItem方法将该CBitmapButton与刚开始在界面上拉出的控件关联。按钮控件自动调整为和图片一样大小。

代码如下:

1 m_btnBitmap002.LoadBitmaps(IDB_UP, IDB_DOWN, IDB_FOCUSED);  
2 m_btnBitmap002.SubclassDlgItem(IDC_BTN_TESTAUTO, this);
3 //CBitmapButton test; //不可这样定义局部变量再关联
4 //test.LoadBitmaps(IDB_UP, IDB_DOWN, IDB_FOCUSED);
5 //test.SubclassDlgItem(IDC_BTN_TESTAUTO, this);

第三种方法:应用CBitmapButton的AutoLoad方法自动为按钮加载图片

BOOL AutoLoad(UINT nID, CWnd* pParent);

我们不用指定图片的ID,那么程序是采取怎样的规则去加载图片的呢?

规则:如果按钮控件的Caption为Test,则四张位图的ID应分别为“TestU”,“TestD”,“TestF”,“TestX”,分别对应Up,Down,Focused,Disabled状态。注意:""也是ID的一部分。

所以步骤为:
(一)在对话框中拉出按钮控件,Caption改为Test,指定按钮的Style为Owner Draw。

(二)定义对话框的成员变量CBitmapButton   m_btnBitmap003;

(三)导入四张状态位图,ID分别改为“TestU”,“TestD”,“TestF”,“TestX”。

(四)在对话框的OnInitDialog中调用AutoLoad方法

1 m_btnBitmap003.AutoLoad(IDC_BTNTEST, this);  

这种方法按钮也会自动调整为和位图一样大小。





posted on 2012-02-27 23:40  wangyao1052  阅读(8257)  评论(0编辑  收藏  举报

导航