Связывание значений анимации раскадровки - PullRequest
0 голосов
/ 05 июля 2010

У меня есть перечисление для модели представления, которая представляет один из 5 цветов, и я использую ValueConverter для преобразования этих значений в реальные цвета.

В частности, это цвет фона каждого элемента списка, чтобы изменить его при наведении на него.

У меня есть пользовательский элемент управления с визуальным менеджером состояний и группой наведения мыши, которая использует SplineColorKeyFrame для анимации цвета при наведении (это установлено в xaml шаблона элемента управления). У пользовательского элемента управления есть только свойство зависимости для цвета при наведении.

Это прекрасно работает, если значение SplineColorKeyFrame из ресурса или установлен в xaml в качестве фиксированного цвета. Однако он просто анимируется на прозрачный, когда я устанавливаю значение в «{TemplateBinding HoverColor}»

Даже если для свойства DependencyProperty в xaml задать цвет, а попытка использовать TemplateBinding в элементе управления для считывания цвета вызывает проблему, анимация не будет использовать правильный цвет, если я скажу, что она получена из привязки. или привязка шаблона.

Я отслеживал приложение и вижу, что свойство зависимости имеет правильное значение, но, похоже, оно не фиксирует это значение в анимации.

Кто-нибудь может подсказать, как это обойти?

Вот мой шаблон управления:

<Style TargetType="{x:Type local:MyCustomControl}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type local:MyCustomControl}">
                <Border Background="{TemplateBinding Background}"
                        BorderBrush="{TemplateBinding BorderBrush}"
                        BorderThickness="{TemplateBinding BorderThickness}" x:Name="border">
                    <VisualStateManager.VisualStateGroups>
                        <VisualStateGroup x:Name="MouseOverGroup">
                            <VisualStateGroup.Transitions>
                                <VisualTransition GeneratedDuration="0:0:0.2"/>
                            </VisualStateGroup.Transitions>
                            <VisualState x:Name="MouseOver">
                                <Storyboard>
                                    <ColorAnimationUsingKeyFrames Storyboard.TargetProperty="(Panel.Background).(SolidColorBrush.Color)" Storyboard.TargetName="border">
                                        <SplineColorKeyFrame KeyTime="0" Value="{TemplateBinding HoverColor}" />
                                    </ColorAnimationUsingKeyFrames>
                                </Storyboard>
                            </VisualState>
                            <VisualState x:Name="Normal"/>
                        </VisualStateGroup>
                    </VisualStateManager.VisualStateGroups>
                    <VisualStateManager.CustomVisualStateManager>
                        <ic:ExtendedVisualStateManager/>
                    </VisualStateManager.CustomVisualStateManager>

                    <i:Interaction.Triggers>
                        <i:EventTrigger EventName="MouseEnter">
                            <ic:GoToStateAction x:Name="MouseOverAction" StateName="MouseOver"/>
                        </i:EventTrigger>
                        <i:EventTrigger EventName="MouseLeave">
                            <ic:GoToStateAction x:Name="NormalAction" StateName="Normal"/>
                        </i:EventTrigger>
                    </i:Interaction.Triggers>
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

Вот мой код управления:

   public class MyCustomControl : Control
    {
        public static DependencyProperty HoverColorProperty = DependencyProperty.Register("HoverColor", typeof (Color),
                                                                                          typeof (MyCustomControl));
        public Color HoverColor
        {
            get
            {
                return (Color)GetValue(HoverColorProperty);
            }
            set
            {
                SetValue(HoverColorProperty, value);
            }
        }

        static MyCustomControl()
        {
            DefaultStyleKeyProperty.OverrideMetadata(typeof(MyCustomControl), new FrameworkPropertyMetadata(typeof(MyCustomControl)));
        }
    }

Вот главное окно xaml:

<Window x:Class="Test.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
        xmlns:Test="clr-namespace:Test" Title="MainWindow" Height="350" Width="525">
    <Window.DataContext>
        <Test:ViewModel/>
    </Window.DataContext>
    <Grid>
        <Test:MyCustomControl HoverColor="Yellow"
                              HorizontalAlignment="Center" VerticalAlignment="Center" Width="150" Height="150"
                              Background="Bisque">

        </Test:MyCustomControl>
    </Grid>
</Window>

1 Ответ

0 голосов
/ 01 июля 2011

Я нашел ответ на эту проблему.Оказывается, что по какой-то причине привязка не работает, если StoryBoard встроен в Xaml.Если вы помещаете раскадровку в ресурс и ссылаетесь на ресурс в VisualStateManager, то все работает.

...