代码创建 WPF 旋转、翻转动画(汇总)

2021-01-18 09:12

阅读:642

先建立一个button

        Button  Width="80" Height="60" Content="旋转" Name="trans" Click="trans_Click"  Style="{x:Null}"/>

方法一:绕左上角旋转

 public void Transform1()
        {
            RotateTransform rtf = new RotateTransform();
            trans.RenderTransform = rtf;
            DoubleAnimation dbAscending = new DoubleAnimation(0, 360, new Duration

            (TimeSpan.FromSeconds(1)));
            dbAscending.RepeatBehavior = RepeatBehavior.Forever;
            rtf.BeginAnimation(RotateTransform.AngleProperty, dbAscending);
        }

方法二:绕左上角旋转

public void Transform2()
        {
            RotateTransform rtf = new RotateTransform();
            trans.RenderTransform = rtf;
            DoubleAnimation dbAscending = new DoubleAnimation(0, 360, new Duration(TimeSpan.FromSeconds(1)));
            Storyboard storyboard = new Storyboard();
            dbAscending.RepeatBehavior = RepeatBehavior.Forever;
            storyboard.Children.Add(dbAscending);
            Storyboard.SetTarget(dbAscending, trans);
            Storyboard.SetTargetProperty(dbAscending, new PropertyPath("RenderTransform.Angle"));
            storyboard.Begin();
        }

效果如下:

技术图片

截图不怎么能看出效果,这两种方法是按某个角进行旋转的。

方法三:Xaml动画,绕X中线或者Y中线翻转

Window x:Class="Oland.HSS.InHospital.Window2"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="Window2" Height="300" Width="300">
    Window.Resources>
        Storyboard x:Key="LoadHeadStoryboard" >
            DoubleAnimationUsingKeyFrames BeginTime="0:0:0" Duration="0:0:5"
                                           RepeatBehavior="Forever"
                                           Storyboard.TargetName="DesignerHead"
                                           Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleY)">
                SplineDoubleKeyFrame   Value="1"/>
                SplineDoubleKeyFrame    Value="-1"/>
                SplineDoubleKeyFrame    Value="1"/>
            DoubleAnimationUsingKeyFrames>

        Storyboard>
    Window.Resources>
    Window.Triggers>
        EventTrigger RoutedEvent="FrameworkElement.Loaded">
            BeginStoryboard Storyboard="{StaticResource LoadHeadStoryboard}"/>
        EventTrigger>
    Window.Triggers>
    Grid>
        Button  Content="旋转" x:Name="DesignerHead"  Height="40" Width="60" RenderTransformOrigin="0.4,0.5"  Style="{x:Null}">
            Button.RenderTransform>
                TransformGroup>
                    ScaleTransform ScaleX="1" ScaleY="1">ScaleTransform>
                TransformGroup>
            Button.RenderTransform>
        Button>
    Grid>
Window>

技术图片

可设置是延X中线或者是Y中线旋转,上边那种是按左上角旋转。

 

方法四:第一种方式使用Xaml实现(左上)

Button Content="旋转" Height="32" HorizontalAlignment="Left" Margin="106,176,0,0" Name="button1" VerticalAlignment="Top" Width="58" >
            Button.RenderTransform>
                RotateTransform x:Name="trans" Angle="0"/>
            Button.RenderTransform>
            Button.Triggers>
                EventTrigger RoutedEvent="Button.Click">
                    BeginStoryboard>
                        Storyboard>
                            DoubleAnimation To="360" RepeatBehavior="Forever" Duration="0:0:3"
                                             Storyboard.TargetName="trans"
                                             Storyboard.TargetProperty="Angle"/>
                        Storyboard>
                    BeginStoryboard>
                EventTrigger>
            Button.Triggers>
        Button>

效果同第一第二种方法

技术图片

方法五:绕中点旋转:

 Button Content="旋转" Height="32" HorizontalAlignment="Left" Margin="106,176,0,0" Name="button1" VerticalAlignment="Top" Width="58" RenderTransformOrigin="0.5,0.5">
            Button.RenderTransform>
                RotateTransform x:Name="trans" Angle="0"/>
            Button.RenderTransform>
            Button.Triggers>
                EventTrigger RoutedEvent="Button.Click">
                    BeginStoryboard >
                        Storyboard>
                            DoubleAnimation From="0" To="360" RepeatBehavior="Forever" Duration="0:0:3"
                                             Storyboard.TargetName="trans"
                                             Storyboard.TargetProperty="Angle"/>
                        Storyboard>
                    BeginStoryboard>
                EventTrigger>
            Button.Triggers>
        Button>

这段代码和上面差不多,

关键是RenderTransformOrigin,设成0.5,0.5就可以了


评论


亲,登录后才可以留言!