MONO中文软件开发Win32高级编程 Using keyboard hooks in WinCE

1  /  1  页   1 跳转 查看:845

Using keyboard hooks in WinCE

Using keyboard hooks in WinCE

Using keyboard hooks in WinCE

http://www.codeproject.com/KB/mobile/wincekbhook.aspx

Introduction

The article shows how to use keyboard hooks in WinCE.
Background

I came across a problem where I had to remap certain special keys on my handheld for an existing dialog based application. The only solution I knew that would gracefully do this in WinCE was hooks. But MSDN states that hook APIs aren't supported in WinCE. But I found that they were present in coredll.lib. So, I thought of manually loading these APIs and using them. Initially, I did have some problems doing this, but a look into winuser.h in VC++, made the job a lot easier. Googling also helped me to some extent, but I don't remember the URLs now, my apologies to those whom I haven't given the credit.
Using the code

You just have to use two files winceKBhook.cpp and winceKBhook.h. The code has been commented thoroughly for easy understanding. You can use these files in either an EXE or a DLL.

The mechanism of using a hook would be to install it. This is done using the function ActivateKBHook() in winceKBhook.cpp. This function loads the necessary hook APIs and installs the keyboard hook. It is necessary to pass the handle of the application to be hooked and a low level keyboard procedure, which has to be defined by the user. All the keyboard events come to this procedure. Your code can then manage these events the way you want. The example shown below just remaps the keys. After you are done with using the hook you can unload it using DeActivateKBHook().
Collapse

//Install the KB hook by passing the

//handle of the application to be hooked

//and the address of the KB procedure

//which will handle all the KB events

if(!ActivateKBHook(hInstance, LLKeyboardHookCallbackFunction))
{
    MessageBox(GetActiveWindow(),
        TEXT("Couldn't intall hook...Terminating"),
        TEXT("Warning"), NULL);
    exit(1);
}

//LLKeyboardHookCallbackFunction is the funtion whose

//address we passed to the system while installing the hook.

//so all the KB events will bring the control to this procedure.

//Here we want that when the user presse left or

//right key it should be interpreted as an UP key

//so now you can allow the user to configure the

//key boards the way he/she wants it

LRESULT CALLBACK LLKeyboardHookCallbackFunction(
                  int nCode, WPARAM wParam, LPARAM lParam)
{
    if(((((KBDLLHOOKSTRUCT*)lParam)->vkCode) == VK_LEFT) ||
          ((((KBDLLHOOKSTRUCT*)lParam)->vkCode) == VK_RIGHT))
    {
        //Generate the keyboard press event of the mapped key

        keybd_event(VK_UP, 0, 0, 0);

        //release the mapped key

        keybd_event(VK_UP, 0, KEYEVENTF_KEYUP, 0);
    }

    //let default processing take place

    return CallNextHookEx(g_hInstalledLLKBDhook, nCode,
                                              wParam, lParam);
}

//we are done with the hook. now uninstall it.

DeactivateKBHook();

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here
About the Author
Prathamesh S Kulkarni

附件附件:

您所在的用户组无法下载或查看附件

Sinoprise Network Studio
        ----专注.NET技术
 

回复:Using keyboard hooks in WinCE

在编译时有错误,是因为找不到WINCEKBHOOK_API  的定义.

可以添加如下定义:

#define WINCEKBHOOK_API 

即可
Sinoprise Network Studio
        ----专注.NET技术
 
1  /  1  页   1 跳转

版权所有 Sinoprise Network Studio   Sitemap

Powered by Discuz!NT 2.0.1214    Copyright © 2001-2009 Comsenz Inc.
Processed in 0.0625 second(s) , 6 queries. 京ICP备05062328号
返顶部