基础知识

(一)动画:是快速播放一系列图像(其中每个图像与下一个图像略微不同)给人造成的一种幻觉

(二)动画类型:两类    (1)From/To/By动画:在起始值和结束值之间进行动画处理。      (2)关键帧动画:在使用关键帧对象指定的一系列值之间播放动画

(三) 动画是时间线:所有动画均继承自 Timeline 对象,因此所有动画都是专用类型的时间线.有以下重要属性:

(1)TargetName:指定要进行动画处理的对象    
    (2)TargetProperty:指定要进行动画处理的属性    
    (3)Duration:(时间线)整个动画单次播放持续的时间(格式为 小时 : 分钟 : 秒 或者Forever 或者 Automatic)    
    (4)AutoReverse:指定时间线在到达其 Duration 的终点后是否倒退(True/Flase)     
    (5)RepeatBehavior:获取或设置此时间线的重复行为(RepeatBehavior 可以定义为时间跨度字符串、#x 字符串或者特殊值 Forever)。 
    (6)FillBehavior: 属性指定时间线结束时的行为方式( HoldEnd和Stop) ,默认HoldEnd.如果想保持结束后的状态HoldEnd,否则Stop     
    (7) BeginTime: 属性可以指定动画对象活动开始点的时间

 <UserControl x:Class="AnimationStudy.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
d:DesignHeight="" d:DesignWidth="">
<StackPanel>
<StackPanel.Resources>
<!-- 矩形透明度动画 -->
<Storyboard x:Name="myStoryboard">
<!--
()TargetName:指定要进行动画处理的对象
()TargetProperty:指定要进行动画处理的属性
()Duration:(时间线)整个动画单次播放持续的时间(格式为 小时 : 分钟 : 秒 或者Forever 或者 Automatic)
()AutoReverse:指定时间线在到达其 Duration 的终点后是否倒退(True/Flase)
()RepeatBehavior:获取或设置此时间线的重复行为(RepeatBehavior 可以定义为时间跨度字符串、#x 字符串或者特殊值 Forever)。
()FillBehavior: 属性指定时间线结束时的行为方式( HoldEnd和Stop) ,默认HoldEnd.如果想保持结束后的状态HoldEnd,否则Stop
() BeginTime: 属性可以指定动画对象活动开始点的时间
-->
<DoubleAnimation Storyboard.TargetName="MyAnimatedRectangle"
Storyboard.TargetProperty="Opacity" BeginTime="0:0:2"
From="1.0" To="0.0" Duration="0:0:1"
AutoReverse="False"
RepeatBehavior="1x" FillBehavior="HoldEnd" />
</Storyboard>
</StackPanel.Resources> <TextBlock Margin="">点击矩形开始动画</TextBlock>
<Rectangle MouseLeftButtonDown="Mouse_Clicked"
x:Name="MyAnimatedRectangle"
Width=""
Height=""
Fill="Blue" />
</StackPanel>
</UserControl>

(四) 对属性应用动画

 <UserControl x:Class="AnimationStudy.AnimationByProperty"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
d:DesignHeight="" d:DesignWidth="">
<!--对属性应用动画
()间接以属性作为目标
正在进行动画处理的属性值 (Color) 属于未命名甚至未显式声明的 SolidColorBrush 对象
Storyboard.TargetProperty="(Panel.Background).(SolidColorBrush.Color)"
()直接属性目标
显式创建 SolidColorBrush,对其进行命名,然后直接以其 Color 属性为目标
-->
<StackPanel x:Name="myStackPanel" Background="Red" Loaded="Start_Animation">
<StackPanel.Resources>
<Storyboard x:Name="colorStoryboard">
<ColorAnimation
BeginTime="00:00:00"
Storyboard.TargetName="myStackPanel"
Storyboard.TargetProperty="(Panel.Background).(SolidColorBrush.Color)"
From="Red" To="Green" Duration="0:0:4" />
</Storyboard>
</StackPanel.Resources>
</StackPanel>
<!--<StackPanel Loaded="Start_Animation">
<StackPanel.Resources>
<Storyboard x:Name="colorStoryboard">
<ColorAnimation BeginTime="00:00:00" Storyboard.TargetName="mySolidColorBrush"
Storyboard.TargetProperty="Color" From="Red" To="Green" Duration="0:0:4" />
</Storyboard>
</StackPanel.Resources>
<StackPanel.Background>
<SolidColorBrush x:Name="mySolidColorBrush" Color="Red" />
</StackPanel.Background>
</StackPanel>-->
</UserControl>

(五)在程序代码中创建动画,改写(三)中Xaml为程序代码

 //在程序代码中创建动画
private void button1_Click(object sender, RoutedEventArgs e)
{
//创建矩形
Rectangle myRectangle = new Rectangle();
myRectangle.Width = ;
myRectangle.Height = ;
Color myClolor = Color.FromArgb(, , , );
SolidColorBrush myBrush = new SolidColorBrush();
myBrush.Color = myClolor;
myRectangle.Fill = myBrush;
LayoutRoot.Children.Add(myRectangle);
//2秒中的时间线
Duration duration = new Duration(TimeSpan.FromSeconds()); // 创建DoubleAnimation动画
DoubleAnimation myDoubleAnimation = new DoubleAnimation();
myDoubleAnimation.Duration = duration;
//创建演示图版.并将myDoubleAnimation动画加到演示图板
Storyboard sb = new Storyboard();
sb.Duration = duration;
sb.Children.Add(myDoubleAnimation); //设置动画对象和动画属性
Storyboard.SetTarget(myDoubleAnimation, myRectangle);
Storyboard.SetTargetProperty(myDoubleAnimation, new PropertyPath(OpacityProperty));
myDoubleAnimation.To =0.0;
sb.BeginTime = new TimeSpan(, , , );
sb.RepeatBehavior = new RepeatBehavior();
myDoubleAnimation.AutoReverse = false;
myDoubleAnimation.FillBehavior = FillBehavior.HoldEnd;
//以资源文件加入到LayOutRoot
LayoutRoot.Resources.Add("",sb);
//开始动画
sb.Begin(); }

(一)关键帧动画:动画形式显示了目标属性的值,单个关键帧动画可以创建任意数量的目标值之间的过渡.

(二)关键帧动画的优点:

(1)使用关键帧对象描述关键帧动画的目标值

(2)单个关键帧动画可以创建任意数量的目标值之间的过渡

(3)某些关键帧方法除支持多个目标值外,还支持多个内插方法

(三)内插方法:定义了从某个值过渡到下一个值的方式

(1)离散

(2)线性

(3)样条

(四)创建关键帧动画

(1)步骤:

a、 按照对 From/To/By 动画使用的方法声明动画并指定其 Duration。

b、  对于每一个目标值,创建相应类型的关键帧,设置其值和 KeyTime,并将其添加到动画的 KeyFrames 集合内。

c、 按照对 From/To/By 动画使用的方法,将动画与属性相关联。

(2)实例讲解:

 <UserControl x:Class="AnimationStudy.AnimationUsingKeyFrames"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
d:DesignHeight="" d:DesignWidth=""> <Canvas>
<Canvas.Resources>
<Storyboard x:Name="myStoryboard">
<!--
(一)目标值(关键帧)和关键时间
Value(目标值/关键帧): 指定关键帧的目标值
KeyTime(关键时间): 属性指定到达关键帧的 Value 的时间(在动画的 Duration 之内)
(二)关键帧的类型
_interpolationMethod(内插方法)_type(处理得值类型) KeyFrame
(三)内插方法:
()线性(Linear)内插:动画将以段持续期间内的固定速度来播放。
()离散(Discrete)内插:动画函数将从一个值跳到下一个没有内插的值
()样条(Spline)内插:样条内插可用于达到更现实的计时效果
(四)样条内插中的KeySpline
()KeySpline作用:获取或设置用于定义此关键帧的动画进度的两个控制点。
()应用:KeySpline 来模拟下落的水滴或跳动的球等物体的物理轨迹。
a)"渐入"和"渐出"效果应用于动画。
b) 对于用户交互效果,例如背景淡入/淡出或控制按钮弹跳等
c)以便按照特定的方式来提高或降低动画的更改速率
()在该列中SplineDoubleKeyFrame KeySpline="0.6,0.0 0.9,0.00",这里的两个控制点为
(0.6,0.0)和(0.9,0.00)两个控制点
(五)组合内插方法:可以在单个关键帧动画中使用具有不同内插类型的关键帧(将以几个内插方法【线性、离散、样条】组合起来)
(六)缓动函数:以将自定义算术公式应用于动画。
-->
<DoubleAnimationUsingKeyFrames
Storyboard.TargetName="MyAnimatedTranslateTransform"
Storyboard.TargetProperty="X"
Duration="0:0:10">
<LinearDoubleKeyFrame Value="" KeyTime="0:0:3" />
<DiscreteDoubleKeyFrame Value="" KeyTime="0:0:4" />
<SplineDoubleKeyFrame KeySpline="0.6,0.0 0.9,0.00" Value="" KeyTime="0:0:6" />
</DoubleAnimationUsingKeyFrames>
</Storyboard>
</Canvas.Resources>
<Rectangle MouseLeftButtonDown="Mouse_Clicked" Fill="Blue" Width="" Height="">
<Rectangle.RenderTransform>
<TranslateTransform x:Name="MyAnimatedTranslateTransform" X="" Y="" />
</Rectangle.RenderTransform>
</Rectangle>
</Canvas>
</UserControl>

