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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 通过端口查找进程

    通过端口查找进程

    2021年9月16日
    48
  • MySQL Connector/Net 的简单使用「建议收藏」

    MySQL Connector/Net 的简单使用「建议收藏」IDE:vs2022Targetframework:.net6.0首先,新建工程(WindowsApplication)然后,在NuGet中获取MySQL连接器(.netcore)Project-》ManageNuGetPackages之后,放置控件3个TextBox,2个ComboBox(cBoxDBs和cBoxTables)等等密码框设置下拉框设置(cBoxDBs:数据库,cBox

    2022年7月15日
    16
  • python中dtype、type()、astype()区别

    python中dtype、type()、astype()区别(1)type()是python内置的函数。type()返回数据结构类型(list、dict、numpy.ndarray等)(2)dtype返回数据元素的数据类型(int、float等)(3)astype()改变np.array中所有数据元素的数据类型。————————————备注:1)由于list、dict等可以包含不同的数据类型,因此没有dtype属性2)np.array中要求所有元素属于同一数据类型,因此有dtype属性备注:能用dtype()才能用astype().

    2022年5月2日
    72
  • 简易漫画网站搭建-漫画喵Server版

    简易漫画网站搭建-漫画喵Server版本文实现了一个简单的个人漫画网站,配合之前的漫画爬虫使用。享受无处不在的漫画生活。github地址:https://github.com/miaoerduo/cartoon-cat-server

    2022年8月4日
    9
  • memwatch

    memwatch一、简介memwatch可以跟踪程序中的内存泄漏和错误,能检测双重释放(double-free)、错误释放(erroneousfree)、没有释放的内存(unfreedmemory)、溢出(Ov

    2022年7月4日
    37
  • java单例模式_Java单例模式

    java单例模式_Java单例模式单例(Singleton)模式是Java中最简单的设计模式之一。这种类型的设计模式属于创建模式,因为此模式提供了创建对象的最佳方法之一。这种模式涉及一个类,它负责创建一个对象,同时确保只创建一个对象。这个类提供了一种方法来访问它的唯一对象,可以直接访问,而不需要实例化类的对象。实现实例我们将创建一个单一对象类-SingleObject。单个对象(SingleObject)类的构造函数是私有的,…

    2022年7月8日
    24

发表回复

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

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