GetStyle,ModifyStyle,GetExStyle,ModifyStyleEx「建议收藏」

GetStyle,ModifyStyle,GetExStyle,ModifyStyleEx「建议收藏」要添加或除去窗口的普通风格,可以使用GetStyle()和ModifyStyle()方法来实现要设置或去除窗口的扩展风格,可以使用GetExStyle()和ModifyStyleEx()方法实现1.CWnd::GetExStyle与CWnd::ModifyStyle(1)GetExStyle原型: DWORDGetStyle()const;作用: 获取

大家好,又见面了,我是你们的朋友全栈君。

要添加或除去窗口的普通风格,可以使用GetStyle()和ModifyStyle()方法来实现
要设置或去除窗口的扩展风格,可以使用GetExStyle()和ModifyStyleEx() 方法实现


1. CWnd::GetExStyle 与 CWnd::ModifyStyle

(1) GetExStyle
原型:  DWORD GetStyle() const;
作用:  获取窗口风格参数
返回:  返回当前窗口风格
例如:
DWORD dwStyle = GetStyle();

::SetWindowLong(GetSafeHwnd(), GWL_STYLE, dwStyle | SS_NOTIFY);

(2) ModifyStyle
原型:  
BOOL ModifyStyle
(
DWORD dwRemove,        //指定修改时要删除的窗风格
DWORD dwAdd,                //指定修改时将要增加的窗口风格
UINT nFlags=0                  //该参数将被传给SetWindowPos,否则为0,如果SetWindowPos不被调用的话,一般该参数默认值
);
BOOL ModifyStyleEx(
   DWORD dwRemove,     //指定扩展了样式修改时要移除的样式
   DWORD dwAdd,             //指定扩展了样式修改时要添加的样式
   UINT nFlags = 0              //标志将于 SetWindowPos或零,如果 SetWindowPos 不应调用。 默认值为零
);

作用:  修改窗口的风格
返回:  如果该函数成功调用返回一个非0值,否则返回0;
备注:  如果nFlags不为0,ModifyStyle将调用SetWindowPos并且结合nFlags和以下四个预先布置好的标志重画该窗口:
       SWP_NOSIZE             保持当前大小
       SWP_NOMOVE           保持当前位置.
       SWP_NOZORDER     保持当前的Z次序
       SWP_NOACTIVATE    不激活该窗口

2.  CWnd::GetExStyle CWnd::ModifyStyleEx

用于改窗口的扩展风格,声明与上同

C++中一些实例:
ModifyStyle(WS_CAPTION, 0, 0);                       //去除标题栏
ModifyStyle(WS_MAXIMIZEBOX, 0, 0);               //去最大化按钮
ModifyStyle(0, WS_THICKFRAME, 0);               //添加 WS_THICKFRAME风格
ModifyStyle(0, WS_EX_TOOLWINDOW, 0);      //设置工具栏窗口风格
ModifyStyleEx(0, WS_EX_ACCEPTFILES, 0);  //设置Accept files 属性

//隐藏任务栏图标
ModifyStyleEx(WS_EX_APPWINDOW, WS_EX_TOOLWINDOW);

3. GetWindowLong 与 SetWindowLong

原型:LONGGetWindowLong(HWNDhWnd, intnlndex);

作用:获得指定窗口的有关信息

原型:LONGSetWindowLong(HWND hWnd,int nlndex,LONG dwNewLong);

作用:用来改变指定窗口的属性

例如:

//去边框(包括标题栏)
void CWebBrushDlg::RemoveBorder()
{
	DWORD dwStyle = GetStyle();
	DWORD dwNewStyle = WS_OVERLAPPED | WS_VISIBLE | WS_SYSMENU | WS_MINIMIZEBOX | WS_MAXIMIZEBOX | WS_CLIPCHILDREN | WS_CLIPSIBLINGS;
	dwNewStyle &= dwStyle;
	SetWindowLong(m_hWnd, GWL_STYLE, dwNewStyle);

	DWORD dwExStyle = GetExStyle();
	DWORD dwNewExStyle = WS_EX_LEFT | WS_EX_LTRREADING | WS_EX_RIGHTSCROLLBAR;
	dwNewExStyle &= dwExStyle;
	SetWindowLong(m_hWnd, GWL_EXSTYLE, dwNewExStyle);
}

4. 列表视图的GetExStyle()和GetExtendedStyle()区别:
GetExStyle是CWnd类函数,得到的是CWnd窗口通用的扩展属性。
GetExtendedStyle是CListCtrl的成员函数,得到的是CListCtrl的扩展属性。

5. 设置ListCtrl属性

//加载ListCtrl
LONG lStyle;
lStyle = GetWindowLong(m_TaskList.m_hWnd, GWL_STYLE); //获取当前窗口Style
lStyle &= ~LVS_TYPEMASK; //清除显示方式
lStyle |= LVS_REPORT | LVSIL_SMALL | LVS_ALIGNTOP | LVS_SHOWSELALWAYS; //设置Style
SetWindowLong(m_TaskList.m_hWnd, GWL_STYLE, lStyle);

DWORD dwStyle = m_TaskList.GetExtendedStyle();
dwStyle |= LVS_EX_FULLROWSELECT; //选中某行使整行高亮(只适用与report风格的listctrl)
dwStyle |= LVS_EX_SUBITEMIMAGES; //subitem添加图标
m_TaskList.SetExtendedStyle(dwStyle);

6. CListCtrl扩展风格设置方法SetExtendedStyle和ModifyStyleEx比较

对于初学者来说,当他需要设定listctrl的扩展风格时,常常想到用ModifyStyleEx 来设定,代码如下:

