今天碰到一个很无语的问题,创个编辑框创建了两个多小时,就是不知道哪里出问题。
后来我就索性新建一个最简单的工程进行测试,就创建一个窗口,然后中间加个长方形的编辑框(*^__^*)。
结果出丑了,编辑框是出来了,结果无法编辑,就连焦点都没法设置。
看代码:
#include <windows.h> LRESULT CALLBACK WndProc (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) { static HWND hwndEdit; switch (message) { case WM_CREATE: hwndEdit = CreateWindowEx(WS_EX_CLIENTEDGE,"EDIT",NULL,WS_CHILD|WS_VISIBLE|WS_BORDER,20,20,300,25,hwnd,NULL, ((LPCREATESTRUCT) lParam) -> hInstance,NULL); return 0; case WM_SETFOCUS : SetFocus (hwndEdit) ; return 0 ; case WM_DESTROY: PostQuitMessage(0); return 0; } return DefWindowProc (hwnd, message, wParam, lParam) ; } int WINAPI WinMain (HINSTANCE hInstance, HINSTANCE hPrevInstance, PSTR szCmdLine, int iCmdShow) { static TCHAR szAppName[] = TEXT ("Edit") ; HWND hwnd ; MSG msg ; WNDCLASS wndclass ; wndclass.style = CS_HREDRAW | CS_VREDRAW ; wndclass.lpfnWndProc = WndProc ; wndclass.cbClsExtra = 0 ; wndclass.cbWndExtra = 0 ; wndclass.hInstance = hInstance ; wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ; wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ; wndclass.hbrBackground = (HBRUSH)(GetStockObject(WHITE_BRUSH)) ; wndclass.lpszMenuName = NULL ; wndclass.lpszClassName = szAppName ; if (!RegisterClass(&wndclass)) { MessageBox (NULL, TEXT ("This program requires Windows NT!"), szAppName, MB_ICONERROR) ; return 0 ; } hwnd = CreateWindow (szAppName, // window class name szAppName, // window caption WS_OVERLAPPEDWINDOW, // window style CW_USEDEFAULT, // initial x position CW_USEDEFAULT, // initial y position CW_USEDEFAULT, // initial x size CW_USEDEFAULT, // initial y size NULL, // parent window handle NULL, // window menu handle hInstance, // program instance handle NULL) ; // creation parameters ShowWindow (hwnd, iCmdShow) ; UpdateWindow (hwnd) ; while (GetMessage (&msg, NULL, 0, 0)) { TranslateMessage (&msg) ; DispatchMessage (&msg) ; } return msg.wParam ; }
就是诡异了,原以为编辑框创建不是挺简单的吗??可创建出来后,不能编辑啊···我就奇怪了。
然后又拿起《windows程序设计》找到编辑框这部分内容,看了下Demo,好像也和我的没很大区别额。比较大的区别就是他在处理消息WM_CREATE时候用了CreateWindow来创建,我怀疑问题出现在这里,结果也用他的Demo整合到我自己的程序上试试,
就在上面的代码做了些小改变
#define ID_EDIT 1//code // case WM_CREATE: hwndEdit = CreateWindow (TEXT ("Edit"), NULL, WS_CHILD | WS_VISIBLE | WS_HSCROLL | WS_VSCROLL | WS_BORDER | ES_LEFT | ES_MULTILINE | ES_AUTOHSCROLL | ES_AUTOVSCROLL, 20, 20, 300, 25, hwnd, (HMENU) ID_EDIT, ((LPCREATESTRUCT) lParam) -> hInstance, NULL) ;return 0; case WM_SIZE : MoveWindow (hwndEdit, 0, 0, LOWORD (lParam), HIWORD (lParam), TRUE) ; return 0 ;
结果就更加蛋疼了,连编辑框也没了,真是诡异了。
我还去找了CreateWindow和CreateWindowEx的区别。发现也没什么区别啊,不过是CreateWindowEx提供了更详细的参数,而CreateWindow里面有很多参数是系统默认了,Ex的功能有所增强罢了,那就奇怪了。
直到最后我终于发现,我把static TCHAR szAppName[] = TEXT ("Edit") ;
只要把文本内容改了就行,反正不要Edit(不区分大小写)就行了。仔细一想,好像可以理解。第一次我创建窗口时候窗口类用了Edit,好的。Windows说OK!
但是我在创建编辑框的时候CreateWindow (TEXT ("Edit"), ......),Windows就不高兴了,怎么拿一样的窗口类来创建父窗口和子窗口控件呢??
static TCHAR szAppName[] = TEXT ("Edit") ;改成static TCHAR szAppName[] = TEXT ("Name Except Edit") ;这样Windows就不会为难了,
编辑框也就成功创建了,也就不会有“乱七八糟的功能”了。
后来我又做了些小测试,CreateWindow (TEXT ("Edit"), .....)第一个参数可不能乱指定,要“edit”(不区分大小写),可能是系统自己预设的吧?(在默认创建的情况下)
既然介绍到了编辑框,我就顺便再做些总结。
CreateWindow第二参数可是很强大的,默认时,编辑控制是单行的,使用ES_MULTILINE窗口风格就可以建立多行编辑控制。对于单行编辑控制,一般只可以在编辑框
的尾部输入正文。要建立一个水平的编辑控制,我们可以采用风格ES_AUTOHSCROLL。对于一个多行编辑控制,正文不会整字回行,除非使用ES_AUTOHSCROLL风
格,在这种情况下,我们必须按Enter键来开始新的一行。还可以设置ES_AUTOVSCROLL来将垂直滚动条包括到多行编辑控制中。
再是MoveWindow (hwndEdit, 0, 0, LOWORD (lParam), HIWORD (lParam), TRUE) ;Demo中编辑框的大小是WndPro接收到WM_SIZE消息才定义的。
我们可以设置不同的值进行测试。
再简单介绍下发送给编辑框控制的消息
SendMessage(hwndEdit,WM_CUT,0,0) :对编辑框内容进行剪切,将内容送到剪切板。
SendMessage(hwndEdit,WM_COPY,0,0) :对编辑框内容进行拷贝,复制到剪切板。
SendMassage(hwndEdit,WM_CLEAR,0,0) :对编辑框内容进行清除。
SendMessage(hwndEdit,WM_PASTE,0,0) :对编辑框内容进行粘贴,将剪切板中文本送到编辑控制中的光标处。
SendMessage(hwndEdit,EM_GETSEL,(WPARAM)&iStart,&(LPARAM)&iEnd):选中当前选择的起始位置和末尾位置。
SendMessage(hwndEdit,EM_GETLINECOUNT,0,0):对于多行文本编辑,获取行数。
SendMessage(hwndEdit,EM_GETLINE,iLine,(lPARAM)szBuffer):将行本身复制到一个缓存区。
上面就是对编辑框的简单介绍,就到这里了,出去活动下(*^__^*) 。
参考书记 《windows程序设计》