稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
2011-11-28 15:59
316 查看
[索引页]
[源码下载]
稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
作者:webabcd
介绍
Silverlight
3.0 动画的缓动效果:
Easing 可以与 Storyboard 结合实现动画的缓动效果
Silverlight 3 内置 11 种缓动效果:分别为BackEase, BounceEase, CircleEase, CubicEase, ElasticEase, ExponentialEase, PowerEase, QuadraticEase, QuarticEase, QuinticEase, SineEase
各个缓动类都继承自 EasingFunctionBase,除了 EasingFunctionBase 提供的功能外,各个缓动类可能还会有各自的属性(懒的写了,查文档吧)
EasingFunctionBase 有一个用于设置缓动模式的枚举类型属性 EasingMode (EasingMode.EaseOut(默认值), EasingMode.EaseIn, EasingMode.EaseInOut)
在线DEMO
/article/4589629.html
示例
1、Silverlight
3.0 内置的 11 种缓动效果的 Demo
Easing.xaml
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<navigation:Page x:Class="Silverlight30.Animation.Easing"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
mc:Ignorable="d"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
d:DesignWidth="640" d:DesignHeight="480"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Title="Easing Page">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Grid x:Name="LayoutRoot">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Orientation="Horizontal" HorizontalAlignment="Left">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用于显示各种 Easing 的图例列表-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="10">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ListBox x:Name="lstEasing">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ListBox.ItemTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DataTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="1">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TextBlock Text="{Binding EasingName}" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Image Source="{Binding PicAddress}" Width="300" Height="50" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DataTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ListBox.ItemTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ListBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="10, 200">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--分别用 3 种动画来演示各类 Easing-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBox x:Name="cboTransform" Margin="5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Translate" IsSelected="True" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Rotate" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Scale" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ComboBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用各种 EasingMode 分别做演示-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBox x:Name="cboEasingMode" Margin="5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseOut" IsSelected="True" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseIn" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseInOut" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ComboBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Button x:Name="btnShow" Content="演示" Click="btnShow_Click" Margin="5" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用于做动画演示的矩形-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TranslateTransform x:Name="tt" X="0" Y="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<RotateTransform x:Name="rt" Angle="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ScaleTransform x:Name="st" ScaleX="1" ScaleY="1" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Grid>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</navigation:Page>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Easing.xaml.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
/*
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* Easing - 与 Storyboard 结合实现动画的缓动效果
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* Silverlight 3 内置 11 种缓动效果:分别为BackEase, BounceEase, CircleEase, CubicEase, ElasticEase, ExponentialEase, PowerEase, QuadraticEase, QuarticEase, QuinticEase, SineEase
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* 各个缓动类都继承自 EasingFunctionBase,除了 EasingFunctionBase 提供的功能外,各个缓动类可能还会有各自的属性(懒的写了,查文档吧)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* EasingFunctionBase 有一个用于设置缓动模式的枚举类型属性 EasingMode (EasingMode.EaseOut(默认值), EasingMode.EaseIn, EasingMode.EaseInOut)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
*/
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Collections.Generic;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Navigation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using Silverlight30.Model;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Xml.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public partial class Easing : Page
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public Easing()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
InitializeComponent();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
this.Loaded += new RoutedEventHandler(Easing_Loaded);
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 绑定各种 Easing 的图例列表
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
void Easing_Loaded(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
XElement root = XElement.Load("Animation/Easing.xml");
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
var easings = from n in root.Elements("easing")
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
select new EasingModel
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
EasingName = (string)n.Attribute("EasingName"),
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Description = (string)n.Attribute("Description"),
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
PicAddress = (string)n.Attribute("PicAddress")
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
};
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
lstEasing.ItemsSource = easings;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
lstEasing.SelectedIndex = 0;
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private Storyboard _prevStoryboard;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private void btnShow_Click(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
if (_prevStoryboard != null)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
_prevStoryboard.Stop();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 实例化用户所选择的 Easing
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Type type = typeof(EasingFunctionBase).Assembly.GetType("System.Windows.Media.Animation." + ((EasingModel)lstEasing.SelectedItem).EasingName, false);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
EasingFunctionBase easing = Activator.CreateInstance(type) as EasingFunctionBase;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 根据用户的选择,设置 Easing 的 EasingMode 属性
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
easing.EasingMode = (EasingMode)Enum.Parse(typeof(EasingMode), ((ComboBoxItem)cboEasingMode.SelectedItem).Content.ToString(), true);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard sb = new Storyboard();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
_prevStoryboard = sb;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
var transformType = ((ComboBoxItem)cboTransform.SelectedItem).Content.ToString();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
switch (transformType)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 位移动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Translate":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daTranslateY = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.From = 0 ;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.To = 200;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daTranslateY, new PropertyPath("Y"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daTranslateY, tt);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daTranslateY);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 缩放动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Scale":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daScaleX = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.From = 1;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.To = 2;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daScaleY = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.From = 1;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.To = 2;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daScaleX, new PropertyPath("ScaleX"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daScaleX, st);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daScaleY, new PropertyPath("ScaleY"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daScaleY, st);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daScaleX);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daScaleY);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 旋转动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Rotate":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daAngle = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.To = 0;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.To = 360;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daAngle, new PropertyPath("Angle"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daAngle, rt);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daAngle);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Begin();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
2、自定义缓动效果的
Demo
MyCustomEasing.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Ink;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
/// <summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// 自定义缓动效果
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
/// </summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public class MyCustomEasing : EasingFunctionBase
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public MyCustomEasing()
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
: base()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
/// <summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// 实现 EaseIn 模式下的逻辑
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// EaseOut 和 EaseInOut 会自动实现
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// </summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// <param name="normalizedTime">标准时间位(0 - 1之间)。即 动画运行到此的时间 占 动画运行所需的全部时间 的百分比</param>
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
/// <returns></returns>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
protected override double EaseInCore(double normalizedTime)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// QuinticEase 效果的实现算法
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 假定动画运行的总共时间为 1 秒
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 那么当 normalizedTime 为 0.1 时,动画运行到的位置为无该缓动效果时,0.00001秒后的位置。以此类推
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
return Math.Pow(normalizedTime, 5);
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
CustomEasing.xaml
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<navigation:Page x:Class="Silverlight30.Animation.CustomEasing"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
mc:Ignorable="d"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:custom="clr-namespace:Silverlight30.Animation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
d:DesignWidth="640" d:DesignHeight="480"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Title="CustomEasing Page">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Grid x:Name="LayoutRoot">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel.Resources>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Storyboard x:Name="ani">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DoubleAnimation
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Storyboard.TargetName="tt"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Storyboard.TargetProperty="Y"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
From="0"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
To="200"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Duration="00:00:03"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DoubleAnimation.EasingFunction>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--使用自定义的缓动效果-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<custom:MyCustomEasing EasingMode="EaseOut" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DoubleAnimation.EasingFunction>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DoubleAnimation>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Storyboard>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel.Resources>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Button x:Name="btnShow" Content="演示" Margin="5" Click="btnShow_Click" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TranslateTransform x:Name="tt" X="0" Y="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Grid>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</navigation:Page>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
CustomEasing.xaml.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Collections.Generic;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Navigation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public partial class CustomEasing : Page
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public CustomEasing()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
InitializeComponent();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private void btnShow_Click(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
ani.Begin();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
OK
[源码下载]
[源码下载]
稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
作者:webabcd
介绍
Silverlight
3.0 动画的缓动效果:
Easing 可以与 Storyboard 结合实现动画的缓动效果
Silverlight 3 内置 11 种缓动效果:分别为BackEase, BounceEase, CircleEase, CubicEase, ElasticEase, ExponentialEase, PowerEase, QuadraticEase, QuarticEase, QuinticEase, SineEase
各个缓动类都继承自 EasingFunctionBase,除了 EasingFunctionBase 提供的功能外,各个缓动类可能还会有各自的属性(懒的写了,查文档吧)
EasingFunctionBase 有一个用于设置缓动模式的枚举类型属性 EasingMode (EasingMode.EaseOut(默认值), EasingMode.EaseIn, EasingMode.EaseInOut)
在线DEMO
/article/4589629.html
示例
1、Silverlight
3.0 内置的 11 种缓动效果的 Demo
Easing.xaml
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<navigation:Page x:Class="Silverlight30.Animation.Easing"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
mc:Ignorable="d"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
d:DesignWidth="640" d:DesignHeight="480"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Title="Easing Page">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Grid x:Name="LayoutRoot">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Orientation="Horizontal" HorizontalAlignment="Left">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用于显示各种 Easing 的图例列表-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="10">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ListBox x:Name="lstEasing">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ListBox.ItemTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DataTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="1">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TextBlock Text="{Binding EasingName}" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Image Source="{Binding PicAddress}" Width="300" Height="50" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DataTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ListBox.ItemTemplate>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ListBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel Margin="10, 200">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--分别用 3 种动画来演示各类 Easing-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBox x:Name="cboTransform" Margin="5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Translate" IsSelected="True" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Rotate" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="Scale" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ComboBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用各种 EasingMode 分别做演示-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBox x:Name="cboEasingMode" Margin="5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseOut" IsSelected="True" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseIn" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ComboBoxItem Content="EaseInOut" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</ComboBox>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Button x:Name="btnShow" Content="演示" Click="btnShow_Click" Margin="5" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--用于做动画演示的矩形-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TranslateTransform x:Name="tt" X="0" Y="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<RotateTransform x:Name="rt" Angle="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<ScaleTransform x:Name="st" ScaleX="1" ScaleY="1" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Grid>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</navigation:Page>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Easing.xaml.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
/*
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* Easing - 与 Storyboard 结合实现动画的缓动效果
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* Silverlight 3 内置 11 种缓动效果:分别为BackEase, BounceEase, CircleEase, CubicEase, ElasticEase, ExponentialEase, PowerEase, QuadraticEase, QuarticEase, QuinticEase, SineEase
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* 各个缓动类都继承自 EasingFunctionBase,除了 EasingFunctionBase 提供的功能外,各个缓动类可能还会有各自的属性(懒的写了,查文档吧)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
* EasingFunctionBase 有一个用于设置缓动模式的枚举类型属性 EasingMode (EasingMode.EaseOut(默认值), EasingMode.EaseIn, EasingMode.EaseInOut)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
*/
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Collections.Generic;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Navigation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using Silverlight30.Model;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Xml.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public partial class Easing : Page
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public Easing()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
InitializeComponent();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
this.Loaded += new RoutedEventHandler(Easing_Loaded);
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 绑定各种 Easing 的图例列表
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
void Easing_Loaded(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
XElement root = XElement.Load("Animation/Easing.xml");
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
var easings = from n in root.Elements("easing")
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
select new EasingModel
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
EasingName = (string)n.Attribute("EasingName"),
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Description = (string)n.Attribute("Description"),
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
PicAddress = (string)n.Attribute("PicAddress")
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
};
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
lstEasing.ItemsSource = easings;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
lstEasing.SelectedIndex = 0;
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private Storyboard _prevStoryboard;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private void btnShow_Click(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
if (_prevStoryboard != null)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
_prevStoryboard.Stop();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 实例化用户所选择的 Easing
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Type type = typeof(EasingFunctionBase).Assembly.GetType("System.Windows.Media.Animation." + ((EasingModel)lstEasing.SelectedItem).EasingName, false);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
EasingFunctionBase easing = Activator.CreateInstance(type) as EasingFunctionBase;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 根据用户的选择,设置 Easing 的 EasingMode 属性
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
easing.EasingMode = (EasingMode)Enum.Parse(typeof(EasingMode), ((ComboBoxItem)cboEasingMode.SelectedItem).Content.ToString(), true);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard sb = new Storyboard();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
_prevStoryboard = sb;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
var transformType = ((ComboBoxItem)cboTransform.SelectedItem).Content.ToString();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
switch (transformType)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 位移动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Translate":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daTranslateY = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.From = 0 ;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.To = 200;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daTranslateY.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daTranslateY, new PropertyPath("Y"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daTranslateY, tt);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daTranslateY);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 缩放动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Scale":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daScaleX = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.From = 1;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.To = 2;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daScaleY = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.From = 1;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.To = 2;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleX.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daScaleY.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daScaleX, new PropertyPath("ScaleX"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daScaleX, st);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daScaleY, new PropertyPath("ScaleY"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daScaleY, st);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daScaleX);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daScaleY);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 旋转动画结合 Easing 的演示
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
case "Rotate":
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
DoubleAnimation daAngle = new DoubleAnimation();
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.To = 0;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.To = 360;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.Duration = TimeSpan.FromSeconds(3);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
daAngle.EasingFunction = easing;
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTargetProperty(daAngle, new PropertyPath("Angle"));
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
Storyboard.SetTarget(daAngle, rt);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Children.Add(daAngle);
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
break;
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
sb.Begin();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
2、自定义缓动效果的
Demo
MyCustomEasing.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Ink;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
/// <summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// 自定义缓动效果
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
/// </summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public class MyCustomEasing : EasingFunctionBase
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public MyCustomEasing()
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
: base()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
/// <summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// 实现 EaseIn 模式下的逻辑
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// EaseOut 和 EaseInOut 会自动实现
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// </summary>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
/// <param name="normalizedTime">标准时间位(0 - 1之间)。即 动画运行到此的时间 占 动画运行所需的全部时间 的百分比</param>
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
/// <returns></returns>
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
protected override double EaseInCore(double normalizedTime)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// QuinticEase 效果的实现算法
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 假定动画运行的总共时间为 1 秒
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
// 那么当 normalizedTime 为 0.1 时,动画运行到的位置为无该缓动效果时,0.00001秒后的位置。以此类推
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
return Math.Pow(normalizedTime, 5);
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
CustomEasing.xaml
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<navigation:Page x:Class="Silverlight30.Animation.CustomEasing"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
mc:Ignorable="d"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:custom="clr-namespace:Silverlight30.Animation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
d:DesignWidth="640" d:DesignHeight="480"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Title="CustomEasing Page">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Grid x:Name="LayoutRoot">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<StackPanel.Resources>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Storyboard x:Name="ani">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DoubleAnimation
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Storyboard.TargetName="tt"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Storyboard.TargetProperty="Y"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
From="0"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
To="200"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
Duration="00:00:03"
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<DoubleAnimation.EasingFunction>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<!--使用自定义的缓动效果-->
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<custom:MyCustomEasing EasingMode="EaseOut" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DoubleAnimation.EasingFunction>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</DoubleAnimation>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Storyboard>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel.Resources>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Button x:Name="btnShow" Content="演示" Margin="5" Click="btnShow_Click" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
<TranslateTransform x:Name="tt" X="0" Y="0" />
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</TransformGroup>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle.RenderTransform>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Rectangle>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</StackPanel>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</Grid>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
</navigation:Page>
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
CustomEasing.xaml.cs
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Collections.Generic;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Linq;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Net;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Controls;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Documents;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Input;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Media.Animation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Shapes;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
using System.Windows.Navigation;
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
namespace Silverlight30.Animation
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public partial class CustomEasing : Page
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
public CustomEasing()
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
InitializeComponent();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
private void btnShow_Click(object sender, RoutedEventArgs e)
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockStart.gif)
{
![](http://www.cnblogs.com/Images/OutliningIndicators/InBlock.gif)
ani.Begin();
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedSubBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/ExpandedBlockEnd.gif)
}
![](http://www.cnblogs.com/Images/OutliningIndicators/None.gif)
OK
[源码下载]
相关文章推荐
- 稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
- 稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
- 稳扎稳打Silverlight(37) - 3.0动画之Easing(缓动效果)
- 稳扎稳打Silverlight(38) - 3.0滤镜之BlurEffect, DropShadowEffect, 自定义滤镜, 3D效果之PlaneProjection, 位图API之WriteableBitmap
- 稳扎稳打Silverlight(38) - 3.0滤镜之BlurEffect, DropShadowEffect, 自定义滤镜, 3D效果之PlaneProjection, 位图API之WriteableBitmap
- 稳扎稳打Silverlight(38) - 3.0滤镜之BlurEffect, DropShadowEffect, 自定义滤镜, 3D效果之PlaneProjection, 位图API之Writeab
- 积少成多Flash(12) - Flex 3.0 验证控件(Validator), 缓动效果(easing)
- 积少成多Flash(12) - Flex 3.0 验证控件(Validator), 缓动效果(easing)
- 积少成多Flash(12) - Flex 3.0 验证控件(Validator), 缓动效果(easing)
- 译文:Silverlight 3.0 新功能之二 : 动画缓冲(Animation Easing)
- 稳扎稳打Silverlight(35) - 3.0控件之ChildWindow, SaveFileDialog, HeaderedItemsControl
- 稳扎稳打Silverlight(36) - 3.0控件之TreeView, ListBox增强, DataGrid增强, MediaElement增强
- Silverlight & Blend动画设计系列七:模糊效果(BlurEffect)与阴影效果(DropShadowEffect)
- 稳扎稳打Silverlight(39) - 3.0通信之二进制XML通信, 本地连接
- [ActionScript 3.0] AS3 用于拖动对象时跟随鼠标的缓动效果
- Unity引擎模拟实现HTML5 animation 动画效果,取代NGUI的Tweener缓动
- Silverlight学习笔记--动画效果-- 关键帧动画
- 过渡与动画 - 缓动效果&基于贝塞尔曲线的调速函数
- 超炫,超酷的silverlight 动画效果
- Silverlight 动画效果1 -- 旋转