
[DllImport("user32", EntryPoint = "GetWindowThreadProcessId")]
private static extern int GetWindowThreadProcessId(IntPtr hwnd, out int pid)
获得进程ID。
句柄获取方法(获取该窗口的句柄后,即可向该窗口类类发送消息、处理程序):0。获取所在类窗口的句柄:this->m_hwnd
1。主窗口的句柄:
无论在主窗口类内,还是子窗口类内,获取主窗口句柄的方法:
afxgetmainwnd()->m_hwnd,
如:::sendmessage(afxgetmainwnd()->m_hwnd , wm_my_dosome , 0 ,(lparam)i)
在窗口类中
this->m_hwnd
或者this->getsafehwnd()
2。子窗口句柄:用findwindow,(只要知道子窗口的名字即可)如:
::findwindow(null,windowsname)
返回找到的窗口的句柄
寻找当前窗口是否在运行windowname的程序,该名字为窗口名字,如:
cwnd* pwnd=findwindow(null,_t("清芝--支票机"))//
getsafehwnd
函数功能:获取带明某个窗口对象(cwnd的派生对象)指针的句柄(hwnd)时,最安全的方法是使用getsafehwnd()函数。
通过下面的例子来看其理由蠢和告:
cwnd *pwnd = findwindow(“explorewclass”,null)//希望找到资源管理器
hwnd hwnd = pwnd->m_hwnd//得到它的hwnd
这样的代码当开始得到的pwnd为空的时候就会出现一个“general protection error”,并关闭应用程序,因为一般不能对一个null指针访问其成员,如果用下面的代码:
cwnd *pwnd = findwindow(“explorewclass”,null)//希望找到资源管理器
hwnd hwnd = pwnd->getsafehwnd()//得到它的hwnd
就不会出现问题,因为尽管当pwnd是null时,getsafehwnd仍然可以用,只是返回null
3。获取窗口中 控件的句柄,用 getdlgitem
语法为:getdlgitem(idc_combo3)->m_hwnd :参数为 该控件的id,返回值为:cwnd* 类型,但它是cwnd类内的函数,因此要先获取控件所在窗口的指棚升针,如:
cstring str(_t("dd"))
::sendmessage(afxgetmainwnd()->getdlgitem(idc_combo3)->m_hwnd, wm_settext , 0 , (lparam)str.getbuffer(0))
从句柄获得指针,用 fromhandle
语法:cwnd* pwnd = cwnd::fromhandle(hwnd)
获取窗口句柄(全集) vc&mfc
获得窗口句柄:
this->m_hwnd
hwnd getforegroundwindow(void)
getsafehwnd 取你程序所在窗口类的句柄
getactivewindow 取当前活动窗口句柄
afxgetmainwnd 取主窗口句柄
getforegroundwindow 取前台窗口句柄
findwindow
enumwindow
照你的程序来看,ReadTime是全局函数,所以要获取主窗口句柄应该:
h_d
=
AfxGetMainWnd()->GetSafeHwnd()
::SetWindowText(::GetDlgItem(h_d,
IDC_STATIC),
str)
顺便说一句,IDC_STATIC很多static
control都是用的这个ID,建议改一下。
这一句还是错的:GetDlgItem(IDC_STATIC)->SetWindowText(str)
因为凯启运全局旁凯函数GetDlgItem不仅需要两个参盯梁数,而且返回值是HWND,是不能调用的。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)