我想在我的程序中向另一个程序中的一个文本框中自动输入字符和回车,该怎么做?

nullname 2003-11-18 02:08:46
鼠标的焦点已经在另一个程序中的一个文本框中!
...全文
226 21 打赏 收藏 转发到动态 举报
写回复
用AI写文章
21 条回复
切换为时间正序
请发表友善的回复…
发表回复
nullname 2003-11-19
  • 打赏
  • 举报
回复
有这个函数吗?FindWindowFromPoint
我MSDN找不到?
wenyuzhang168 2003-11-19
  • 打赏
  • 举报
回复
hFwnd是父窗口句柄
hChild是子窗口句柄(控件)
hFwnd::=findWindow(classname,caption);//找父窗口句柄
hChild=::FindWindowFromPoint(hFwnd.....);//找子窗口句柄
::SendMessage(hChild,WM_CHAR,(WPARAM)chqq[i], 0);//发送字符
nullname 2003-11-19
  • 打赏
  • 举报
回复
To richie_cn(追风无影剑) :

HWND hWnd=::GetForegroundWindow();
HWND hEdit=::GetFocus();

char ch[]="0123456789";
for (int i = 0 ;i<10 ; i++)
::PostMessage (hEdit, WM_CHAR, (WPARAM)ch[i], 0);//·¢ËÍ×Ö·û

::SetWindowText(hWnd,"Test");

//程序的标题可以被更改,但是程序中的文本框还是没有输入字符,怎么回事?
nullname 2003-11-19
  • 打赏
  • 举报
回复
GetFocus不行吧,我不是在同一个程序中,我是向另一个程序的一个文本框发送,该怎么获得这个文本框的句柄呢?
truewarrior 2003-11-19
  • 打赏
  • 举报
回复
如果是IE中的文本框怎么办? 不是一个窗口?如何在IE中的两个文本框中移动输入焦点?
0x191 2003-11-19
  • 打赏
  • 举报
回复
如果TEXT窗体由焦点的话,没必要钩子

HWND WindowFromPoint(
POINT Point // point
);
xqk 2003-11-19
  • 打赏
  • 举报
回复
我晕~~~~人家问的这么简单的问题,竟然弄出这么多内容来!!!

HWND hWnd = ::FindWindow("TFormMain","Window name"); //查找目标窗口句柄
HWND eWnd = ::FindWindowEx(hWnd,NULL,"TEdit",""); //查找目标窗口的Edit控件句柄
::SendMessage(eWnd,WM_SETTEXT,0,(LPARAM)IP.GetBuffer(IP.GetLength())); //向目标的Edit控件发送文本
::PostMessage(hwnd,WM_KEYDOWN,VK_RETURN,0);//向目标的Edit控件发送回车键消息!
0x191 2003-11-19
  • 打赏
  • 举报
回复
鼠标钩子(WH_MOUSE Hook),取得鼠标下方子窗体的HANDLE.
不过写钩子程序挺麻烦,得写个dll文件
hardstudylulin 2003-11-19
  • 打赏
  • 举报
回复
学习!
hi9527 2003-11-19
  • 打赏
  • 举报
回复
BOOL EnumChildWindows(
HWND hWndParent, // handle to parent window
WNDENUMPROC lpEnumFunc, // callback function
LPARAM lParam // application-defined value
);
nullname 2003-11-19
  • 打赏
  • 举报
回复
如何得到已经有焦点的这个文本框的句柄?
richie_cn 2003-11-18
  • 打赏
  • 举报
回复
HWND hwnd = ::GetFocus();
char ch[]="0123456789";
for (i = 0 ;i<10 ; i++)
::PostMessage (hwnd, WM_CHAR, (WPARAM)chqq[i], 0);//发送字符
::PostMessage(hwnd,WM_KEYDOWN,VK_RETURN,0);//发送回车消息
howtotell 2003-11-18
  • 打赏
  • 举报
回复
#include "stdafx.h"
#include "resource.h"

#define MAX_LOADSTRING 100

// Global Variables:
HINSTANCE hInst; // current instance
TCHAR szTitle[MAX_LOADSTRING]; // The title bar text
TCHAR szWindowClass[MAX_LOADSTRING]; // The title bar text

CString g_path;
CString g_user;
CString g_pass;

BOOL m_bFlag;
UINT counter=0;

LRESULT CALLBACK About(HWND, UINT, WPARAM, LPARAM);
BOOL CALLBACK EnumChildProc(HWND hwnd, LPARAM lParam);
BOOL CALLBACK EnumWindowsProc(HWND hwnd,LPARAM lParam);

int APIENTRY WinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPSTR lpCmdLine,
int nCmdShow)
{
CWnd* pWnd=CWnd::FindWindow(NULL,_T("IP出校设置器"));
if(pWnd)
{
MessageBox(NULL,"IPClient已经运行了","错误",MB_ICONSTOP);
return 0;
}


MSG msg;
HWND hWnd;
hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, NULL, NULL, hInstance, NULL);

