今天有朋友问我怎么在Button点击的时候修改它的前景色和背景色,自己觉得这个问题挺简单的,就写了两行代码,放到了按钮的点击事件响应行数中,代码如下:

private void button1_Click(object sender, RoutedEventArgs e)
{
    button1.Background = new SolidColorBrush(Colors.Blue);
    button1.Foreground = new SolidColorBrush(Colors.Red);
}

界面截个图,直观些:

iOS点击button改变背景颜色_控件

编译执行后,按钮的颜色没有变化,感觉非常奇怪。于是查看MSDN的帮助文档,把控件更新相关的方法也胡乱试了一通,居然都没有效果。郁闷了,觉得奇怪,把代码直接复制到构造函数的下面了:

public MainPage()
{
    InitializeComponent();
    button1.Background = new SolidColorBrush(Colors.Blue);
    button1.Foreground = new SolidColorBrush(Colors.Red);
}

补充一句,默认情况下Button是黑色背景,白色前景。

编译执行后,按钮颜色变了!这说明在代码中操作Background和Foreground这两个属性也没问题啊。

想不通了,我再加个按钮试试吧,于是又增加个button2,在button2的点击操作中做同样的操作,也是改变button1的前景色和背景色。

问题出现了:

1.如果先点击Button1,还是没有任何变化,再点击Button2,Button1也没有变化

2.如果先点击Button2,Button1的前景色和背景色就变了

3.我又试了Button2点击响应函数中改变自己颜色,没有效果

截图如下:

iOS点击button改变背景颜色_Red_02

 

我有点晕了,为什么呢?不过似乎找到了点规律,就是按钮在其自身的点击响应函数中,修改不了自身的前景色和背景色。

没想明白,再增加一个按钮试试吧。这回策略变一下,在每个按钮的响应函数中,修改另外两个按钮的颜色。

又找到了规律:

1.第一次点击某一个按钮,例如Button1,修改另外两个按钮的前景色和背景色,都正常能修改。如图:

iOS点击button改变背景颜色_背景色_03

2.第二次点击另一个按钮,例如Button2,第一次点击过的按钮颜色不会变。如图:

iOS点击button改变背景颜色_背景色_04

3.只要点击过的按钮,颜色就无法改变了。

我想不明白了,为什么只要点击过的按钮,颜色就修改不了了呢?

我又用Silverlight程序试了一下,在SL中没这个问题,只有在WP7中这个问题存在。

如果真的有这样的需求,给大家几个建议:

1.用Blend编辑好按钮各个状态的颜色,例如按下和正常状态的颜色,不在代码里动态改变了。

2.把按钮设置为透明,后面放个Border,这样做能改背景色,但前景色就无能为力了。

3.用Image或其它控件代替Button,这样可能会麻烦一些。

如果大家有好的解决办法,请在下面留言,非常感谢。

特别感谢:MagicBoy110同学跟我讨论并验证该问题。

 

示例源代码