我一直试图找到一个简单的解决方案来更改具有ES_READONLY标志的编辑控件的颜色。当编辑控件可编辑时,我的代码(有点)有效,但对我的具有只读标志的编辑控件没有影响。
case WM_CTLCOLOREDIT:
{
HDC hdc = (HDC)wParam;
//if (GetDlgItem(hwnd, IDC_EDIT_IN) == (HWND)lParam)
//{
SetTextColor(hdc, RGB(255, 255, 255)); // Set text color to white
SetBkColor(hdc, RGB(255, 255, 255)); // Set background color to black
//}
return 0;
}
break;
我在那里发表评论只是为了检查我的代码是否有效,并且它在编辑控件上是不是只读。如果我在我的其他编辑控件上取出ES_READONLY,它确实可以正常工作。我正在创建聊天程序,并且不希望用户能够输入聊天框区域。当它只读时,它会变成灰色,但我想要一种白色。还有另一种方法吗?此外,颜色仅为文本所在的区域着色,而不是编辑控件的整个高度。我做错了什么?
答案 0 :(得分:7)
您需要创建画笔并跟踪它。然后在代码段中返回此画笔而不是return 0
。一旦不再需要刷子,您必须删除它。这通常是为了响应WM_DESTROY
消息而完成的。
在你的情况下,你可以使用库存刷子弹,这是我推荐的。
当处于只读模式时,编辑控件会响应WM_CTLCOLORSTATIC
而不是WM_CTLCOLOREDIT
,因此您必须正确处理此消息:
case WM_CTLCOLORSTATIC:
{
if( (HWND)lParam == GetDlgItem(hwnd, IDC_EDIT_IN) )
{
SetBkMode( (HDC)wParam, TRANSPARENT );
SetTextColor(hdc, RGB(255, 255, 255));
return (LRESULT)( (HBRUSH)GetStockObject(BLACK_BRUSH) );
// if edit control is in dialog procedure change LRESULT to INT_PTR
}
else // this is some other static control, do not touch it!!
return DefWindowProc( hwnd, message, wParam, lParam );
}
绘制编辑/静态控件时,有3个部分可用于绘画:
为了将整个控件绘制成所需的颜色,您必须返回所需颜色的画笔(return (LRESULT)someBrush
用于窗口过程,或return (INT_PTR)someBrush
用于对话框)。
您对SetBkColor
的来电设置了文字背景的颜色,该颜色与控件的背景颜色不同。这就是为什么我们使用SetBkMode
参数调用TRANSPARENT
来“说”我们希望文本背景与控件的背景匹配。
在你的情况下,我使用了库存刷,因为你不需要跟踪它,也不需要在不再需要它之后删除它。
尽管如此,可能还会出现需要其他颜色的情况。在这种情况下,您需要做的是:
HBRUSH
变量或static HBRUSH
变量。WM_CREATE
。如果在对话框过程中初始化画笔WM_INITDIALOG
。类似于someBrush = CreateSolidBrush( RGB( 255, 0, 255 ) );
的内容,请参阅documentation了解更多信息和示例。return (LRESULT)someBrush
用于窗口过程,或return (INT_PTR)someBrush
用于对话框)。WM_DESTROY
调用DeleteObject(someBrush);
时完成。 我强烈建议您删除以回复WM_DESTROY
而不是WM_CLOSE
,因为这是您的窗口始终会收到的消息,而WM_CLOSE
有时可以跳过(搜索Internet以查找此方案的示例)。
希望这会有所帮助,如果您有其他问题留下评论,我会尽力提供帮助。最好的问候。