POP框架初探

合适的动画效果是提高用户体验最直观的方式,我们项目中的动画应用也不少,主要是使用的UIKit的动画扩展,还有少量用CoreAnimation实现。现在Facebook开源了POP,我们又多了一种强大好用的选择。与CoreAnimation相比,api用法相似,POP提供了更多方便生动的动画效果,主要是弹簧(SpringAnimation)和衰减(DecayAnimation)效果。

使用方法

POP的使用跟CoreAnimation比较相似,基本的步骤如下:

  • 选择一种动画效果
    1.POPBasicAnimation 基本的动画效果,我们常用的EaseInOut、Linenear的动画效果都可以用这种方式实现
    <pre><code>
    POPBasicAnimation *basicAnimation = [POPBasicAnimation animation];
    basicAnimation.timingFunction=[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
    // kCAMediaTimingFunctionLinear kCAMediaTimingFunctionEaseIn kCAMediaTimingFunctionEaseOut kCAMediaTimingFunctionEaseInEaseOut
    </code></pre>
    2.POPSpringAnimation 弹簧效果,如下图
pop.gif

<pre><code>
POPSpringAnimation *springAnimation = [POPSpringAnimation animation];
springAnimation.springBounciness=14; // 弹簧弹力 取值范围为[0, 20],默认值为4
springAnimation.springSpeed=3; // 弹簧速度,速度越快,动画时间越短 [0, 20],默认为12,和springBounciness一起决定着弹簧动画的效果
// 还有:dynamicsTension 弹簧的张力 dynamicsFriction 弹簧摩擦 dynamicsMass 质量 。张力,摩擦,质量这三者可以从更细的粒度上替代springBounciness和springSpeed控制弹簧动画的效果
</code></pre>
3.POPDecayAnimation 衰减效果,参考UIScrollView滑动松手后的减速
<pre><code>
POPDecayAnimation *decayAnimation=[POPDecayAnimation animation];
decayAnimation.velocity=@(233); //值的变化速率
</code></pre>

  • 选择生成动画的Property
    View Properties,包含以下定义
    kPOPViewAlpha kPOPViewBackgroundColor kPOPViewBounds kPOPViewCenter kPOPViewFrame kPOPViewScaleXY kPOPViewSize

Layer Properties
kPOPLayerBackgroundColor kPOPLayerBounds kPOPLayerScaleXY kPOPLayerSize kPOPLayerOpacity kPOPLayerPosition kPOPLayerPositionX kPOPLayerPositionY kPOPLayerRotation kPOPLayerBackgroundColor

  • 设置对应的.toValue
    例如
    <pre><code>
    // 设置alpha
    POPBasicAnimation *basicAnimation = [POPBasicAnimation animation];
    basicAnimation.property = [POPAnimatableProperty propertyWithName:kPOPViewAlpha];
    basicAnimation.toValue= @(0);
    // 设置BackgroundColor
    POPSpringAnimation *basicAnimation = [POPSpringAnimation animation];
    basicAnimation.property = [POPAnimatableProperty propertyWithName: kPOPLayerBackgroundColor];
    basicAnimation.toValue= [UIColor redColor];
    </code></pre>

  • 为动画设置name和delegate
    <pre><code>
    basicAnimation.name=@"POPAnimation";
    basicAnimation.delegate=self;
    </code></pre>
    delegate方法如下

<pre><code>

  • (void)pop_animationDidStart:(POPAnimation *)anim;
  • (void)pop_animationDidStop:(POPAnimation *)anim finished:(BOOL)finished;
  • (void)pop_animationDidReachToValue:(POPAnimation *)anim;

</code></pre>

  • 将animation添加到对象上
    <pre><code>
    [self.tableView pop_addAnimation:basicAnimation forKey:@"POPAnimation"];
    </code></pre>

完整例子

<pre><code>
POPSpringAnimation *basicAnimation = [POPSpringAnimation animation];
basicAnimation.property = [POPAnimatableProperty propertyWithName:kPOPViewFrame];
basicAnimation.toValue=[NSValue valueWithCGRect:CGRectMake(0, 0, 90, 190)];
basicAnimation.name=@"SomeAnimationNameYouChoose";
basicAnimation.delegate=self;
[self.tableView pop_addAnimation:basicAnimation forKey:@"POPAnimation"];
</code></pre>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 10,529评论 5 13
  • 先看看CAAnimation动画的继承结构 CAAnimation{ CAPropertyAnimation { ...
    时间不会倒着走阅读 5,622评论 0 1
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 12,716评论 6 30
  • 在iOS实际开发中常用的动画无非是以下四种:UIView动画,核心动画,帧动画,自定义转场动画。 1.UIView...
    请叫我周小帅阅读 8,381评论 1 23
  • 鸟鸣……被鸟类世代传递 抵达今日窗前 第一只鸟儿由谁造出? 它又如何叫出 开天辟地的第一声? 亘古以前从来没有 叫...
    诗人凤凰阅读 1,170评论 0 0