按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
}
5。2 文本编辑(Edit Box )控件
5。2。1 文本编辑控件的使用
文本编辑(Edit Box )控件是一种传统控件,实际上是一个简易的正文编辑器,用户可
以在编辑框中输入并编辑正文。
文本编辑框既可以是单行的,也可以是多行的,多行编辑框的编号是从零开始编排的。
在一个多行编辑框中,除了最后一行外,每一行的结尾处都有一对回车换行符(用“rn ”表
示),这对回车换行符是正文换行的标志,在屏幕上是不可见的。
文本编辑控件会向父窗口发出如表 5…4 所示的控件通知消息。
表 5…4 文本编辑控件的通知消息
通知消息 含义
编辑框的内容被用户改变了,与 EN_UPDATE 不同,该消息是在编辑框显示的正
EN_CHANGE
文被刷新后才发出的
EN_ERRSPACE 编辑框控件无法申请足够的动态内存来满足需要
EN_HSCROLL 用户在水平滚动条上单击鼠标
EN_KILLFOCUS 编辑框失去输入焦点
输 入 的 字 符 超 过 了 规 定 的 最 大 字 符 数 。 在 没 有 ES_AUTOHSCROLL 或
EN_MAXTEXT
ES_AUTOVSCROLL 的编辑框中,当正文超出了编辑框的边框时也会发出该消息
EN_SETFOCUS 编辑框获得输入焦点
EN_UPDATE 在编辑框准备显示改变了的正文时发送该消息
EN_VSCROLL 用户在垂直滚动条上单击鼠标
编辑框控件的相关操作函数封装在 MFC 类库中的 CEdit 类中。CEdit 类的成员函数 Create
用于创建按钮控件,该函数的声明如下:
BOOL Create(DWORD dwStyle;const RECT& rect;CWnd* pParentWnd;UINT nID);
其中参数 dwStyle 指定了编辑框控件风格,文本编辑控件的主要风格如表 5…5 所示。
rect 指定了编辑框的位置和尺寸。
pParentWnd 指定了父窗口,不能为 NULL 。文本编辑框的 ID 由 nID 指定。如果创建成
功,该函数返回 TRUE,否则返回 FALSE 。
表 5…5 文本编辑控件风格
控件风格 含义
当用户在行尾键入一个字符时,正文将自动向右滚动 10 个字符,当用户按回车
ES_AUTOHSCROLL
键时,正文总是滚向左边
ES_AUTOVSCROLL 当用户在最后一个可见行按回车键时,正文向上滚动一页
ES_CENTER 在多行编辑框中使正文居中
ES_LEFT 左对齐正文
ES_LOWERCASE 把用户输入的字母统统转换成小写字母
指定一个多行编辑器 。若多行编辑器不指定 ES_AUTOHSCROLL 风格,则会自
ES_MULTILINE 动换行,若不指定 ES_AUTOVSCROLL ,则多行编辑器会在窗口中正文装满时
发出警告声响
·103 ·
…………………………………………………………Page 113……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
续表
控件风格 含义
默认时,当编辑框失去输入焦点后会隐藏所选的正文,当获得输入焦点时又显
ES_NOHIDESEL
示出来。设置该风格可禁止这种默认行为
使编辑框中的正文可以在 ANSI 字符集和 OEM 字符集之间相互转换。这在编辑
ES_OEMCONVERT
框中包含文件名时是很有用的
ES_PASSWORD 使所有键入的字符都用“*”来显示
ES_RIGHT 右对齐正文
ES_UPPERCASE 把用户输入的字母统统转换成大写字母
ES_READONLY 将编辑框设置成只读的
使多行编辑器接收回车键输入并换行。如果不指定该风格,按回车键会选择默
ES_WANTRETURN
认的命令按钮,这往往会导致对话框的关闭
除了表 5…5 中的风格外,一般还要为文本编辑控件指定 WS_CHILD 、WS_VISIBLE 、
WS_TABSTOP 和 WS_BORDER 等窗口风格。创建一个普通的单行编辑框应指定风格
WS_CHILD|WS_VISIBLE|WS_TABSTOP |WS_BORDER|ES_LEFT ,这将创建一个带边框、左
对 齐 正 文 、 可 水 平 滚 动 的 单 行 编 辑 器 。 要 创 建 一 个 普 通 多 行 编 辑 框 , 还 要 附 加
ES_MULTILINE|ES_WANTRETURN|ES_AUTOVSCROLL |WS_HSCROLL| WS_VSCROLL
风格,这将创建一个可水平和垂直滚动的,带有水平和垂直滚动条的多行编辑器。
对于用对话框模板编辑器创建的编辑框控件,可以在控件的属性对话框中指定表 5…5 中
列出的控件风格。例如,在属性对话框中选择 Multi…line 项,相当于指定了 ES_MULTILINE
风格。对话框模板编辑器中设置编辑框控件属性的 Edit Properties 对话框如图 5…2 所示。
图 5…2 Edit Properties 对话框
5。2。2 Cedit 类的主要成员函数
文本编辑控件支持剪贴板操作,CEdit 类提供了一些与剪贴板有关的成员函数,如表 5…6
所示。
表 5…6 与剪贴板有关的 CEdit 成员函数
成员函数声明 用途
void Clear() 清除编辑框中被选择的正文
void Copy() 把在编辑框中选择的正文拷贝到剪贴板中
void Cut() 清除编辑框中被选择的正文并把这些正文拷贝到剪贴板中
void Paste() 将剪贴板中的正文插入到编辑框的当前插入符处
撤消上一次键入 。对于单行编辑框,该函数总返回 TRUE,对于多行编辑
BOOL Undo()
框,返回 TRUE 表明操作成功,否则返回 FALSE
可以用下列 CEdit 或 CWnd 类的成员函数来查询编辑框。在学习下面的函数时,读者会
经常遇到术语“字符索引”。字符的字符索引是指从编辑框的开头字符开始的字符编号,它是
从零开始编号的 。也就是说,字符索引实际上是指当把整个编辑正文看作一个字符串数组时,
·104 ·
…………………………………………………………Page 114……………………………………………………………
第 5 章 常用控件
该字符所在的数组元素的下标。
1.GetWindowText()函数
该成员函数声明方式如下:
int GetWindowText(LPTSTR lpszStringBuf; int nMaxCount) const;
void GetWindowText(CString& rString) const;
这两个函数均是 CWnd 类的成员函数,可用来获得窗口的标题或控件中的正文。第一种
声明方式用 lpszStringBuf 参数指向的字符串数组作为拷贝正文的缓冲区,参数 nMaxCount
用于获取拷贝到缓冲区中的最大字符数,该函数返回以字节为单位的实际拷贝字符数(不包
括结尾的空字节 )。第二种声明方式用一个 CString 对象作为缓冲区。
2 .GetWindowTextLength()函数
该成员函数声明方式如下:
int GetWindowTextLength() const;
CWnd 的成员函数,可用来获得窗口的标题或控件中的正文的长度。
3 .GetSel()函数
该成员函数声明按如下方式进行声明:
DWORD GetSel() const;
void GetSel(int& nStartChar;int& nEndChar) const;
两个函数都是 CEdit 的成员函数,用来获得所选正文的位置。第一种声明方式用于返回
一个 DWORD 值,其中低位字节说明了被选择的正文开始处的字符索引,高位字节说明了选
择的正文结束处的最后一个字符的字符索引,如果没有正文被选择,那么返回的低位和高位
字节都是当前插入符所在字符的字符索引。第二种声明方式中的两个参数是两个引用,其含
义与第一种声明方式的低位和高位字节相同。
4 .LineFromChar() 函数
该成员函数声明方式如下:
int LineFromChar(int nIndex = – 1) const;
CEdit 的成员函数,仅用于多行编辑框,用来返回指定字符索引所在行的行索引(从零
开始编号)。参数 nIndex 指定了一个字符索引,如果 nIndex 是…1,那么函数将返回选择正文
的第一个字符所在行的行号,若没有正文被选择,则该函数会返回当前的插入符所在行的行
号。
5 .LineIndex() 函数
该成员函数声明方式如下:
int LineIndex(int nLine = – 1) const;
CEdit 的成员函数,仅用于多行编辑框,用来获得指定行的开头字符的字符索引,如果
指定行超过了编辑框中的最大行数,该函数将返回…1 。参数 nLine 指定了从零开始的行索引,
·105 ·
…………………………………………………………Page 115……………………………………………………………
Visual C++ 6。0 程序设计从入门到精通
如果它的值为…1,则函数返回当前的插入符所在行的字符索引。
6 .GetLineCount()函数
该成员函数声明方式如下:
int GetLineCount() const;
CEdit 的成员函数,仅用于多行编辑框,用来获得正文的行数。如果编辑框是空的,那
么该函数的返回值是 1。
7 .LineLength() 函数
该成员函数声明方式如下:
int LineLength( int nLine = – 1 ) const;