当前位置:C++技术网 > 精选软件 > win32检测键盘的大小写状态并实时显示编辑的大小写状态

win32检测键盘的大小写状态并实时显示编辑的大小写状态

更新时间:2016-01-04 17:18:28浏览次数:1+次

    对于编辑的功能,我们在文章《win32直接在窗口中输入文字,将窗口当做编辑框》中已经分析实现了。实时提示编辑的键盘的字母大小写状态,其实也不难,我们本文就分析实现它。
    其实呢,键盘大小写的控制,并不需要我们来实现,键盘会自动切换。只要键盘检测到"CapsLock"即大小写切换按键按下,就会切换键盘上的字母的输入状态。这一点不需要我多讲。
    我们不好直接修改键盘的大小写状态,其实一点必要也没有,键盘自动完成,不需要我们完成。我们只需要检测即可,然后切换一下状态显示,让用户清楚的知道当前的输入的大小写状态即可。

    效果图如下:

实时提示用户当前键盘的大小写编辑状态

【实时提示用户当前键盘的大小写编辑状态】
    我们从图中可以看到,既有大写字母,也有小写字母,而我就是通过点击"CapsLock"按键来切换大小写的状态,切换时窗口就可以实时提示。
    窗口编辑文字的功能的代码没有改动,我就额外增加了WM_KEYDOWN消息。因为"CapsLock"按键并不会产生字符,它是控制键,所以需要处理按键消息。大小写状态切换按键的虚拟键为VK_CAPITAL,WM_KEYDOWN消息的wParam参数就存储着虚拟键码的值。所以将虚拟键码的值与VK_CAPITAL来比较就可以判断按下的按键是不是大小写切换按键了。然后我们创建一个静态的布尔变量,用来指示是否为大写状态,按下大小写切换按键,就将这个布尔变量的值取反即可。然后在WM_PAINT消息中,根据这个布尔变量即可知道大小写状态了,进而输出文字提示。
    这里额外提示下,我使用了右键单击消息来清除字符串的所有文字。然而我之前只将第一个元素置0,其他的没管。这样一来,当再输入一个字符后,原先的字符串就恢复了之前的所有内容,因为第一个空字符被替换成正常字符了。你就发现瞬间输入的字符串变长了。
    所以,要彻底清除字符串的内容,使用memset函数来实现即可。
    下面是完整的代码:
#include "windows.h"
#include <tchar.h>
TCHAR cjjjs[100]=_T("【C++技术网http:www.cjjjs.com】请直接输入文字");
TCHAR txt[1024]=_T("");
LRESULT CALLBACK WinProc(HWND hwnd,UINT message,WPARAM wParam,LPARAM lParam)
{
    HDC hdc;
    PAINTSTRUCT ps;
    static bool bIsCap=false;
    switch (message)
    {
    case WM_PAINT:
        hdc = BeginPaint(hwnd,&ps);
        SelectObject(hdc,GetStockObject(SYSTEM_FIXED_FONT));
        TextOut(hdc,0,100,cjjjs,lstrlen(cjjjs));
        TextOut(hdc,0,0,txt,lstrlen(txt));
        if (bIsCap)
        {
            TextOut(hdc,0,150,_T("当前状态:大写"),lstrlen(_T("当前状态:大写")));
        }
        else
        {
            TextOut(hdc,0,150,_T("当前状态:小写"),lstrlen(_T("当前状态:小写")));
        }
        
        EndPaint(hwnd,&ps);
        return 0;
     case WM_CHAR:
         {
             TCHAR ch=(TCHAR)wParam;            
             if (ch==8)
             {
                 int len=lstrlen(txt)-1;
                 txt[len]=_T('\0');
             }
             else
             {
                 txt[lstrlen(txt)]=ch;
             }
         }
        InvalidateRect(hwnd,NULL,TRUE);//刷新显示结果
        return 0;
     case WM_KEYDOWN:
         {
             if (VK_CAPITAL==wParam)
             {
                 bIsCap=!bIsCap;
             }
         }
         InvalidateRect(hwnd,NULL,TRUE);//刷新显示结果
         return 0;
     case WM_RBUTTONDOWN:
         {
             txt[0]=_T('\0');//只是填充开头一个元素为0,在输入一个之后,就会恢复之前的长度
             memset(txt,0,sizeof(txt));//这样才能将所有内存情况,真正清空字符串
             InvalidateRect(hwnd,NULL,TRUE);
         }
         return 0;
     case WM_DESTROY:
         PostQuitMessage(0);
         return 0;
     default:
         return DefWindowProc(hwnd, message, wParam, lParam);
    }
}

int WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrev,LPSTR lpCmd,int iShow)
{
    TCHAR ClassName[] = _T("MyClass");
    TCHAR title1[] = _T("C++技术网http://www.cjjjs.com");
    WNDCLASS wndClass;
    wndClass.cbClsExtra=0;
    wndClass.cbWndExtra=0;
    wndClass.hbrBackground= (HBRUSH)GetStockObject(WHITE_BRUSH);
    wndClass.hCursor=LoadCursor(NULL,IDC_HAND);
    wndClass.hIcon=LoadIcon(NULL,IDI_APPLICATION);
    wndClass.hInstance = hInstance;
    wndClass.lpfnWndProc = WinProc;
    wndClass.lpszClassName = ClassName;
    wndClass.lpszMenuName=NULL;
    wndClass.style=CS_HREDRAW|CS_VREDRAW;

    if(!RegisterClass(&wndClass))return 0;
    HWND hwnd = CreateWindow(ClassName,title1,WS_OVERLAPPEDWINDOW,0,0,650,400,NULL,NULL,hInstance,NULL);
    ShowWindow(hwnd,SW_SHOWNORMAL);

    MSG msg;
    while (GetMessage(&msg,NULL,0,0))
    {
        TranslateMessage(&msg);
        DispatchMessage(&msg);
    }
    return msg.wParam;
}