最近在写一个动画效果的时候,发现有个常用的参数:动画的速度控制参数,之前对它没有什么深入理解.今天突然来了兴趣,就来详细研究下它.
一.UIViewAnimationOptions是什么?
它是控制动画效果的一个选项,这里我重点研究的动画速度控制相关的内容。
首先,贴一段常用的UIView动画代码:
[UIView animateWithDuration:1 animations:^{
// 动画代码
} completion:^(BOOL finished) {
}];
此时,是不用传入options参数的, 这是完整的UIView动画的方法:
[UIView animateWithDuration:1 delay:0 options:options animations:^{
// 动画代码
} completion:^(BOOL finished) {
}];
这里的options就是控制动画效果的枚举类型 UIViewAnimationOptions
它有四个枚举值是跟速度控制相关的: UIViewAnimationOptionCurveEaseInOut,UIViewAnimationOptionCurveEaseIn,UIViewAnimationOptionCurveEaseOut,和UIViewAnimationOptionCurveLinear, 苹果文档对它解释如下:
UIViewAnimationOptionCurveEaseInOut
Specify an ease-in ease-out curve, which causes the animation to begin slowly, accelerate through the middle of its duration, and then slow again before completing.
UIViewAnimationOptionCurveEaseIn
An ease-in curve causes the animation to begin slowly, and then speed up as it progresses.
UIViewAnimationOptionCurveEaseOut
An ease-out curve causes the animation to begin quickly, and then slow as it completes.
UIViewAnimationOptionCurveLinear
A linear animation curve causes an animation to occur evenly over its duration.
但是仅仅通过文字描述,显然是不够直观,干脆做个动画,来个直观感受:
二.动画效果演示:
我用OC写了个demo,上面是一个UIView动画, 下面是展示动画运动距离的函数曲线:
UIViewAnimationOptionCurveEaseInOut
data:image/s3,"s3://crabby-images/c0613/c0613ef1df51ccde87a25ce7a09625c07870df71" alt=""
UIViewAnimationOptionCurveEaseIn
data:image/s3,"s3://crabby-images/27d57/27d572444b2783ebce10155ea7e63660895aa6e9" alt=""
UIViewAnimationOptionCurveEaseOut
data:image/s3,"s3://crabby-images/4ce1c/4ce1c7a73ae68548c1a63024bb9d5800a9e22037" alt=""
UIViewAnimationOptionCurveLinear
data:image/s3,"s3://crabby-images/ef05c/ef05c800de1f9ee95981db45d56c730cf5b2b520" alt=""
三.代码
对这个小demo感兴趣的话,稍后会贴出github地址。
网友评论