WPF:像 CSS 中那样使用三次贝塞尔曲线的缓动函数
目前我在代码中有类似的东西:
var doubleAnimation = new DoubleAnimation(1, new Duration(TimeSpan.FromMilliseconds(280)))
{
FillBehavior = FillBehavior.HoldEnd,
EasingFunction = new CubicEase()
};
但是结果并不完美。
是否可以像CSS一样使用Cutic Bezier曲线创建自定义缓解?
transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1)
我看到我们可以通过继承来创建自定义宽松功能 easingFunctionBase
我需要指定曲线上的点坐标以获得相同的结果。
https://cubic-bezier.com/#.4,0,0,。 2,1
我可以创建一个自定义的轻松函数:
internal class MaterialEasingFunction : EasingFunctionBase
{
public MaterialEasingFunction()
: base()
{
EasingMode = EasingMode.EaseInOut;
}
protected override double EaseInCore(double normalizedTime) => Math.Pow(normalizedTime, 3);
protected override Freezable CreateInstanceCore() => new MaterialEasingFunction();
}
但是我不知道如何指定曲线上点的坐标。
您知道我该怎么做吗?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我们可以使用
AccelerationRatio
和减速>
doublemeyimation
:https://lealen.microsoft.com/fr-fr/dotnet/desktop/wpf/wpf/graphics-multimedia/how-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-te-t-te-cel---------------------------------- /a>
这是Cupic Bezier的CSS语法:
在这种情况下,我们仅使用
x1
和x2
。由于坐标从0到1,我们可以将点的X配音用作加速度和减速比率,
这是最终结果:
We can use
AccelerationRatio
andDecelerationRatio
properties on aDoubleAnimation
:https://learn.microsoft.com/fr-fr/dotnet/desktop/wpf/graphics-multimedia/how-to-accelerate-or-decelerate-an-animation?view=netframeworkdesktop-4.8
This is the CSS syntax for cubic bezier :
In this case, we just using
x1
andx2
.Since the coordinates go from 0 to 1, we can use the x-coordinates of the points as acceleration and deceleration ratios
This is the final result :