ここから取得した画像のアニメーションを実行した後:ボタンで画像を アニメーション化する外部、つまりViewModelからのボタンのクリックに応じて、アニメーションのオンとオフを切り替えられるようにしたい
そこで、新しいDependencyPropertyをBahaviorに追加しました(ここで必要なものはすべて)
 public static readonly DependencyProperty IsShakingProperty =
        DependencyProperty.Register(IsShakingName,
                                    typeof(bool),
                                    typeof(ShakeBehavior),
                                    new PropertyMetadata(DefaultIsShaking));
ViewModelに新しいパブリックプロパティを追加しました
public bool IsShaking { get; set; }
しかし、Trueまたはfalseに設定されたViewModelプロパティに応じて、アニメーションのオンとオフを切り替えるにはどうすればよいですか?(ボタンクリックでアニメーションを制御したい)
これが私が関連すると思うコードのいくつかです
private Timeline CreateAnimationTimeline()
{
    DoubleAnimationUsingKeyFrames animation = new DoubleAnimationUsingKeyFrames();
    animation.SetValue(Storyboard.TargetPropertyProperty, new PropertyPath("(0).(1)", UIElement.RenderTransformProperty, RotateTransform.AngleProperty));
    int keyFrameCount = 8;
    double timeOffsetInSeconds = 0.25;
    double totalAnimationLength = keyFrameCount * timeOffsetInSeconds;
    double repeatInterval = RepeatInterval;
    bool isShaking = IsShaking;
    // Can't be less than zero and pointless to be less than total length
    if (repeatInterval < totalAnimationLength)
        repeatInterval = totalAnimationLength;
    animation.Duration = new Duration(TimeSpan.FromSeconds(repeatInterval));
    int targetValue = 12;
    for (int i = 0; i < keyFrameCount; i++)
        animation.KeyFrames.Add(new LinearDoubleKeyFrame(i % 2 == 0 ? targetValue : -targetValue, KeyTime.FromTimeSpan(TimeSpan.FromSeconds(i * timeOffsetInSeconds))));
    animation.KeyFrames.Add(new LinearDoubleKeyFrame(0, KeyTime.FromTimeSpan(TimeSpan.FromSeconds(totalAnimationLength))));
    return animation;
}
これが私のXAMLの一部です:
<ListBox.ItemTemplate>
                <DataTemplate>
                    <Button Focusable="False" Command="{Binding ClickToolCommand}" Grid.Row="{Binding Path=Row}" Grid.Column="{Binding Path=Col}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="0">
                        <Image Source="myImage.png" Grid.Row="{Binding Path=Row}" Grid.Column="{Binding Path=Col}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="0">
                            <i:Interaction.Behaviors>
                                <local:ShakeBehavior RepeatInterval="1" SpeedRatio="3.0" IsShaking="{Binding Path=IsShaking}"/>
                            </i:Interaction.Behaviors>
                        </Image>
                    </Button>
                </DataTemplate>
            </ListBox.ItemTemplate>
他のSOで指摘されているように、おそらくDataTriggerが役立つ可能性がありますが、カスタムがあるため、XAML内にストーリーボードがありません。Behavior
どんな入力でも大歓迎です!