WPF与缓动(四) 弧形缓动

简介: 原文:WPF与缓动(四) 弧形缓动                                                   WPF与缓动(四)  弧形缓动                                                                   ...
原文: WPF与缓动(四) 弧形缓动

                                                   WPF与缓动(四)  弧形缓动
                                                                        周银辉

弧形缓动就是其缓动曲线为一段圆弧, 如何我们假设圆弧上的点的斜率为速度的话,那么可以想像其速度的变化多么具有戏剧性, 其加速或减速来得很突然, 与5次缓动差不多.
参考以下代码:

img_a6339ee3e57d1d52bc7d02b338e15a60.gif   // 圆形缓动
img_a6339ee3e57d1d52bc7d02b338e15a60.gif
         protected   override   double  GetCurrentValueCore( double  defaultOriginValue,  double  defaultDestinationValue, AnimationClock animationClock)
img_405b18b4b6584ae338e0f6ecaf736533.gifimg_1c53668bcee393edac0d7b3b3daff1ae.gif        
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif {
img_33d02437d135341f0800e3d415312ae8.gif            
double from = (this.From==null?defaultDestinationValue:(double)this.From);
img_33d02437d135341f0800e3d415312ae8.gif            
double to = (this.To==null?defaultOriginValue:(double)this.To);
img_33d02437d135341f0800e3d415312ae8.gif            
double delta = to - from;
img_33d02437d135341f0800e3d415312ae8.gif            
double value = animationClock.CurrentProgress.Value;
img_33d02437d135341f0800e3d415312ae8.gif
img_33d02437d135341f0800e3d415312ae8.gif            
double t = value * this.Duration.TimeSpan.Ticks;
img_33d02437d135341f0800e3d415312ae8.gif            
double d = this.Duration.TimeSpan.Ticks;
img_33d02437d135341f0800e3d415312ae8.gif
img_33d02437d135341f0800e3d415312ae8.gif            
//加速
img_33d02437d135341f0800e3d415312ae8.gif            
//return delta * (1-Math.Sqrt(1-(t/=d)*t)) + from;
img_33d02437d135341f0800e3d415312ae8.gif
img_33d02437d135341f0800e3d415312ae8.gif            
//减速
img_33d02437d135341f0800e3d415312ae8.gif            
//return delta * Math.Sqrt(1 - (t = t / d - 1) * t) + from;
img_33d02437d135341f0800e3d415312ae8.gif
img_33d02437d135341f0800e3d415312ae8.gif            
//先加速,后减速
img_33d02437d135341f0800e3d415312ae8.gif
            if ((t /= (d / 2)) < 1)
img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif            
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
img_33d02437d135341f0800e3d415312ae8.gif                
return delta / 2 * (1 - Math.Sqrt(1 - t * t)) + from;
img_105a1e124122b2abcee4ea8e9f5108f3.gif            }

img_33d02437d135341f0800e3d415312ae8.gif            
return delta / 2 * (Math.Sqrt(1 - (t -= 2* t) + 1+ from;
img_33d02437d135341f0800e3d415312ae8.gif            
img_05dd8d549cff04457a6366b0a7c9352a.gif        }

下载Demo

 

目录
相关文章
|
C# 前端开发
WPF 一个弧形手势提示动画
原文:WPF 一个弧形手势提示动画 这是一个操作提示动画,一个小手在屏幕上按照一个弧形来回运动 ...
730 0
|
C#
WPF与缓动(一) N次缓动
原文:WPF与缓动(一) N次缓动                                                             WPF与缓动(一)  N次缓动                                                         ...
916 0
|
C#
WPF与缓动(二) 正弦与余弦缓动
原文:WPF与缓动(二) 正弦与余弦缓动                                                                            WPF与缓动(二) 正弦与余弦缓动                                     ...
824 0
|
C#
WPF与缓动(三) 指数缓动
原文:WPF与缓动(三) 指数缓动                                                         WPF与缓动(三) 指数缓动                                                                             周银辉指数缓动给人的感觉是加速度很大.
617 0
|
C# 内存技术
WPF中ListBox滚动时的缓动效果
原文:WPF中ListBox滚动时的缓动效果 上周工作中遇到的问题: 常规的ListBox在滚动时总是一格格的移动,感觉上很生硬。
1183 0
|
C#
WPF中的动画——(四)缓动函数
原文:WPF中的动画——(四)缓动函数 缓动函数可以通过一系列公式模拟一些物理效果,如实地弹跳或其行为如同在弹簧上一样。它们一般应用在From/To/By动画上,可以使得其动画更加平滑。     var widthAnimation = new DoubleAnimation()    {    ...
988 0
|
C# 内存技术
WPF界面设计技巧(7)—模拟电梯升降的缓动动画
原文:WPF界面设计技巧(7)—模拟电梯升降的缓动动画     如同Flash一样,WPF的亮点之一也在于其擅于表现平滑的动画效果,但以移动动画来说,仅凭简单的起始位置、目标位置,所产生的动画仍会非常生硬,这种动画忽略了移动开始时的加速过程与移动结束时的减速过程。
1037 0
|
8月前
|
C# 开发者 Windows
基于Material Design风格开源、易用、强大的WPF UI控件库
基于Material Design风格开源、易用、强大的WPF UI控件库
419 0
|
5月前
|
开发框架 缓存 前端开发
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件