文章转自:http://www.cnblogs.com/Joetao/articles/2054005.html

Silverlight动画的基本知识、关键帧动画的更多相关文章

  1. Core Animation 动画的使用:关键帧动画、基础动画、动画组

    首先让我们了解下什么是 Core Animation,Core Animation 为核心动画,他为图形渲染和动画提供了基础.使用核心动画,我们只需要设置起点.终点.关键帧等一些参数,剩下的工作核心动 ...

  2. WPF中的动画——(五)关键帧动画

    与 From/To/By 动画类似,关键帧动画以也可以以动画形式显示目标属性值. 和From/To/By 动画不同的是, From/To/By 动画只能控制在两个状态之间变化,而关键帧动画则可以在多个 ...

  3. iOS block-base 动画简单用法+关键帧动画设置线性变化速度的问题

    本文转载至 http://www.tuicool.com/articles/aANBF3m 时间 2014-12-07 20:13:37  segmentfault-博客原文  http://segm ...

  4. Windows Store App 关键帧动画

    关键帧动画和插值动画类似,同样可以根据目标属性值的变化产生相应的动画效果,不同的是,插值动画是在两个属性值之间进行渐变,而关键帧动画打破了仅通过两个属性值控制动画的局限性,它可以在任意多个属性值之间进 ...

  5. ios基础动画、关键帧动画、动画组、转场动画等

    概览 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌.在这里你可以看到iOS中如何使用图层精简非交互式绘图,如何通过核心动画创建基础动画.关键帧动画 ...

  6. 背水一战 Windows 10 (14) - 动画: 线性动画, 关键帧动画

    [源码下载] 背水一战 Windows 10 (14) - 动画: 线性动画, 关键帧动画 作者:webabcd 介绍背水一战 Windows 10 之 动画 线性动画 - ColorAnimatio ...

  7. 核心动画基础动画(CABasicAnimation)关键帧动画

    1.在iOS中核心动画分为几类: 基础动画(CABasicAnimation) 关键帧动画(CAKeyframeAnimation) 动画组(CAAnimationGroup) 转场动画(CATran ...

  8. 【WPF学习】第五十四章 关键帧动画

    到目前为止,看到的所有动画都使用线性插值从起点到终点.但如果需要创建具有多个分段的动画和不规则移动的动画.例如,可能希望创建一个动画,快速地将一个元素滑入到视图中,然后慢慢地将它移到正确位置.可通过创 ...

  9. Windows Phone开发(39):漫谈关键帧动画上篇

    原文:Windows Phone开发(39):漫谈关键帧动画上篇 尽管前面介绍的几种动画会让觉得很好玩了,但是,不知道你是否发现,在前面说到的一系列XXXAnimation中,都有一个共同点,那就是仅 ...

随机推荐

  1. jQuery的如何捕捉回车键,改变事件标签

    我希望有一个jQuery的解决方案,我必须接近,有什么需要做的? $('html').bind('keypress', function(e) { if(e.keyCode == 13) { retu ...

  2. Code Jam 2008 APAC local onsites Problem C. Millionaire —— 概率DP

    题意: 你有X元钱,进行M轮赌博游戏.每一轮可以将所持的任意一部分钱作为赌注(赌注为0元表示这一轮不押),赌注可以是小数的,不是一定要整数.每一轮 赢的概率为P,赢了赌注翻倍,输了赌注就没了.如果你最 ...

  3. 1.6.1 什么是 Indexing

    这部分描述了建立索引的过程:添加内容到solr索引中,如果有需要,修改内容或者删除它.通过添加内容到索引里边,我们使其内容可以搜索. solr索引能够接收不同来源的数据,xml文件,逗号分隔值的(CV ...

  4. 1.4.2 solr字段类型--(1.4.2.4)使用Dates(日期)

    1.4.2 solr字段类型 (1.4.2.1) 字段类型定义和字段类型属性. (1.4.2.2) solr附带的字段类型 (1.4.2.3) 使用货币和汇率 (1.4.2.4) 使用Dates(日期 ...

  5. The requested URL Not Found问题

    遇到这么一个问题: 最近刚转到linux下工作 在本地运行localhost下的thinkphp程序时,出现 一开始以为是权限问题,把目录以及文件权限都改为777依然不起作用 后来发现是rewrite ...

  6. 关于ios项目沙盒中的文件和Xcode项目创建的文件

    //1.1获取在Xcode项目打开的情况下创建的Plist文件 NSString *path = [[NSBundle mainBundle]pathForResource:@"Profes ...

  7. H5入门-xhtml+css2-第01节

    <!-- 声明版本号,DOCTYPE html是html5版本 --> <!DOCTYPE html> <!-- 声明网页语言 en-英文 zh-中文 zh-cn中文 - ...

  8. [CAMCOCO][C#]我的系统架构 总图

    之前写的感觉有点乱,把架构的设计图先放上来吧,对照着说. CAMCOCO架构能够支持的模型: 1.B/S程序,比如CRM什么的,和访问普通网站没什么区别,都是从WEB服务器上进行操作: 2.APP的服 ...

  9. 跟我一起学习ASP.NET 4.5 MVC4.0(一)(转)

    由于上面一个项目使用的是ASP.NET4.0 MVC3.0,在招人的时候发现很多人有听说过MVC,但是却是没用过,对MVC也只是一知半解,最近想给团队成员做一个系统的解说,让大家都可以学习一下ASP. ...

  10. Android实现抽奖转盘

    一.SurfaceView认识及的应用的思路 SurfaceView继承自(extends)View,View是在UI线程中进行绘制: 而SurfaceView是在一个子线程中对自己进行绘制,优势:避 ...