私は次のようなカスタムコントロールを持っています:
<Style TargetType="local:AnswerButton">
<Setter Property="Background" Value="{StaticResource BlueGradient}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="local:AnswerButton">
<Grid>
<vsm:VisualStateManager.VisualStateGroups>
<vsm:VisualStateGroup x:Name="CommonStates">
<vsm:VisualState x:Name="Normal">
<Storyboard>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="(Border.Background)" Storyboard.TargetName="myBorder">
<DiscreteObjectKeyFrame KeyTime="0" Value="{StaticResource BlueGradient}" />
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</vsm:VisualState>
<vsm:VisualState x:Name="RightAnswer">
<Storyboard RepeatBehavior="Forever" BeginTime="00:00:00" AutoReverse="True">
<ColorAnimation Duration="0:0:0.6" From="Orange" To="Green" Storyboard.TargetProperty="(Border.Background).(SolidColorBrush.Color)" Storyboard.TargetName="myBorder"/>
</Storyboard>
</vsm:VisualState>
</vsm:VisualStateGroup>
</vsm:VisualStateManager.VisualStateGroups>
<Border BorderBrush="Blue" BorderThickness="2" CornerRadius="10">
<Border Name="myBorder" Background="{TemplateBinding Background}" CornerRadius="9" Opacity="1">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="100"/>
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<TextBlock Grid.Column="0"
TextAlignment="Center" VerticalAlignment="Center"
Text="{TemplateBinding Option}" Foreground="Yellow" />
<TextBlock Grid.Column="1"
TextAlignment="Left" VerticalAlignment="Center"
Text="{TemplateBinding Text}" Foreground="White" />
</Grid>
</Border>
</Border>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
ボタンの状態を変えたいだけです。最初(デフォルト)のボタンにはBlueGradientブラシがあり、2番目のボタンにはアニメーションがあります(RightAnswer状態のように)。このコードは部分的に機能しています。RightAnswerの状態をボタンに設定してからNormalに変更し、RightAnswerに設定しようとすると、次のエラーが発生します。
指定されたオブジェクトのTargetProperty(Border.Background)。(SolidColorBrush.Color)を解決できません。
問題は、ある状態で私が得た状態とStoryboard.TargetProperty="(Border.Background).(SolidColorBrush.Color)"
2番目の状態であるということだと思いますStoryboard.TargetProperty="(Border.Background)"
。私はそれを変更しようとしましたが、機能していません。では、どうすればこれを修正できますか?
編集:
BlueGradient
<LinearGradientBrush x:Key="BlueGradient"
StartPoint="0,0" EndPoint="1,1">
<GradientStop Color="#12449d" Offset="0" />
<GradientStop Color="#0a2554" Offset="1" />
</LinearGradientBrush>