• 稳扎稳打Silverlight(37) 3.0动画之Easing(缓动效果)


    [索引页]
    [源码下载]


    稳扎稳打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
    http://www.cnblogs.com/webabcd/archive/2009/08/04/1538238.html


    示例
    1、Silverlight 3.0 内置的 11 种缓动效果的 Demo
    Easing.xaml
    <navigation:Page x:Class="Silverlight30.Animation.Easing" 
               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"
               xmlns:navigation
    ="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
               d:DesignWidth
    ="640" d:DesignHeight="480"
               Title
    ="Easing Page">
        
    <Grid x:Name="LayoutRoot">
            
    <StackPanel Orientation="Horizontal" HorizontalAlignment="Left">

                
    <!--用于显示各种 Easing 的图例列表-->
                
    <StackPanel Margin="10">
                    
    <ListBox x:Name="lstEasing">
                        
    <ListBox.ItemTemplate>
                            
    <DataTemplate>
                                
    <StackPanel Margin="1">
                                    
    <TextBlock Text="{Binding EasingName}" />
                                    
    <Image Source="{Binding PicAddress}" Width="300" Height="50" />
                                
    </StackPanel>
                            
    </DataTemplate>
                        
    </ListBox.ItemTemplate>
                    
    </ListBox>
                
    </StackPanel>

                
    <StackPanel Margin="10, 200">
               
                    
    <!--分别用 3 种动画来演示各类 Easing-->
                    
    <ComboBox x:Name="cboTransform" Margin="5">
                        
    <ComboBoxItem Content="Translate" IsSelected="True" />
                        
    <ComboBoxItem Content="Rotate" />
                        
    <ComboBoxItem Content="Scale" />
                    
    </ComboBox>
                    
                    
    <!--用各种 EasingMode 分别做演示-->
                    
    <ComboBox x:Name="cboEasingMode" Margin="5">
                        
    <ComboBoxItem Content="EaseOut" IsSelected="True" />
                        
    <ComboBoxItem Content="EaseIn" />
                        
    <ComboBoxItem Content="EaseInOut" />
                    
    </ComboBox>

                    
    <Button x:Name="btnShow" Content="演示" Click="btnShow_Click" Margin="5" />

                    
    <!--用于做动画演示的矩形-->
                    
    <Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
                        
    <Rectangle.RenderTransform>
                            
    <TransformGroup>
                                
    <TranslateTransform x:Name="tt" X="0" Y="0" />
                                
    <RotateTransform x:Name="rt" Angle="0" />
                                
    <ScaleTransform x:Name="st" ScaleX="1" ScaleY="1" />
                            
    </TransformGroup>
                        
    </Rectangle.RenderTransform>
                    
    </Rectangle>

                
    </StackPanel>
            
    </StackPanel>
        
    </Grid>
    </navigation:Page>

    Easing.xaml.cs
    /*
     * 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)
     
    */


    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;
    using System.Windows.Navigation;

    using Silverlight30.Model;
    using System.Xml.Linq;

    namespace Silverlight30.Animation
    {
        
    public partial class Easing : Page
        
    {
            
    public Easing()
            
    {
                InitializeComponent();

                
    this.Loaded += new RoutedEventHandler(Easing_Loaded);
            }


            
    // 绑定各种 Easing 的图例列表
            void Easing_Loaded(object sender, RoutedEventArgs e)
            
    {
                XElement root 
    = XElement.Load("Animation/Easing.xml");
                var easings 
    = from n in root.Elements("easing")
                              select 
    new EasingModel
                              
    {
                                  EasingName 
    = (string)n.Attribute("EasingName"),
                                  Description 
    = (string)n.Attribute("Description"),
                                  PicAddress 
    = (string)n.Attribute("PicAddress")
                              }
    ;

                lstEasing.ItemsSource 
    = easings;
                lstEasing.SelectedIndex 
    = 0;
            }


            
    private Storyboard _prevStoryboard;

            
    private void btnShow_Click(object sender, RoutedEventArgs e)
            
    {
                
    if (_prevStoryboard != null)
                    _prevStoryboard.Stop();

                
    // 实例化用户所选择的 Easing
                Type type = typeof(EasingFunctionBase).Assembly.GetType("System.Windows.Media.Animation." + ((EasingModel)lstEasing.SelectedItem).EasingName, false);
                EasingFunctionBase easing 
    = Activator.CreateInstance(type) as EasingFunctionBase;

                
    // 根据用户的选择,设置 Easing 的 EasingMode 属性
                easing.EasingMode = (EasingMode)Enum.Parse(typeof(EasingMode), ((ComboBoxItem)cboEasingMode.SelectedItem).Content.ToString(), true);

                Storyboard sb 
    = new Storyboard();
                _prevStoryboard 
    = sb;

                var transformType 
    = ((ComboBoxItem)cboTransform.SelectedItem).Content.ToString();
                
    switch (transformType)
                
    {
                    
    // 位移动画结合 Easing 的演示
                    case "Translate":
                        DoubleAnimation daTranslateY 
    = new DoubleAnimation();
                        daTranslateY.From 
    = 0 ;
                        daTranslateY.To 
    = 200;
                        daTranslateY.Duration 
    = TimeSpan.FromSeconds(3);

                        daTranslateY.EasingFunction 
    = easing;

                        Storyboard.SetTargetProperty(daTranslateY, 
    new PropertyPath("Y"));
                        Storyboard.SetTarget(daTranslateY, tt);

                        sb.Children.Add(daTranslateY);

                        
    break;
                    
    // 缩放动画结合 Easing 的演示
                    case "Scale":
                        DoubleAnimation daScaleX 
    = new DoubleAnimation();
                        daScaleX.From 
    = 1;
                        daScaleX.To 
    = 2;
                        daScaleX.Duration 
    = TimeSpan.FromSeconds(3);

                        DoubleAnimation daScaleY 
    = new DoubleAnimation();
                        daScaleY.From 
    = 1;
                        daScaleY.To 
    = 2;
                        daScaleY.Duration 
    = TimeSpan.FromSeconds(3);

                        daScaleX.EasingFunction 
    = easing;
                        daScaleY.EasingFunction 
    = easing;

                        Storyboard.SetTargetProperty(daScaleX, 
    new PropertyPath("ScaleX"));
                        Storyboard.SetTarget(daScaleX, st);
                        Storyboard.SetTargetProperty(daScaleY, 
    new PropertyPath("ScaleY"));
                        Storyboard.SetTarget(daScaleY, st);

                        sb.Children.Add(daScaleX);
                        sb.Children.Add(daScaleY);

                        
    break;
                    
    // 旋转动画结合 Easing 的演示
                    case "Rotate":
                        DoubleAnimation daAngle 
    = new DoubleAnimation();
                        daAngle.To 
    = 0;
                        daAngle.To 
    = 360;
                        daAngle.Duration 
    = TimeSpan.FromSeconds(3);

                        daAngle.EasingFunction 
    = easing;

                        Storyboard.SetTargetProperty(daAngle, 
    new PropertyPath("Angle"));
                        Storyboard.SetTarget(daAngle, rt);

                        sb.Children.Add(daAngle);

                        
    break;
                }

       
                sb.Begin();
            }

        }

    }



    2、自定义缓动效果的 Demo
    MyCustomEasing.cs
    using System;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Ink;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;

    namespace Silverlight30.Animation
    {
        
    /// <summary>
        
    /// 自定义缓动效果
        
    /// </summary>

        public class MyCustomEasing : EasingFunctionBase
        
    {
            
    public MyCustomEasing()
                : 
    base()
            
    {
     
            }


            
    /// <summary>
            
    /// 实现 EaseIn 模式下的逻辑
            
    /// EaseOut 和 EaseInOut 会自动实现
            
    /// </summary>
            
    /// <param name="normalizedTime">标准时间位(0 - 1之间)。即 动画运行到此的时间 占 动画运行所需的全部时间 的百分比</param>
            
    /// <returns></returns>

            protected override double EaseInCore(double normalizedTime)
            
    {
                
    // QuinticEase 效果的实现算法

                
    // 假定动画运行的总共时间为 1 秒
                
    // 那么当 normalizedTime 为 0.1 时,动画运行到的位置为无该缓动效果时,0.00001秒后的位置。以此类推
                return Math.Pow(normalizedTime, 5);
            }

        }

    }


    CustomEasing.xaml
    <navigation:Page x:Class="Silverlight30.Animation.CustomEasing" 
               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"
               xmlns:custom
    ="clr-namespace:Silverlight30.Animation"
               xmlns:navigation
    ="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
               d:DesignWidth
    ="640" d:DesignHeight="480"
               Title
    ="CustomEasing Page">
        
    <Grid x:Name="LayoutRoot">
            
    <StackPanel>
            
                
    <StackPanel.Resources>
                    
    <Storyboard x:Name="ani">
                        
    <DoubleAnimation 
                            
    Storyboard.TargetName="tt"
                            Storyboard.TargetProperty
    ="Y"
                            From
    ="0" 
                            To
    ="200" 
                            Duration
    ="00:00:03"
                        
    >
                            
    <DoubleAnimation.EasingFunction>
                                
    <!--使用自定义的缓动效果-->
                                
    <custom:MyCustomEasing EasingMode="EaseOut" />
                            
    </DoubleAnimation.EasingFunction>
                        
    </DoubleAnimation>
                    
    </Storyboard>
                
    </StackPanel.Resources>

                
    <Button x:Name="btnShow" Content="演示" Margin="5" Click="btnShow_Click" />

                
    <Rectangle x:Name="rect" Fill="Blue" Width="200" Height="40" Margin="5" RenderTransformOrigin="0.5,0.5">
                    
    <Rectangle.RenderTransform>
                        
    <TransformGroup>
                            
    <TranslateTransform x:Name="tt" X="0" Y="0" />
                        
    </TransformGroup>
                    
    </Rectangle.RenderTransform>
                
    </Rectangle>
                
            
    </StackPanel>
        
    </Grid>
    </navigation:Page>

    CustomEasing.xaml.cs
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Shapes;
    using System.Windows.Navigation;

    namespace Silverlight30.Animation
    {
        
    public partial class CustomEasing : Page
        
    {
            
    public CustomEasing()
            
    {
                InitializeComponent();
            }


            
    private void btnShow_Click(object sender, RoutedEventArgs e)
            
    {
                ani.Begin();
            }

        }

    }



    OK
    [源码下载]
  • 相关阅读:
    iOS开发中常见错误总结(1)
    iOS开发——OC篇&纯代码退出键盘
    获取下拉框
    @RequestBody 注解
    form 表单提交
    数据库excel导出
    状态模式
    图书网上商城实现(一)
    MongoDB(一)—— 搭建环境和启动服务
    MySQL开发遇到的问题
  • 原文地址:https://www.cnblogs.com/webabcd/p/1550334.html
Copyright © 2020-2023  润新知