【09】MFC入门到精通——MFC 属性页对话框的 CPropertyPage类 和 CPropertySheet 类
文章目录
- 九、属性页对话框的类`CPropertyPage`类 和 `CPropertySheet` 类。
- 9.1 CPropertyPage 类
- (1)构造函数
- (2)CancelToClose()函数
- (3)SetModified()函数
- (4)可重载函数
- 9.2 CPropertySheet类
- (1)构造函数
- (2)GetActiveIndex()函数
- (3)GetActivePage()函数
- (4)GetPage()函数
- (5)GetPageCount()函数
- (6)GetPageIndex()函数
- (7)SetActivePage()函数
- (8)SetWizardButtons()函数
- (9)SetWizardMode()函数
- (10)SetTitle()函数
- (11)AddPage()函数
- (12)PressButton()函数
- (13)RemovePage()函数
九、属性页对话框的类CPropertyPage
类 和 CPropertySheet
类。
属性页对话框的分类
属性页对话框想必大家并不陌生,XP系统中桌面右键点属性,弹出的就是属性页对话框,它通过标签切换各个页面。另外,我们在创建MFC工程时使用的向导对话框也属于属性页对话框,它通过点击“Next”等按钮来切换页面。
属性页对话框就是包含一般属性页对话框和向导对话框两类。它将多个对话框集成于一身,通过标签或按钮来切换页面。
我们使用属性页对话框时,用到的类主要有两个:CPropertyPage
类 和 CPropertySheet
类。
CMFCPropertySheet和CMFCPropertyPage都是vs08sp1以后引入的新类,扩充了已有的CPropertySheet和CPropertyPage这两个类。
9.1 CPropertyPage 类
CPropertyPage类继承自CDialog类,它被用于处理某单个的属性页,所以要为每个属性页都创建一个继承自CPropertyPage的子类。大家可以在VS2010的MSDN中查找CPropertyPage类以及它的成员的详细说明。下面就为大家讲解MSDN中列出的CPropertyPage类的部分主要成员函数。
(1)构造函数
这里讲三个CProperty类的构造函数,函数原型为:
CPropertyPage( );
explicit CPropertyPage(UINT nIDTemplate,UINT nIDCaption = 0,DWORD dwSize = sizeof(PROPSHEETPAGE));
explicit CPropertyPage(LPCTSTR lpszTemplateName,UINT nIDCaption = 0,DWORD dwSize = sizeof(PROPSHEETPAGE));
-
第一个是没有任何参数的构造函数。
-
第二个构造函数中,参数nIDTemplate是属性页的对话框资源ID,
- 参数nIDCaption是属性页对话框选项卡的标题所用字符串资源的ID,若设为0,则选项卡标题就使用该属性页的对话框资源的标题。
-
第三个构造函数中,参数lpszTemplateName为属性页的对话框资源的名称字符串,不能为NULL。参数nIDCaption同上。
(2)CancelToClose()函数
在模态属性页对话框的属性页进行了某不可恢复的操作后,使用CancelToClose() 函数
将“OK”按钮改为“Close”按钮,并禁用“Cancel”按钮。函数原型为:
void CancelToClose( );
(3)SetModified()函数
调用此函数可激活或禁用“Apply”按钮,函数原型为:
void SetModified(BOOL bChanged = TRUE);
(4)可重载函数
CPropertyPage类提供了一些消息处理函数,来响应属性页对话框的各种消息。
我们重载这些消息处理函数,就可以自定义对属性页对话框操作的处理。
可重载的消息处理函数包括:
OnApply:处理属性页的“Apply”按钮被单击的消息OnCancel:处理属性页的“Cancel”按钮被单击的消息OnKillActive:处理属性页当前活动状态被切换的消息,常用于数据验证OnOK:处理属性页的“OK”按钮、“Apply”按钮或者“Close”按钮被单击的消息OnQueryCancel:处理属性页的“Cancel”按钮被单击前发出的消息OnReset:处理属性页的“Reset”按钮被单击的消息OnSetActive:处理属性页被切换为当前活动页的消息OnWizardBack:处理属性页的“Back”按钮被单击的消息,仅在向导对话框中有效OnWizardFinish:处理属性页的“Finish”按钮被单击的消息,仅在向导对话框中有效OnWizardNext:处理属性页的“Next”按钮被单击的消息,仅在向导对话框中有效
9.2 CPropertySheet类
CPropertySheet类继承自CWnd类,它是属性表类,负责加载、打开或删除属性页,并可以在属性页对话框中切换属性页。它跟对话框类似,也有模态和非模态两种。下面就讲解CPropertySheet类的部分成员函数。
(1)构造函数
这里依然列出CPropertySheet类的三个构造函数:
CPropertySheet( );
explicit CPropertySheet(UINT nIDCaption,CWnd* pParentWnd = NULL,UINT iSelectPage = 0);
explicit CPropertySheet(LPCTSTR pszCaption,CWnd* pParentWnd = NULL,UINT iSelectPage = 0);
-
参数 nIDCaption: 标题的字符串资源的ID。
-
参数 pParentWnd: 属性页对话框的父窗口,若设为NULL,则父窗口为应用程序的主窗口。
-
参数 iSelectPage: 初始状态时,活动属性页的索引,默认为第一个添加到属性表的属性页。
-
参数 pszCaption: 标题字符串。
(2)GetActiveIndex()函数
获取当前活动属性页的索引。函数原型为:
int GetActiveIndex( ) const;
- 返回值:当前活动属性页的索引。
(3)GetActivePage()函数
获取当前活动属性页对象。函数原型为:
CPropertyPage* GetActivePage( ) const;
- 返回值:当前活动属性页对象的指针。
(4)GetPage()函数
获取某个属性页对象。函数原型为:
CPropertyPage* GetPage(int nPage) const;
-
参数nPage: 目标属性页的索引。
-
返回值: 目标属性页对象的指针。
(5)GetPageCount()函数
获取属性页的数量。函数原型为:
int GetPageCount( ) const;
- 返回值:属性页的数量。
(6)GetPageIndex()函数
获取某属性页在属性页对话框中的索引。函数原型为:
int GetPageIndex(CPropertyPage* pPage);
-
参数pPage: 要获取索引的属性页对象的指针。
-
返回值: 属性页对象在属性页对话框中的索引。
(7)SetActivePage()函数
设置某个属性页为活动属性页。函数原型为:
BOOL SetActivePage(int nPage);BOOL SetActivePage(CPropertyPage* pPage);
-
参数 nPage: 要设置为活动属性页的索引。
-
参数 pPage: 要设置为活动属性页的对象指针。
(8)SetWizardButtons()函数
在向导对话框上启用或禁用Back、Next或Finish按钮,应在调用DoModal之前调用此函数。
函数原型为:
void SetWizardButtons(DWORD dwFlags);
参数dwFlags:设置向导按钮的外观和功能属性。可以是以下值的组合:
PSWIZB_BACK 启用“Back”按钮,如果不包含此值则禁用“Back”按钮。PSWIZB_NEXT 启用“Next”按钮,如果不包含此值则禁用“Next”按钮。PSWIZB_FINISH 启用“Finish”按钮。PSWIZB_DISABLEDFINISH 显示禁用的“Finish”按钮。
(9)SetWizardMode()函数
设置属性页对话框为向导对话框模式,应在调用DoModal之前调用此函数。函数原型为:
void SetWizardMode( );
(10)SetTitle()函数
设置属性对话框的标题。函数原型为:
void SetTitle(LPCTSTR lpszText,UINT nStyle = 0);
-
参数lpszText:标题字符串。
-
参数nStyle:指定属性表标题的风格。应当为 0 或 PSH_PROPTITLE。
如果设为PSH_PROPTITLE,则单词“Properties”会出现在指定标题之后。
例如,SetTitle(“Simple”,PSH_PROPTITLE)这种调用会使得属性表标题为 “Simple Properties”。
(11)AddPage()函数
为属性对话框添加新的属性页。函数原型为:
void AddPage(CPropertyPage *pPage);
- 参数pPage:要添加的新的属性页的对象指针。
(12)PressButton()函数
模拟按下某指定的按钮。函数原型为:
void PressButton(int nButton);
- 参数nButton:要模拟按下的按钮,它可以是下列值之一:
PSBTN_BACK 选择“Back”按钮。PSBTN_NEXT 选择“Next”按钮。PSBTN_FINISH 选择“Finish”按钮。PSBTN_OK 选择“OK”按钮。PSBTN_APPLYNOW 选择“Apply”按钮。PSBTN_CANCEL 选择“Cancel”按钮。PSBTN_HELP 选择“帮助”按钮。
(13)RemovePage()函数
删除某属性页。函数原型为:
void RemovePage(CPropertyPage *pPage);
void RemovePage(int nPage);
-
参数pPage:要删除的属性页的对象指针。
-
参数nPage:要删除的属性页的索引。
属性对话框和相关的两个类就先介绍到这,主要是为后面使用属性页对话框做准备。