动画(Animation)

WPF动画使用三种方法:

(1)线性插值:在开始值和结束值之间以逐步增加的方式改变属性的动画(线性插值过

程)。

(2)关键帧:从一个值突然变成另一值的动画(关键帧动画)。所有关键帧动画都使用

"类型名 + AnimationUsingKeyFrames " 的形式进行命名,比如

StringAnimationUsingKeyFrames和ObjectAnimationUsingKeyFrames。

(3)路径。

System.Windows.Media.Animation名称空间中将发现以下内容:

7 "类型名+Animation"  这些类使用插值动画。

22 "类型名+AnimationUsingKeyFrames" 这些类使用关键帧动画。

3 "类型名+AnimationUsingPath"类这类使用基于路径的动画。

注意

某些数据类型有关键帧动画类,但没有插值动画类。例如,可使用关键帧为字符串应用动画,不能使用插值为字符串应用动画。然而,所有数据类型都支持关键帧动画,除非他们根本不支持动画。

所有具有(使用插值)常规动画类的数据类型,也都有相应的关键帧动画的动画类型,如线性插值的DoubleAnimation对应DoubleAnimationUsingKeyFrames。另外还有一种基于路径的动画。

Animation类提供一种简单的“渐变”动画我们为一个Animation指定开始值和一

个结束值并指定由开始值到达结束值所需的时间便可形成一个简单的动画。比

如我们指定长方形的宽度由100变化到200所需时间为1秒很容易想像这样的动

画是什么样的而它对应的Xaml代码如下一、动画创建

第 1 部分:创建 DoubleAnimation

使元素淡入和淡出的一种方法是对其属性进行动画处理 Opacity 。 由于 Opacity 属性的类型为 Double ,因此需要一个生成双精度值的动画。 DoubleAnimation是一种动画。

DoubleAnimation创建两个双精度值之间的转换。 若要指定其起始值,请设置其 From 属性。 若要指定其结束值,请设置其 To 属性。

1

2

3

<!--定义动画:TargetName指定操作控件,TargetProperty指定操作控件的具体属性,

From指定开始值,To指定结束值,Duration指定所需时间-->

<DoubleAnimation  Storyboard.TargetName="MyRectangle" Storyboard.TargetProperty="Width" From="100" To="200"

Duration="0:0:1"/>

第 2 部分:创建演示图板(故事版)

若要将动画应用于对象,请创建 Storyboard 并使用 TargetName 和 TargetProperty 附加属性指要进行动画处理的对象和属性。

 

第 3 部分 (XAML):将演示图板与触发器关联(事件触发器)

若要应用和启动中,最简单的方法 Storyboard XAML 是使用事件触发器。 本部分演示如何将 Storyboard 与 XAML 中的触发器相关联。

第4 部分:完整的示例下面的示例演示如何创建在 XAML 中淡入和淡出视图的矩形。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

<Window x:Class="WpfApplication.MainWindow"

        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"         xmlns:local="clr-namespace:WpfApplication"

        Title="MainWindow" Height="768" Width="1366" >

    <StackPanel Margin="10">

        <!--矩形-->

        <Rectangle

                Name="MyRectangle"

                Width="100"                 Height="100"                 Fill="Blue">

            <Rectangle.Triggers>

                <!-- 动画矩形的不透明度 -->

                <EventTrigger RoutedEvent="Rectangle.Loaded">

                    <BeginStoryboard>

                        <Storyboard>

                            <!--Duration :起始值到目标值需要时间5秒。

AutoReverse="True":使元素消失后变为视野

                                RepeatBehavior="Forever": 使动画无限重复->

                            <DoubleAnimation

Storyboard.TargetName="MyRectangle"

23

24

25

26

27

28

29

30

31

32

33

Storyboard.TargetProperty="Opacity"

From="1.0" To="0.0"

Duration="0:0:5"

AutoReverse="True"

RepeatBehavior="Forever" />

                        </Storyboard>

                    </BeginStoryboard>

                </EventTrigger>

            </Rectangle.Triggers>

        </Rectangle>

    </StackPanel>

</Window>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值