八宝书库 > 文学其他电子书 > C语言实例教程(PDF格式) >

第47部分

C语言实例教程(PDF格式)-第47部分

小说: C语言实例教程(PDF格式) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!






font。DeleteObject();  



font。CreateFontIndirect(&lf);  



pEdit…》SetFont(&font);  



}  



}  



在成员函数OnEditSetfont中所使用的方法和技巧已在第三节的末尾 

讲述如何为按钮控件设置字体时进行了介绍。因此对于函数 

OnEditSetfont我们不进行详细的注解。  



6。   考虑下面的情况:如果当前没有可供撤消的操作, “编辑”菜单 

下的 “撤消”应该处于不可用(变灰)状态;同样的,如果当前编辑控 

件中没有选定任何文本,那么 “剪贴”、 “复制”以及 “删除”命令 

也应该不可用;如果当前剪贴板中没有任何文本数据, “粘贴”命令 

应该不可用。我们通过为消息WM_INITMENUPOPUP添加消息处理函数来 

设置各菜单命令的可用状态。该消息在用户单击某菜单之后在菜单项 

弹出之前发送。  



对于类CEditDemoDlg,我们不能使用ClassWizard来为消息 

WM_INITMENUPOPUP添加消息处理函数,但事实上,对话框也可以接收 

到消息WM_INITMENUPOPUP。这里,我们可以手动来添加相应的消息映 

射项。  



第一步是在类CEditDemoDlg的定义中添加消息处理函数  



afx_msg void OnInitMenuPopup( CMenu* pPopupMenu; UINT nIndex; BOOL bSysMenu );  



可以把该处理函数的声明添加到由ClassWizard生成的消息处理函数 

的后面。由ClassWizard生成的消息处理函数位于两行注释标记// 

