学学人家的框架iOS图像动画iOS

POP框架初探

2014-11-06  本文已影响2890人  HolyCat_猫

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

使用方法

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

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>

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

<pre><code>

</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>

上一篇 下一篇

猜你喜欢

热点阅读