iOS开发之POP动画基础1

简介:
pop动画引擎是Facebook公司开源的,主要实现了真实物理系的动画效果(弹簧效果与衰减效果)
1、pop动画引擎的动画效果非常流程,其最主要原因是底层使用了CADisplayLink来刷新,每秒达到了60帧,和游戏引擎相当。
2、pop动画与CALayer动画的区别:CALayer动画是有中间状态的,在展示过程中实际上有另一layer层在展示动画,当在执行动画过程中突然移除掉动画效果,会直接到指定的最终状态,容易引起不流程的体验。
pop动画是没有中间状态的,在执行动画的过程中,如果中途移除掉动画效果,那么layer会停留在当前位置。

实现衰减效果:
1)衰减动画由POPDecayAnimation来实现
2)需要精确计算停止运动瞬间的加速度才能够用衰减动画做出真是的效果
目标效果:拖拽一个圆形小球,停止拖拽的瞬间小球继续向前慢慢移动减速停止。
代码实现:

#pragma mark -创建一个圆形的小球
- (void)createBtn{
    UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom];
    btn.bounds = CGRectMake(0, 0, 100, 100);
    btn.center = self.view.center;
    btn.layer.cornerRadius = 50;
    btn.layer.masksToBounds = YES;
    btn.backgroundColor = [UIColor redColor];
    //添加到view中
    [self.view addSubview:btn];
    //为btn添加拖拽手势
    UIPanGestureRecognizer *pan = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(btnPanGes:)];
    [btn addGestureRecognizer:pan];
}

#pragma mark - 拖拽事件
- (void)btnPanGes:(UIPanGestureRecognizer *)recognizer{
    //获取拖拽的变化量
    CGPoint trans = [recognizer translationInView:recognizer.view];
    //动态改变被拖拽的目标的frame值
    recognizer.view.center = CGPointMake(trans.x+recognizer.view.center.x, trans.y+recognizer.view.center.y);
    //清空偏移量
    [recognizer setTranslation:CGPointZero inView:self.view];
    //当停止拖拽的那一瞬间计算加速度并添加衰减动画
    if (recognizer.state == UIGestureRecognizerStateEnded) {
        //获取此时的加速度
        CGPoint vo = [recognizer velocityInView:self.view];
        //创建衰减动画
        POPDecayAnimation *decay = [POPDecayAnimation animationWithPropertyNamed:kPOPLayerPosition];
        decay.velocity = [NSValue valueWithCGPoint:vo];
        [recognizer.view.layer pop_addAnimation:decay forKey:nil];
    }
}

实现弹簧效果
1)弹簧效果通过POPSpringAnimation来实现
2)可以通过设置弹性系数和速度来设置效果
实现目标:一个红色的视图像弹簧般变大
代码实现:

- (void)createView{
    UIView *showView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, 50, 50)];
    showView.backgroundColor = [UIColor redColor];
    showView.center = self.view.center;
    //添加到主视图
    [self.view addSubview:showView];
    //添加弹簧动画,对bounds属性做动画效果
    POPSpringAnimation *spring = [POPSpringAnimation animationWithPropertyNamed:kPOPLayerBounds];
    spring.springBounciness = 20;//设置弹性系数,数值越大,震动幅度越大
    spring.springSpeed = 0;//设置速度,速度越快,动画效果越快结束
    spring.toValue = [NSValue valueWithCGRect:CGRectMake(0, 0, 300, 300)];
    [showView.layer pop_addAnimation:spring forKey:nil];
}

自定义动画:
POP默认支持的三种动画都继承自POPPropertyAnimation中定义了一个叫property的属性( 之前没有用到它是因为POP根据不同的默认动画属性帮你生成了默认的property) 而这个property则是用来驱动POP的动画效果中的重要一环。

POPAnimatableProperty *prop = [POPAnimatableProperty propertyWithName:@"prop" initializer:^(POPMutableAnimatableProperty *prop) {
    prop.readBlock = ^(id obj, CGFloat values[]) {
        
    };
    prop.writeBlock = ^(id obj, const CGFloat values[]) {
        
    };
    prop.threshold = 0.01;
}];

其组成就是一个readBlock一个writeBlock和一个threashold
readBlock告诉POP当前的属性值
writeBlock中修改变化后的属性值
threashold决定了动画变化间隔的阈值 值越大writeBlock的调用次数越少

POPAnimatableProperty其实是POP中一个比较重要的东西 像上面提到的POP自带的动画属性 查看源代码可以看到也只是POP自动帮你设置好了POPAnimatableProperty而已 其作用就是当动画的某个时间片被触发时 告诉系统如何根据当前时间片做出变化

自定义属性实现目标:类似秒表的动画
代码:

- (void)animatableProp{
    UILabel *lab = [[UILabel alloc]init];
    lab.frame = CGRectMake(0, 0, 100,50);
    lab.font = [UIFont systemFontOfSize:30];
    [self.view addSubview:lab];
    lab.center = self.view.center;
    POPAnimatableProperty *prop = [POPAnimatableProperty propertyWithName:@"countDown" initializer:^(POPMutableAnimatableProperty *prop) {
        prop.writeBlock = ^(id obj,const CGFloat values[]){
            UILabel *label = (UILabel*)obj;
            label.text = [NSString stringWithFormat:@"%d:%d:%d",(int)values[0]/60,(int)values[0]%60,(int)(values[0]*100)%100];
        };
    }];
    //秒表采用线性事件函数
    POPBasicAnimation *basic = [POPBasicAnimation linearAnimation];
    basic.property = prop;//采用自定义属性
    basic.fromValue = @(0);//从0开始
    basic.toValue = @(3*60);//180秒
    basic.duration = 3*60;//持续3分钟
    [lab pop_addAnimation:basic forKey:nil];
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容