C语言实例教程(PDF格式)-第47部分
按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 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_