VC中获取窗体句柄的各种方法

VC中获取窗体句柄的各种方法

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

 AfxGetMainWnd

AfxGetMainWnd获取自身窗体句柄

HWND hWnd = AfxGetMainWnd()->m_hWnd;

GetTopWindow

函数功能:该函数检查与特定父窗体相联的子窗体z序(Z序:垂直屏幕的方向,即叠放次序),并返回在z序顶部的子窗体的句柄。

函数原型:HWND GetTopWindow(HWND hWnd);

參数:

  hWnd:被查序的父窗体的句柄。假设该參数为NULL,函数返回Z序顶部的窗体句柄。

返回值:

    假设函数成功,返回值为在Z序顶部的子窗体句柄。假设指定的窗体无子窗体,返回值为NULL。

GetForegroundWindow

函数功能:该函数返回当前系统的前台窗体的窗体句柄。

函数原型:HWND GetForegroundWindow(VOID)  

返回值:函数返回前台窗回的句柄。

GetActiveWindow

函数功能:该函数能够获得与调用该方法的线程的消息队列相关的活动窗体的窗体句柄(就是取得当前进程的活动窗体的窗体句柄)。

函数原型:HWND GetActiveWindow(VOID)

返回值:返回值是与调用线程的消息队列相关的活动窗体的句柄。否则,返回值为NULL。

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

IsWindowVisible

函数功能:该函数获得给定窗体的可视状态。

函数原型:BOOL IsWindowVisible(HWND hWnd);

參数;

  hWnd:被測试窗体的句柄。

返回值:

    假设指定的窗体及其父窗体具有WS_VISIBLE风格,返回值为非零;假设指定的窗体及其父窗体不具有WS_VISIBLE风格,返回值为零。因为返回值表明了窗体是否具有Ws_VISIBLE风格,因此,即使该窗体被其它窗体遮盖,函数返回值也为非零。

备注:

    窗体的可视状态由WS_VISIBLE位指示。当设置了WS_VISIBLE位,窗体就可显示,并且仅仅要窗体具有WS_VISIBLE风格,不论什么画在窗体的信息都将被显示。

IsWindow:

函数功能:该函数确定给定的窗体句柄是否标示一个已存在的窗体。 

函数原型:BOOL IsWindow(HWND hWnd);

參数:

    hWnd:被測试窗体的句柄。

返回值:

    假设窗体句柄标识了一个已存在的窗体,返回值为TURE;假设窗体句柄未标识一个已存在窗体,返回值为FALSE。

FindWindow:

HWND FindWindow(LPCSTR lpClassName,LPCSTR lpWindowName );

參数:

lpClassName

  指向一个以null结尾的、用来指定类名的字符串或一个能够确定类名字符串的原子。假设这个參数是一个原子,那么它必须是一个在调用此函数前已经通过GlobalAddAtom函数创建好的全局原子。这个原子(一个16bit的值),必须被放置在lpClassName的低位字节中,lpClassName的高位字节置零。

lpWindowName

  指向一个以null结尾的、用来指定窗体名(即窗体标题)的字符串。假设此參数为NULL,则匹配全部窗体名。

返回值:

假设函数运行成功,则返回值是拥有指定窗体类名或窗体名的窗体的句柄。

  假设函数运行失败,则返回值为 NULL 。能够通过调用GetLastError函数获得更加具体的错误信息。

SetWindowText:

至于窗体标题的改变,我们能够通过SetWindowText来实现

注:假设窗体本身属性是不显示标题的,这个函数的调用不会影响窗体属性。

//Set title for application’s main frame window .

AfxGetMainWnd ( ) -> SetWindowText (_T(“Application title”) )

//Set title for View’s MDI child frame window .

GetParentFrame ( ) -> SetWindowText (“_T (“MDI Child Frame new title”) )

//Set title for dialog’s push button control.

GetDigitem (IDC_BUTTON) -> SetWindowText (_T (“Button new title “) )

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118655.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • IDEA优化设置

    IDEA优化设置IDEA优化设置设置Ctrl+鼠标滑轮动态放大缩小页面文字

  • 向量与矩阵范数_矩阵范数与谱半径的关系

    向量与矩阵范数_矩阵范数与谱半径的关系范数(norm),是具有“长度”概念的函数。在线性代数、泛函分析及相关的数学领域,范函是一个函数,其为矢量空间内的所有矢量赋予非零的正长度或大小。半范数反而可以为非零的矢量赋予零长度。举一个简单的例子,在二维的欧氏几何空间R就可定义欧氏范数。在这个矢量空间中的元素常常在笛卡儿坐标系统中被画成一个从原点出发的带有箭头的有向线段。每一个矢量的欧氏范数就是有向线段的长度。其中定义范数的矢量空间就是赋范矢

  • 卡巴斯基升级_卡巴斯基免费版和收费版的区别

    卡巴斯基升级_卡巴斯基免费版和收费版的区别http://hi.baidu.com/sxcxq1128/blog/item/1918d0ef30523c232df534c1.html  卡巴斯基2010授权文件如何安装使用激活卡巴斯基2010版授权文件安装方法比以前的版本有些不同,请仔细看以下教程免得有了key也不会使用^_^第一步:打开卡巴斯基授权许可激活页点击左下角的“授权许可”上图

  • 【转载】企业服务总线Enterprise service bus介绍

    【转载】企业服务总线Enterprise service bus介绍

    2021年11月18日
  • python中unittest框架_unittest框架原理

    python中unittest框架_unittest框架原理unittest简介参考:https://urlify.cn/e6rAr2为什么要使用unittest在编写接口自动化用例时,我们一般针对一个接口建立一个.py文件,一条测试用例封装为一个函数(方法),但是在批量执行的过程中,如果其中一条出错,后面的用例就无法执行。使用测试框架可以互不影响的用例执行及更灵活的执行控制。unittest特点 •python自带的单元测试框架,无需安装; •用例执行互不干扰; •提供不同范围的setUp(测试准备)和t..

    2022年10月10日
  • java tess4j训练库_Java 验证码识别库 Tess4j 学习

    java tess4j训练库_Java 验证码识别库 Tess4j 学习Java验证码识别库Tess4j学习【在用java的Jsoup做爬虫爬取数据时遇到了验证码识别的问题(基于maven),找了网上挺多的资料,发现Tess4j可以自动识别验证码,在这里简单记录下学习过程及遇到的一些问题。】步骤:需要在步骤一的tessdata文件中加入相关语言包(训练文件),在这里下载:https://github.com/tesseract-ocr/tessdata,如果是简…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号