如何在css变换动画中实现easeOutBack缓动
我正在处理一些 css 动画。但我发现,CSS 过渡仅支持以下缓动功能。
轻松|线性|缓入|缓出 |缓入缓出 | cubic-bezier()
我确实想在带有纯css的动画中使用类似easeOutBack缓动的东西。我正在考虑用 webkit 动画来做到这一点。但只有 safari 支持。
easeOutBack 动作是一个动作 物体将超出的地方 边界并再次返回。有关不同运动函数的更多信息。 您可以在下面看到此链接。
http://hosted.zeh.com。 br/tweener/docs/en-us/misc/transitions.html
有人对如何在CSS变换动画中实现easeOutBack缓动有建议吗?
I am working with some css animation. But I found that, the CSS transition only support following easing function.
ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier()
I do want to use something like easeOutBack easing in the animation with pure css. I am thinking to do it with the webkit-animation. But only safari support it.
The easeOutBack motion is a motion
where the object will go beyond the
boundary and back again.More about different motion function.
You can see this link below.http://hosted.zeh.com.br/tweener/docs/en-us/misc/transitions.html
Anyone have suggestion of how to implement easeOutBack easing in css transform animation?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
您可以使用
-webkit-animation-timing-function
CSS 属性指定自己的曲线。函数的格式为 cubic-bezier(P1x, P1y, P2x, P2y) 其中 P1 和 P2 是从 (0,0) 到 (1,1) 的三次贝塞尔曲线的两个中点)。在你的情况下,你想要的东西看起来像 -
EaseOutBack http://i56.tinypic.com/adg8yo.png
所以您在此曲线中指定的点是 -
(0,0)
和(0.2,1)
。这使得曲线 - cubic-bezier(0,0,0.2,1) 。唉,webkit 三次曲线规范不允许动画超出 1,1 立方体的边界。因此,要实际根据需要对曲线进行动画处理,您需要添加一个额外的关键帧来指定“溢出”。
看看我组合在一起的示例 - http://jsfiddle.net/Heqs8/
You can specify your own curve with the
-webkit-animation-timing-function
CSS property.The format of the function is
cubic-bezier(P1x, P1y, P2x, P2y)
where P1 and P2 are the two middle points of a cubic bezier curve from (0,0) to (1,1). In your case you want something that looks like -EaseOutBack http://i56.tinypic.com/adg8yo.png
So the points you would specify in this curve are -
(0,0)
and(0.2,1)
. This makes the curve -cubic-bezier(0,0,0.2,1)
.Alas, the webkit cubic curve specification does not allow the animation to exceed the bounds of 1,1 cube. So to actually animate the curve as desired you need to add an extra keyframe that specifies the 'overflow'.
Take a look at the example I threw together - http://jsfiddle.net/Heqs8/
看起来下面的代码会将
easeOutBack
动画添加到 jQuery,然后您应该能够使用它。从 http://jsfiddle.net/marcofucci/rRtAq/ 找到,其中提到 http://gsgd.co.uk/sandbox/jquery/easing/。
Looks like the following code will add the
easeOutBack
animation to jQuery, and then you should be able to use it.Found from http://jsfiddle.net/marcofucci/rRtAq/ which mentions http://gsgd.co.uk/sandbox/jquery/easing/.
另一种替代方案是 CSS3 动画生成器,它支持 W3C 规范不支持的 12 种缓动功能,包括后缓动-出去。 CSS3 动画生成器不使用具有许多限制的三次曲线,而是使用计算的关键帧。
Another alternative is the CSS3 Animation Generator, which enables 12 easing functions not supported by the W3C specifics, including back-ease-out. Rather than using cubic curves, which has a number of limitations, the CSS3 Animation Generator uses calculated keyframes.