WPF与缓动(二) 正弦与余弦缓动

如果要比二次缓动(请参见WPF与缓动(一) N次缓动)更平缓, 可以使用正弦或余弦缓动.


如果我们用曲线上点的斜率表示速度,可以发现,由0到PI/2,速度逐渐减小,从PI/2到PI速度逐渐增加.

我们可以总结出如下公式


其中位置的改变量相当于Animation中的To与From的差值, t/t(总)相当于animationClock.CurrentProgress.Value, b实际就是From值

参考如下代码:

using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Media.Animation;
using System.Windows;

namespace EaseMoveDemo
{
  public class EaseMoveAnimation : DoubleAnimationBase
  {

    public static readonly DependencyProperty FromProperty = DependencyProperty.Register(
      "From", typeof(double?), typeof(EaseMoveAnimation), new PropertyMetadata(null));

    public static readonly DependencyProperty ToProperty = DependencyProperty.Register(
      "To", typeof(double?), typeof(EaseMoveAnimation), new PropertyMetadata(null));

    public double? From
    {
      get
      {
        return (double?)this.GetValue(EaseMoveAnimation.FromProperty);
      }
      set
      {
        this.SetValue(EaseMoveAnimation.FromProperty, value);
      }
    }

    public double? To
    {
      get
      {
        return (double?)this.GetValue(EaseMoveAnimation.ToProperty);
      }
      set
      {
        this.SetValue(EaseMoveAnimation.ToProperty, value);
      }
    }

    //正余弦缓动
    protected override double GetCurrentValueCore(double defaultOriginValue, double defaultDestinationValue, AnimationClock animationClock)
    {
      double from = (this.From==null?defaultDestinationValue:(double)this.From);
      double to = (this.To==null?defaultOriginValue:(double)this.To);
      double delta = to - from;

      //加速
      //return delta * (1 - Math.Cos(Math.PI / 2 * animationClock.CurrentProgress.Value)) + from;

      //减速
      //return delta * Math.Sin(Math.PI / 2 * animationClock.CurrentProgress.Value) + from;

      //先加速,后减速
      return delta/2 * (1 - Math.Cos(Math.PI * animationClock.CurrentProgress.Value)) + from;

    }

    protected override System.Windows.Freezable CreateInstanceCore()
    {
      return new EaseMoveAnimation();
    }
  }
}

本文配套源码

时间: 2024-08-03 19:13:06

WPF与缓动(二) 正弦与余弦缓动的相关文章

Android高级控件(二)——SurfaceView实现GIF动画架包,播放GIF动画,自己实现功能的初体现

Android高级控件(二)--SurfaceView实现GIF动画架包,播放GIF动画,自己实现功能的初体现 写这个的原因呢,也是因为项目中用到了gif动画,虽然网上有很多的架包可以实现,不过我们还是要追究一下原理怎么做的,我们新建一个GifLibrary,然后右键Properties--Android,我们把架包勾上 然后我们新建一个类GifSurfaceView继承自SurfaceView并且实现它的Callback接口 GifSurfaceView package com.lgl.gif

WPF入门教程系列二——Application介绍

原文:WPF入门教程系列二--Application介绍 一.Application介绍 WPF和WinForm 很相似, WPF与WinForm一样有一个 Application对象来进行一些全局的行为和操作,并且每个 Domain (应用程序域)中仅且只有一个 Application 实例存在.和 WinForm 不同的是WPF Application默认由两部分组成 : App.xaml 和 App.xaml.cs,这有点类似于 Asp.Net WebForm,将定义和行为代码相分离. 微

WPF换肤之二:可拉动的窗体

原文:WPF换肤之二:可拉动的窗体 让我们接着上一章: WPF换肤之一:创建圆角窗体 来继续. 在这一章,我主要是实现对圆角窗体的拖动,改变大小功能. 拖动自绘窗体的步骤 首先,通过上节的设计,我们知道了如何设计一个圆角窗体,通过XAML代码量,我们发现设置这个窗体是多么的简单.但是如何让窗体能够进行Resize呢? 在Winform时代,我们通过WndProc(ref Message m)处理窗体界面消息来实现,那么在WPF中是否也是如此呢? 其实在WPF中,虽说封装比较紧密,但是对于处理界面