{{AFX_MSG和//}}AFX_MSG之间。同我们在此之前强调过的一样,不要 

将OnInitMenuPopup的声明添加到两行注释之间。以后如果再遇到与 

此相似的情况,我们将不再强调。  


…………………………………………………………Page 358……………………………………………………………

接着添加相应的消息映射入口,在类CEditDemoDlg的实现文件 

EditEemoDlg。cpp中找到宏BEGIN_MESSAGE_MAP(CEditDemoDlg;  

CDialog),在它之后,宏END_MESSAGE_MAP之前添加下面的宏代码:  



ON_WM_INITMENUPOPUP()  



我们仍应将上面的代码添加到注释标记//{{AFX_MSG_MAP和//}} 

AFX_MSG_MAP之外。同样的,以后如果再遇到这种情况我们将不再强 

调。  



最后添加函数OnInitMenuPopup的定义:  



void CEditDemoDlg::OnInitMenuPopup( CMenu* pPopupMenu; UINT nIndex; BOOL  

bSysMenu )  



{  



CEdit *pEdit=(CEdit*)GetDlgItem(IDC_EDIT);  



// 当用户单击的是窗口的控制菜单时 bSysMenu 参数为真,否则为假  



if (!bSysMenu)  



{  



// 检查编辑控件是否有可撤消的操作  



if (pEdit…》CanUndo())  



{  



pPopupMenu…》EnableMenuItem(ID_EDIT_UNDO;MF_ENABLED);  



}  



else  



{  



pPopupMenu…》EnableMenuItem(ID_EDIT_UNDO;MF_GRAYED);  



}  



// 检查编辑控件中是否有选定的文本  



int nStart;nEnd;  



pEdit…》GetSel(nStart;nEnd);  



if (nStart==nEnd)  


…………………………………………………………Page 359……………………………………………………………

{  



pPopupMenu…》EnableMenuItem(ID_EDIT_CUT;MF_GRAYED);  



pPopupMenu…》EnableMenuItem(ID_EDIT_COPY;MF_GRAYED);  



pPopupMenu…》EnableMenuItem(ID_EDIT_DEL;MF_GRAYED);  



}  



else  



{  



pPopupMenu…》EnableMenuItem(ID_EDIT_CUT;MF_ENABLED);  



pPopupMenu…》EnableMenuItem(ID_EDIT_COPY;MF_ENABLED);  



pPopupMenu…》EnableMenuItem(ID_EDIT_DEL;MF_ENABLED);  



}  



// 检查剪贴板中是否有文本格式的数据可供粘贴  



// 该过程通过调用 Win32 API 函数 IsClipboardFormatAvailable 来实现  



if (IsClipboardFormatAvailable(CF_TEXT))  



{  



pPopupMenu…》EnableMenuItem(ID_EDIT_PASTE;MF_ENABLED);  



}  



else  



{  



pPopupMenu…》EnableMenuItem(ID_EDIT_PASTE;MF_GRAYED);  



}  



}  



}  



7。   最后我们希望一点,就是说用户可以改变对话框的大小,而且当 

用户改变对话框的大小时,编辑框自动的改变其大小以适应父窗口大 

小的变化。方法是为WM_SIZE添加消息处理函数。在进行这一步操作 

之前,打开对话框的Dialog   Properties对话框,在Styles选项卡中 


…………………………………………………………Page 360……………………………………………………………

将其Border属性设置为Resizing                                (即可以改变大小),同时将 

Maximize             box属性值设置为真。然后,使用ClassWizard为消息 

WM_SIZE添加消息处理函数OnSize,其定义如下:  



void CEditDemoDlg::OnSize(UINT nType; int cx; int cy)   



{  



// 调用基类的 OnSize 成员函数  



CDialog::OnSize(nType; cx; cy);  



CRect rect;  



// 获得父窗口的客户区矩形  



GetClientRect(&rect);  



CEdit *pEdit=(CEdit*)GetDlgItem(IDC_EDIT);  



if (pEdit)  



{  



// 改变编辑控件的大小以适应父窗口大小的改变  



pEdit…》MoveWindow(&rect);  



}  



}  



由于OnSize会在对话框第一次显示时被调用,因此使用if语句检查 

pEdit是否为NULL是必要的。出于同样的目的,我们还需要使用下面 

的代码来替换成员函数OnInitDialog中的// TODO注释:  



CRect rect;  



GetClientRect(&rect);  



CEdit *pEdit=(CEdit*)GetDlgItem(IDC_EDIT);  



if (pEdit)  



{  



pEdit…》MoveWindow(&rect);  



}  


…………………………………………………………Page 361……………………………………………………………

它在对话框第一次显示时完成与上面的OnSize成员函数同样的操作。 

以保证在第一次显示对话框时编辑框控件以正确的大小进行显示。  



编译并运行上面的程序 (如图6。46),并测试其各项功能是否正常。  



                                       



               图6。 46 示例程序EditDemo的运行结果  



                  第六节 列表框控件  



列表框控件通常用来列出一系列可供用户从中进行选择的项,这些项 

一般来说都在字符串的形式给出,但也可以采用其它的形式,如图形 

等。列表框可以只允许单一选择,也就是说用户同时只能选择所有列 

表项中的一项;除此之外,列表框也可以是多项选择的,用户可以在 

多项选择列表框中选择多于一项的列表项。当用户选择了某项时,该 

项被反白显示,同时列表框向父窗口发送一条通知消息。MFC类 

CListBox封装了Windows标准列表框控件,其成员函数 (参见表6。26) 

提供了对标准列表框的绝大多数操作。  



               表6。 26 在类CListBox中定义的成员函数  



       成员函数        描述  



       AddString   向列表框中添加字符串  



       CharToItem  为不包含字符串的自绘制列表框提供对 

                   WM_CHAR的定制处理  



       CListBox    构造一个CListBox对象  



       pareItem  由框架调用以决定新添加的项在有序自绘制列 

                   表框中的位置  



       Create      创建一个Windows列表框控件,并将它与 

                   CListBox对象相关联  


…………………………………………………………Page 362……………………………………………………………

DeleteItem   当用户从自绘制列表框中删除一项时由框架调 

             用  



DeleteString  从列表框中删除字符串  



Dir          从当前目录向列表框中添加文件名  



DrawItem     当自绘列表框的可视部分改变时由框架调用  



FindString   在列表框中查询指定的字符串  



FindStringExact  查找与指定字符串相匹配的第一个列表框字符 

             串  



GetAnchorIndex   返回列表框中当前 “锚点”项的基于零的索引  



                                              续表6。26 



成员函数            描述  



GetCaretIndex   在多重选择列表框中获得当前拥有焦点矩 

                形的项的索引  



GetCount        返回列表框中字符串的数 目  



GetCurSel       返回列表框中当前选择字符串的基于零的 

                索引值  



GetHorizontalExtent  以象素为单位返回列表框横向可滚动的宽 

                度  



GetItemData     返回下列表框项相关联的32位值  



GetItemDataPtr  返回指向列表框项的指针  



GetItemHeight   决定列表框中项的高度  



GetLocale       获得列表框使用的区域标识符  



GetSel          返回列表框项的选定状态  



GetSelItems     返回当前选定字符串的索引  



GetSelCount     在多重选择列表框中获得当前选定字符串 

                的数 目  



GetText         拷贝列表框项到缓冲区  



GetTextLen      以字节为单位返回列表框项的长度  



GetTopIndex     返回列表框中第一个可视项的索引  


…………………………………………………………Page 363……………………………………………………………

InitStorage     为列表框项和字符串预先分配内存  



InsertString    在列表框中的指定位置插入一个字符串  



ItemFromPoint   返回与指定点最接近的列表框项的索引  



MeasureItem     当自绘列表框创建时由框架调用以获得列 

                表框的尺寸  



ResetContent    从列表框中清除所有的项  



SelectString    从单项选择列表框中查找并选定一个字符 

                串  



SelItemRange    在多重选择列表框中选中某一范围的字符 

                串或清除某一范围的字符串的选定状态  



SetAnchorIndex  在多重选择列表框的设置扩展选定的起点 

                ( “锚点”项)  



SetCaretIndex   在多重选择列表框中设置当前拥有焦点矩 

                形的项的索引  



SetColumnWidth  设置多列列表框的列宽  



SetCurSel       在列表框中选定一字符串  



SetHorizontalExtent  以象素为单位设置列表框横向可滚动的宽 

                度  



SetItemHeight   设置列表框中项的高度  



SetItemRect     返回列表框项当前显示的边界矩形  



SetLocale       为列表框指定区域标识符  



                                              续表6。26 



成员函数        描述  



SetSel      在多重选择列表框中选定一列表框项或清除某一 

            列表框项的选定状态  



SetTabStops  设置列表框的制表位  



SetTopIndex  设置列表框中第一个可视项的基于零的索引  



VKeyToItem  为具有LBS_WANTKEYBOARDINPUT样式的列表框提 

            供定制的WM_KEYDOWN消息处理  


…………………………………………………………Page 364……………………………………………………………

以下是列表框可能向父窗口发送的通知消息及其说明:  



        ON_LBN_DLBCLK:  用户双击了列表框中的字符串。 

                       仅当列表框具有LBS_NOTIFY样式 

                       时会发送该通知消息  



        ON_LBN_ERRSPACE:  列表框不能按需要分配足够的内 

                       存  



        ON_LBN_KILLFOCUS:  列表框失去输入焦点  



        ON_LBN_SELCANCEL:  列表框中的当前选择被取消。仅 

                       当列表框具有LBS_NOTIFY样式时 

                       才会发送该通知消息  



        ON_LBN_SELCHANGE:  列表框中的选择将被更新。需要 

                       注意的是,当使用成员函数 

                       CListBox::SetCurSel时不会发送 

                       该通知消息,同时,该消息也仅 

                       当列表框具有LBS_NOTIFY样式才 

                       会发送。对于多重选择列表框, 

                       当用户按下光标键时,即使所选 

                       择的内容没有改变,也会发送 

                       LBN_SELCHANGE通知消息。  



        ON_LBN_SETFOCUS:  列表框获得输入焦点  



        ON_WM_CHARTOITEM:  不包括字符串的列表框收到 

                       WM_CHAR消息  



        ON_WM_VKEYTOITEM:  具有LBS_

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的