3

正常静态控制 下沉式静态控制

我使用以下代码创建静态控件:

hWnd = CreateWindowExW( 0,
                        L"STATIC",
                        Content.c_str(),
                        SS_LEFT | WS_VISIBLE | WS_CHILD /*| SS_SUNKEN*/,
                        200,
                        120,
                        120,
                        40,
                        hWndParent,
                        NULL,
                        hInstance,
                        NULL);

如果我SS_SUNKEN在上面的创建代码中启用样式,创建的静态控件就会出现下沉成功。

但是,我要做的是在创建后更改控件样式。
我试过这个:

void BaseWindowClass::AddStyle(DWORD NewStyle)
{
    // NewStyle     = 0x00001000 = SS_SUNKEN
    LONG oldstyle, changedstyle;
    oldstyle=SetWindowLongW(hWnd, GWL_STYLE, changedstyle=GetWindowLongW(hWnd, GWL_STYLE) | NewStyle);
    UpdateWindowStyles();
    // oldstyle     = 0x50000000
    // changedstyle = 0x50001000 (everything looks normal)
}
void BaseWindowClass::UpdateWindowStyles()
{
    BOOL success;
    success=SetWindowPos(hWnd, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | SWP_FRAMECHANGED);
    // success = 0x00000001 (non-zero: SetWindowPos sucseeded)
}

文档:
SetWindowLong()
SetWindowPos()

我打电话SetWindowPos()后打电话SetWindowLongW(),因为在 SetWindowLong 的文档中,它说:

某些窗口数据被缓存,因此您使用 SetWindowLong 所做的更改在调用 SetWindowPos 函数之前不会生效。具体来说,如果您更改任何框架样式,则必须使用 SWP_FRAMECHANGED 标志调用 SetWindowPos 才能正确更新缓存。

而且,在 SetWindowPos 的文档中,它说:

如果您使用 SetWindowLong 更改了某些窗口数据,则必须调用 SetWindowPos 才能使更改生效。对 uFlags 使用以下组合: SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | SWP_FRAMECHANGED。

即使在更改之后SetWindowLongW()SetWindowPos()我的静态控件的样式也不会改变。

我做错了什么,或者我错过了什么?

4

2 回答 2

1

SS_SUNKEN有效地WS_EX_STATICEDGE在扩展样式 ( GWL_EXSTYLE) 窗口中设置很长时间,因此您可以GWL_EXSTYLE像当前所做的那样适当地更新和重新定位。

于 2013-07-30T00:35:31.510 回答
0

尽管SS_SUNKEN确实会影响静态控件的框架,但它并不是 note 所指的“框架样式”之一。

该注释指的是影响所有窗口的通用框架样式,例如WS_BORDERWS_EX_CLIENTEDGE- 更改时需要重新计算窗口的非客户区的样式。

许多系统控件在创建时会缓存其样式,即使您通过SetWindowLong. 我猜这就是这里发生的事情 - 如果您不使用 创建静态控件SS_SUNKEN,则以后无法添加它。您最好的选择是简单地销毁并使用新样式重新创建控件。

于 2013-07-27T09:53:38.550 回答