ModifyStyleEx(0,LVS_EX_GRIDLINES)  

这是不正确的,正确的设定应该是:

SetExtendedStyle(LVS_EX_GRIDLINES)

那么,ModifyStyleEx和SetExtendedStyle区别在哪里?
实际上,ModifyStyleEx只是对窗口的GWL_EXSTYLE属性作设定,也即只是对窗口的常规扩展属性作设定,这种属性以WS_EX_作为前缀,比如WS_EX_CLIENTEDGE,
在listctrl 控件中,它的扩展风格的值并没有存入窗口的GWL_EXSTYLE属性值中,而是通过发送LVM_SETEXTENDLISTVIEWSTYLE消息给listctrl控件来实现,因此它就不能通过ModifyStyleEx做设定。

比较起ModifyStyle,该API即可设定普通窗口的风格,比如WS_CHILD,WS_VISIBLE。也可.设定控件的普通风格,对listctrl,就有LVS_REPORT,LVS_OWNERDRAWFIXED等等,这就是为什么在创建子控件时我们可以把WS_CHILD,WS_VISIBLE结合在一起传递的控件的create函数的原因:

m_list.Create(WS_CHILD|WS_VISIBLE|LVS_REPORT,CRect(0,0,100,100),this,0);  

但对于扩展风格却不能这么做:

m_list.CreateEx(WS_EX_CLIENTEDGE|LVS_EX_GRIDLINES,"LISTCTRL","",WS_CHILD|WS_VISIBLE,CRect(0,0,100,100),this,0); 

为什么微软没有把控件的扩展风格储存在GWL_EXSTYLE属性中,因为这个属性值为32位长的DWORD型,窗口的常规扩展属性即以WS_EX_作为前缀的属性,已经把它占完了,所以对listctrl 的扩展风格,微软只能把它放在其他地方了。

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161683.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 以《简单易懂》的语言带你搞懂有监督学习算法【附Python代码详解】机器学习系列之KNN篇[通俗易懂]

    以《简单易懂》的语言带你搞懂有监督学习算法【附Python代码详解】机器学习系列之KNN篇[通俗易懂]机器学习系列往期回顾❤️开始学习机器学习之前你必须要了解的知识有哪些?机器学习系列入门篇在上篇文章中,我们介绍了机器学习的一些理论知识,包括什么是监督学习、无监督学习、过拟合欠拟合等等,那在本篇文章中,我们会以KNN来正式介绍什么是有监督学习,让大家在了解KNN的同时完全掌握什么是有监督学习,以帮助大家更好的理解机器学习。注:本篇文章非常详细,附带简单易懂的文字说明和实现代码,欢迎收藏后慢慢阅读。监督学习算法本文主要介绍的有监督学习算法是KNN,后续会接着介绍决策树、线性回归等算法。

    2022年5月28日
    40
  • 解决Typora官方版本图片显示bug

    解决Typora官方版本图片显示bug问题:win10,官网下载的typorawinx64版,就是不显示图片,并不是路径问题!不是偏好设置问题!就是图片无法加载!,网上搜了一下发现很多小伙伴也遇到了这个问题;个人觉得这应该就是0.10版本的bug解决:换了一下0.9版本的,完美解决希望对你有所帮助!0.9版本的安装包pan链接:https://pan.baidu.com/s/1InBp08xV1DcOyiV9Ic65qQ提取码:1234复制这段内容后打开百度网盘手机App,操作更方便哦–来自百度网盘超级会员V3的分享…

    2022年5月12日
    39
  • 线程创建的四种方式

    线程创建的四种方式java中创建线程的四种方法以及区别Java使用Thread类代表线程,所有的线程对象都必须是Thread类或其子类的实例。Java可以用四种方式来创建线程,如下所示:1)继承Thread类创建线程2)实现Runnable接口创建线程3)使用Callable和Future创建线程4)使用线程池例如用Executor框架下面让我们分别来看看这四种创建线程的方法。–…

    2022年5月3日
    69
  • 十大经典排序算法(C语言实现)[通俗易懂]

    十大经典排序算法(C语言实现)[通俗易懂]原文链接:https://www.cnblogs.com/onepixel/articles/7674659.html1、冒泡排序(BubbleSort)冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经…

    2022年5月9日
    50
  • 【愚公系列】2022年03月 漏洞扫描与利用之AWVS「建议收藏」

    【愚公系列】2022年03月 漏洞扫描与利用之AWVS「建议收藏」实验步骤一首先需要添加一个扫描目标,先不进行登陆操作:设置爬虫扫描开始扫描得出网站目录如果需要账号密码则需要设置方式一:方式二:之后点击“save”,保存后就可以进行扫描备注:FullScan–使用FullScan来发起一个扫描的话,Acunetix会检查所有可能得安全漏洞。HighRishVulnerabilities–这个扫描选项将仅仅只会检查那些对web站点影响最大的缺陷漏洞。Cross-SiteScripting(XSS)–XXS漏洞扫描只会检测跨站

    2022年9月23日
    0
  • 人工智能学习路线

    阶段一、人工智能基础- 高等数学必知必会本阶段主要从数据分析、概率论和线性代数及矩阵和凸优化这四大块讲解基础,旨在训练大家逻辑能力,分析能力。拥有良好的数学基础,有利于大家在后续课程的学习中更好的理解机器学习和深度学习的相关算法内容。同时对于AI研究尤为重要,例如人工智能中的智能很大一部分依托“概率论”实现的。一、数据分析1)常数e2)导数3)梯度4)Taylor5)gini系数6)信息熵与…

    2022年4月9日
    1.3K

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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