一、 问题描述
当一个TextBox的ReadOnly属性设为true的时候,我们不管怎么改变ForeColor,该TextBox的字体颜色都不发生改变。
二、 问题重现
1. 新建一个Winforms工程;
2. 从工具箱里拖拽一个TextBox到Form1上;
3. 在属性框里,把textBox1的ReadOnly属性设为true;
4. 在属性框里,把textBox1的Text属性设为一个非空字符串;
5. 在属性框里,改变textBox1的ForeColor属性。
我们可以注意到尽管我们改变了textBox1的ForeColor属性,显示的字体颜色并没有发生变化。
三、 原因分析
在Winforms里TextBox控件是在响应消息WM_CTLCOLOREDIT的时候的时候,把颜色ForeColor通过API SetTextColor设置为字体颜色。在关于消息WM_CTLCOLOREDIT的MSDN页面中,有这样一句话:
Read-only or disabled edit controls do not send the WM_CTLCOLOREDIT message; instead, they send the WM_CTLCOLORSTATIC message.
当我们把一个TextBox设为只读时,Windows将不再发送消息WM_CTLCOLOREDIT给它。但该TextBox将收到消息WM_CTLCOLORSTATIC。在TextBox对消息WM_CTLCOLORSTATIC的响应函数里,Winforms并没有调用SetTextColor把ForeColor设置为字体颜色。也就是说,当一个TextBox为只读时,它的字体颜色不是由Winforms设定的,而是由Windows设置为黑色。因此无论我们怎么修改一个只读TextBox的ForeColor颜色,它的字体颜色都不发生改变。
四、 类似现象
如果把一个Button的FlatStyle属性设为System,然后当我们在试图去修改BackColor的时候,我们发现该Button的背景颜色也不发生改变。原因与上面提到的类似,详情请参考消息WM_CTLCOLORBTN。