WPF命中测试示例(二)——几何区域命中测试

原文:WPF命中测试示例(二)--几何区域命中测试 接续上次的命中测试,这次来做几何区域测试示例.   示例 首先新建一个WPF项目,在主界面中拖入一个按钮控件,并修改代码中的以下高亮位置: 当前设计视图界面如下: 接下来,转到窗体的"Window_Loaded"事件处理函数,编写函数代码: private void Window_Loaded(object sender, RoutedEventArgs e) { Random r = new Random(); for (int i

用动效创建的可用性:动效中的用户体验宣言

本文讲的是用动效创建的可用性:动效中的用户体验宣言, 原文作者:Issara Willenskomer 译文出自:掘金翻译计划 译者:Ruixi 校对者:cdpath,osirism 用动效创建的可用性:动效中的用户体验宣言 下面这段宣言即是我对这个问题的回答--"作为一个UX或者UI设计师,在界面中,如何在合适的时间和位置通过动效的使用来支持可用性呢?" 在过去的5年中,我有幸指导过来自40多个国家的 UX 和 UI 设计师,而且我为这些顶级品牌和设计咨询公司带来的建议和指导基本上都

卷动的菜单的实现,点击卷动标题,显示对应卷动的工具

问题描述 卷动的菜单的实现,点击卷动标题,显示对应卷动的工具 卷动的菜单的实现,点击卷动标题,显示对应卷动的工具,可以点击标题切换,就像VB的Toolbox一样? 解决方案 用verticalmenu实现.http://download.csdn.net/detail/doudouxiaoyi/759031

动漫产业“风光无限”杭州动漫市场任重道远

相关作品:第六届中国国际动漫节已在杭州完美收官,无论是空前巨大规模,还是背后整个动漫产业的深层发展,用"风光无限"来形容杭州当前的动漫产业,恰如其分. 可以说,这些年国内动漫产业遇上了最好的年代.首先是政策支持,在举国建设创新型国家的大背景下,发展包括动漫在内的创意产业无疑如沐春风,从珠三角到长三角,从环渤海到中西部,各地方政府积极将动漫产业列为蓝海战略,动漫基地如雨后春笋般次第而出.杭州动漫产业起步不算最早,但政企齐心合力,发展势头迅猛,已成功举办六届中国国际动漫节,且中国国际动漫节

云计算落地陕西动漫产业平台 引领陕西动漫3D时代

9月21日上午,由陕西动漫产业平台管理管理中心和太平洋电信联合主办,中国IDC圈协办的"2011年陕西动漫产业平台云应用与创新研讨会"在陕西动漫产业平台5楼会议中心盛大举行.陕西省发改委 .陕西省科技厅.陕西省工业和信息化厅.陕西省商务厅陕西省文化厅.西安市科技局.西安市发改委.西安市工信局.西安市商务部.西安市文化广播新闻出版局等相关部门领导.知名专家学者以及部分动漫企业代表参加了研讨会. 随着计算机技术及多媒体技术的进步,影视动漫行业越来越追求特效所占的比重,画面效果越来越细腻.震

动视CEO称Bungie选择动视签约是“别无选择”

9月17日最新消息,动视CEO Bobby Kotick昨日在参加德国银行2010技术大会上表示,Bungie选择动视签约是"别无选择",他们将会为后者提供所有的顶尖支持,以帮助他们的新作能够获得成功. "当他们想再创作出一部如<光环>般伟大的作品时,他们需要一些世界上最顶尖和先进的技术和服务,"Bobby Kotick,"于是他们在候选名单中发现没有任何其他公司能够像动视这样拥有这些,所以他们最终选择了我们." "类似的事