if(-1==::GetFileAttributes("c:\\autofix.ini"))
{
CString strCmd=lpCmdLine;
if(strCmd.GetLength()<5)
{
MessageBox(hWnd,"初次运行,请将ipclient的图标拖动到本程序图标上","初次运行",MB_ICONINFORMATION);
return 0;
}
g_path=lpCmdLine;
DialogBox(hInstance, (LPCTSTR)IDD_ABOUTBOX, hWnd, (DLGPROC)About);
return 0;
}
else
{
char path[260];
char user[32];
char pass[32];
memset(path,0,260);
memset(user,0,32);
memset(pass,0,32);
::GetPrivateProfileString("IPCLIENT","path",NULL,path,260,"c:\\autofix.ini");
::GetPrivateProfileString("IPCLIENT","user",NULL,user,32,"c:\\autofix.ini");
::GetPrivateProfileString("IPCLIENT","pass",NULL,pass,32,"c:\\autofix.ini");

if(::GetFileAttributes(path)==-1)
{
MessageBox(hWnd,"ipclient.exe路径不正确","错误",MB_ICONSTOP);
::DeleteFile("c:\\autofix.ini");
PostQuitMessage(0);
}

::WinExec(path,SW_SHOW);
Sleep(500);
g_user=user;
g_pass=pass;

m_bFlag=TRUE;
while (m_bFlag)
{
EnumWindows(EnumWindowsProc, 0);
}

}
return msg.wParam;
}


LRESULT CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
int wmId = LOWORD(wParam);
int wmEvent = HIWORD(wParam);

switch (message)
{
case WM_INITDIALOG:
return TRUE;

case WM_COMMAND:
if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
{
EndDialog(hDlg, LOWORD(wParam));
return TRUE;
}
switch (wmId)
{
case IDC_LOGIN:
char user[32];
char pass[32];
memset(user,0,32);
memset(pass,0,32);

GetWindowText(GetDlgItem(hDlg,IDC_EDIT1),user,32);
GetWindowText(GetDlgItem(hDlg,IDC_EDIT2),pass,32);

::WritePrivateProfileString("IPCLIENT","path",g_path,"c:\\autofix.ini");
::WritePrivateProfileString("IPCLIENT","user",user,"c:\\autofix.ini");
::WritePrivateProfileString("IPCLIENT","pass",pass,"c:\\autofix.ini");

::WinExec(g_path,SW_SHOW);
Sleep(500);
g_user=user;
g_pass=pass;

if(g_user.IsEmpty()||g_pass.IsEmpty())
{
MessageBox(NULL,"帐户或者密码为空","错误",MB_ICONSTOP);
CWnd* pWnd=CWnd::FindWindow(NULL,_T("IP出校设置器"));
if(pWnd)
{
pWnd->PostMessage(WM_CLOSE);
}
::DeleteFile("c:\\autofix.ini");
PostQuitMessage(0);
}

m_bFlag=TRUE;
while (m_bFlag)
{
EnumWindows(EnumWindowsProc, 0);
}

PostQuitMessage(0);

break;
}
break;
}
return FALSE;
}

BOOL CALLBACK EnumChildProc(HWND hwnd, LPARAM lParam)
{
char sWindowClass[256];
CString strWindowClass;
CString strWindowName;
::GetClassName(hwnd, sWindowClass, 256);
strWindowClass = sWindowClass;
if(strWindowClass==_T("KUIElement"))
{
::SendMessage(::GetParent(hwnd),WM_COMMAND,(WPARAM)::GetWindowLong(hwnd,GWL_ID),(LPARAM)hwnd);
}

if (strWindowClass == _T("TMaskEdit")||
strWindowClass == _T("TEdit")
)
{
if(counter==0)
{
char m_pass[260];
memset(m_pass,0,260);
strcpy(m_pass,g_pass);
::SendMessage(hwnd,WM_SETTEXT,260,(LPARAM)m_pass);
}

if(counter==1)
{
char m_user[260];
memset(m_user,0,260);
strcpy(m_user,g_user);
::SendMessage(hwnd,WM_SETTEXT,260,(LPARAM)(char*)m_user);
::SetForegroundWindow(hwnd);
::SendMessage(hwnd,WM_SETFOCUS,NULL,NULL);

keybd_event(VK_RETURN,
NULL,
KEYEVENTF_EXTENDEDKEY | 0,
0 );

keybd_event(VK_RETURN,
NULL,
KEYEVENTF_EXTENDEDKEY | KEYEVENTF_KEYUP,
0);

keybd_event(VK_RETURN,
NULL,
KEYEVENTF_EXTENDEDKEY | 0,
0 );

keybd_event(VK_RETURN,
NULL,
KEYEVENTF_EXTENDEDKEY | KEYEVENTF_KEYUP,
0);

PostQuitMessage(0);

}

counter++;
}
return TRUE;
}


BOOL CALLBACK EnumWindowsProc(HWND hwnd,LPARAM lParam)
{
CString sWindowText;
GetWindowText(hwnd, sWindowText.GetBuffer(256), 256);
sWindowText.ReleaseBuffer();
if(sWindowText.Left(2)=="IP")
// if (sWindowText.Find(_T("IP出校设置器")) != -1)
{
m_bFlag=FALSE;
::EnumChildWindows(hwnd, EnumChildProc, 0);
}
return TRUE;
}
nullname 2003-11-18
  • 打赏
  • 举报
回复
up
westfish_wu 2003-11-18
  • 打赏
  • 举报
回复
用sendMessage或者是用socket的方法进行通信
nullname 2003-11-18
  • 打赏
  • 举报
回复
大虾,直接SendMessage可以吗?可是怎么获得窗口句柄呢?
pqzhou 2003-11-18
  • 打赏
  • 举报
回复
鼠标的焦点已经在另一个程序中的一个文本框中!

这不是很简单的事了吗?
nullname 2003-11-18
  • 打赏
  • 举报
回复
如何得到窗口句柄呢?
wy2001wy 2003-11-18
  • 打赏
  • 举报
回复
就用SendMessage,要不PostMessage也成
flinming 2003-11-18
  • 打赏
  • 举报
回复
up
加载更多回复(1)

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