我无法在 WPF 中为自定义属性设置动画

Ily*_*gan 2 wpf animation

我已经为此苦苦挣扎了几个小时,但我找不到我做错了什么。请帮我找出我的错误。

我创建了一个具有一个自定义依赖属性的用户控件,并且我想为该属性设置动画。

这是我的课程:

public partial class UserControl1 : UserControl
{
    public UserControl1()
    {
        InitializeComponent();
    }

    public long Val
    {
        get { return (long)GetValue(ValProperty); }
        set {
             SetValue(ValProperty, value);

             // Update a text block for debug
             ((Class1)this.Resources["class1"]).Val = value;  
        }
    }

    public static readonly DependencyProperty ValProperty =
        DependencyProperty.Register("Val", typeof(long), typeof(UserControl1), new UIPropertyMetadata(0L));
}
Run Code Online (Sandbox Code Playgroud)

下面是应该为其设置动画的代码(有一个名为 usercontrol11 的 UserControl1 实例):

        Int64Animation myAnimation = new Int64Animation();
        myAnimation.From = 100;
        myAnimation.To = 200;
        myAnimation.Duration = new Duration(TimeSpan.FromSeconds(1));

        Storyboard.SetTargetName(myAnimation, userControl11.Name);
        Storyboard.SetTargetProperty(myAnimation, new PropertyPath(UserControl1.ValProperty));

        Storyboard myStoryboard = new Storyboard();
        myStoryboard.Children.Add(myAnimation);
        myStoryboard.Begin(this);
Run Code Online (Sandbox Code Playgroud)

我也尝试了 XAML 方法,但它也不起作用(在以下 XAML 中,宽度动画工作正常,但 Val 不起作用):

<my:UserControl1 HorizontalAlignment="Left" Width="150" Margin="72,45,0,0" x:Name="userControl11" VerticalAlignment="Top" Background="#FFFFD100">
  <my:UserControl1.Triggers>
    <EventTrigger RoutedEvent="MouseEnter">
        <EventTrigger.Actions>
            <BeginStoryboard>
                <Storyboard>
                    <Int64Animation To="300" Duration="0:0:1"
                                    Storyboard.TargetProperty="Val" />
                    <DoubleAnimation To="300" Duration="0:0:1"
                                    Storyboard.TargetProperty="Width" />
                </Storyboard>
            </BeginStoryboard>
        </EventTrigger.Actions>
    </EventTrigger>                        
  </my:UserControl1.Triggers>
</my:UserControl1>
Run Code Online (Sandbox Code Playgroud)

任何帮助都感激不尽!

max*_*max 5

嗯,其实是动画化的。您只是检查了错误的位置,动画不会调用 Val 属性集访问器。例如,您可以覆盖OnPropertyChanged方法来查看更改:

    protected override void OnPropertyChanged(DependencyPropertyChangedEventArgs e)
    {
        base.OnPropertyChanged(e);
        if(e.Property == ValProperty)
        {
            MessageBox.Show(e.NewValue.ToString());
        }
    }
Run Code Online (Sandbox Code Playgroud)