怎样向后台窗口发送键盘消息?VC
我用HWNDhNotPad;hNotPad=::FindWindow(NULL,"无标题-记事本");找到了窗口handle,然后改窗口发送消息::PostMessage...
我用
HWND hNotPad;
hNotPad=::FindWindow(NULL,"无标题 - 记事本");
找到了窗口handle,然后改窗口发送消息
::PostMessage(hNotPad,WM_CHAR,(WPARAM)'a',NULL);
::PostMessage(hNotPad,WM_KEYDOWN,(WPARAM)'a',NULL);
::PostMessage(hNotPad,WM_KEYUP,(WPARAM)'a',NULL);
因为我不知道哪种好使,所以3种一起发了,窗口都没有相应
我想保证接受消息的窗口一直在后台运行,需要怎么发消息啊
我查MSDN写的keybd_event实际就是产生一个WM_KEYUP或WM_KEYDOWN的消息,那keybd_event是不是就是::PostMessage(hNotPad,WM_KEYUP,wParam,lParam)?
1楼兄弟有俩问题。。你这个是.net吧?目标机器上还需要装.NET比较麻烦,而且我要发的消息是键盘消息,不是文本消息。你发的WM_SETTEXT能实现键盘操作吗?而且我也不需要找到焦点窗口的句柄。 展开
HWND hNotPad;
hNotPad=::FindWindow(NULL,"无标题 - 记事本");
找到了窗口handle,然后改窗口发送消息
::PostMessage(hNotPad,WM_CHAR,(WPARAM)'a',NULL);
::PostMessage(hNotPad,WM_KEYDOWN,(WPARAM)'a',NULL);
::PostMessage(hNotPad,WM_KEYUP,(WPARAM)'a',NULL);
因为我不知道哪种好使,所以3种一起发了,窗口都没有相应
我想保证接受消息的窗口一直在后台运行,需要怎么发消息啊
我查MSDN写的keybd_event实际就是产生一个WM_KEYUP或WM_KEYDOWN的消息,那keybd_event是不是就是::PostMessage(hNotPad,WM_KEYUP,wParam,lParam)?
1楼兄弟有俩问题。。你这个是.net吧?目标机器上还需要装.NET比较麻烦,而且我要发的消息是键盘消息,不是文本消息。你发的WM_SETTEXT能实现键盘操作吗?而且我也不需要找到焦点窗口的句柄。 展开
2个回答
展开全部
跟我以前犯的错误一样
你用sendmessage往记事本窗口发消息是没用的,因为Message消息是不会往子窗口(即记事本里面的文本框)传的
除非你改用command消息 或者用FindWindowEx找出记事本里面的文本框的句柄(或者用其它的,如getdlgitem也行),再发送消息
你用sendmessage往记事本窗口发消息是没用的,因为Message消息是不会往子窗口(即记事本里面的文本框)传的
除非你改用command消息 或者用FindWindowEx找出记事本里面的文本框的句柄(或者用其它的,如getdlgitem也行),再发送消息
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
SendMessage(hhh,WM_CHAR,'S',0);
::SendMessage(hhh,WM_CHAR,'S',0);
FindWindowEx找出Edit控件句柄,向其发送WM_CHAR。
貌似你可以试着遍历一下“文本文件”的所有控件,因为他是一个窗口,而是否你真正要输入的输入框你还不确定吧。。
FindWindowEx() 可支持子窗口的查找 再判断其注册类名看看。
给你个例子
[DllImport( "User32.DLL ")]
public static extern int SendMessage(IntPtr hWnd,
uint Msg, int wParam, string lParam);
[DllImport( "User32.DLL ")]
public static extern IntPtr FindWindowEx(IntPtr hwndParent,
IntPtr hwndChildAfter, string lpszClass, string lpszWindow);
public const uint WM_SETTEXT = 0x000C;
private void button1_Click(object sender, EventArgs e)
{
Process vProcess = Process.Start( "notepad.exe ");
while (vProcess.MainWindowHandle == IntPtr.Zero) vProcess.Refresh();
IntPtr vHandle = FindWindowEx(vProcess.MainWindowHandle,
IntPtr.Zero, "Edit ", null);
SendMessage(vHandle, WM_SETTEXT, 0, "Zswang 路过 ");
}
::SendMessage(hhh,WM_CHAR,'S',0);
FindWindowEx找出Edit控件句柄,向其发送WM_CHAR。
貌似你可以试着遍历一下“文本文件”的所有控件,因为他是一个窗口,而是否你真正要输入的输入框你还不确定吧。。
FindWindowEx() 可支持子窗口的查找 再判断其注册类名看看。
给你个例子
[DllImport( "User32.DLL ")]
public static extern int SendMessage(IntPtr hWnd,
uint Msg, int wParam, string lParam);
[DllImport( "User32.DLL ")]
public static extern IntPtr FindWindowEx(IntPtr hwndParent,
IntPtr hwndChildAfter, string lpszClass, string lpszWindow);
public const uint WM_SETTEXT = 0x000C;
private void button1_Click(object sender, EventArgs e)
{
Process vProcess = Process.Start( "notepad.exe ");
while (vProcess.MainWindowHandle == IntPtr.Zero) vProcess.Refresh();
IntPtr vHandle = FindWindowEx(vProcess.MainWindowHandle,
IntPtr.Zero, "Edit ", null);
SendMessage(vHandle, WM_SETTEXT, 0, "Zswang 路过 ");
}
参考资料: http://topic.csdn.net/u/20070921/15/4a9f99d3-362c-4ba4-9557-98acdb33f1ab.html
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询