我的App.xaml
文件中有几个样式:
<SolidColorBrush x:Key="styleBlue" Color="#FF4B77BE"/>
<SolidColorBrush x:Key="styleRed" Color="#FFF64747"/>
<SolidColorBrush x:Key="styleOrange" Color="#FFF89406"/>
<SolidColorBrush x:Key="styleGreen" Color="#FF1BBC9B"/>
<SolidColorBrush x:Key="styleYellow" Color="#FFF9BF3B"/>
<Style x:Key="stackpanelBackground" TargetType="StackPanel">
<Setter Property="Background" Value="{StaticResource styleBlue}"/>
</Style>
我想更改BackgroundProperty
的代码中的mainpage.xaml.cs
。
我试过用这个:
Style style = Application.Current.Resources["stackpanelBackground"] as Style;
style.Setters.SetValue(StackPanel.BackgroundProperty, "{StaticResource styleRed}");
但是我遇到了灾难性的失败异常。我认为这与{StaticResource styleRed}
有关。有更好的方法吗?
答案 0 :(得分:20)
StaticResource
是静态的。一旦应用程序编译,您就无法更改它们。
为此目的,有DynamicResource
:
DynamicResource 将在初始编译期间创建临时表达式,从而推迟查找资源,直到实际需要所请求的资源值才能构造对象。
另请注意,您可以使用FindResource
更好地找到对其他资源的引用。尝试这样的事情(完整的工作样本):
在MainPage.xaml
:
<Window.Resources>
<Color R="255" x:Key="styleRed" />
<Style x:Key="abc" TargetType="StackPanel">
<Setter Property="Background" Value="Blue" />
</Style>
</Window.Resources>
在MainPage.xaml.cs
:
Style style = this.FindResource("abc") as Style;
var r = this.FindResource("styleRed");
foreach (Setter s in style.Setters)
{
if (s.Property == StackPanel.BackgroundProperty)
{
s.Value = r;
}
}
答案 1 :(得分:9)
为什么要修改样式而不是直接设置Background
- 目标StackPanel
的属性?由于“本地值”的优先级高于“样式设置器”,因此将使用您从代码后面写入Background
的值
意思是:
(1)为您的堆叠面板x:Name="spBla"
(2)将画笔分配到Background
的{{1}}(类似spBla
)
您可以在此处详细了解价值优先权:
http://msdn.microsoft.com/en-us/library/ms743230(v=vs.110).aspx
答案 2 :(得分:1)
xaml 资源
<Window.Resources>
<LinearGradientBrush x:Key="GrayBlueGardientBrush"
StartPoint="0,0" EndPoint="1,1">
<GradientStop Color="DarkCyan" Offset="0"/>
<GradientStop Color="#CCCCFF" Offset="0.5"/>
<GradientStop Color="DarkCyan" Offset="1"/>
</LinearGradientBrush>
</Window.Resources>
CS
private void Button_Click(object sender, RoutedEventArgs e)
{
var r = this.FindResource("GrayBlueGardientBrush");
(sender as Button).Background = r as LinearGradientBrush;
}
答案 3 :(得分:0)
如果我理解正确,您想要设置一种样式,只允许您更改特定的堆栈面板,因此您不必全部设置它们。试试这个建议(注意:这是一个建议,我没有测试过,但希望它是朝着正确的方向)
<SolidColorBrush x:Key="styleBlue" Color="#FF4B77BE"/>
<SolidColorBrush x:Key="styleRed" Color="#FFF64747"/>
<SolidColorBrush x:Key="styleOrange" Color="#FFF89406"/>
<SolidColorBrush x:Key="styleGreen" Color="#FF1BBC9B"/>
<SolidColorBrush x:Key="styleYellow" Color="#FFF9BF3B"/>
<Style x:Key="stackpanelBackground" TargetType="StackPanel">
<Setter Property="Background" Value="{Binding Background, FallbackValue={StaticResource styleBlue}}"/>
</Style>
或者尝试使用TemplateBinding而不是Binding,就像我说这是一个建议而我还没有测试过。这将为您提供背景绑定,以及您尚未设置背景颜色的stackpanel的后备值。让我知道这对你是否有用:)