美文网首页iOS文章iOS核心动画动画设计学习
iOS 一分钟搞定加入购物车的交互动画

iOS 一分钟搞定加入购物车的交互动画

作者: 嘿晴天 | 来源:发表于2016-08-18 13:25 被阅读5479次

    交互动画,是一款吸引用户的装逼神技,这是最近弄了一个加入购物车的交互动画,并封装了一下,效果图如下

    Untitled.gif

    1 大致原理
    这里是给屏幕 添加了一个 关键帧动画 和旋转动画的图层

    (1)关键帧动画
    这个动画主要描绘图层下落的路径 ,大致要确定三个点,通过 a,b,c 三个点来确立图层的下落路径,a 点图片 的图片的中心x 和y , b 点 是图片的屏幕一半作为 x 坐标 和 图片的y-80作为y,c 点 则是要下落的位置 ,我的demo 是下落在 第三个tarbar 大致计算一下即可

    873CBD05-1268-4A5D-9530-719EA62BE7DE.png

    来看下关键代码

       _layer.position = CGPointMake(rect.origin.x+view.frame.size.width/2, CGRectGetMidY(rect)); //a 点
            // 路径
        UIBezierPath *path = [UIBezierPath bezierPath];
        [path moveToPoint:_layer.position];
        [path addQuadCurveToPoint:finishPoint controlPoint:CGPointMake(ScreenWidth/2, rect.origin.y-80)];
        //关键帧动画
        CAKeyframeAnimation *pathAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
        pathAnimation.path = path.CGPath;
    

    (2)图层旋转动画则比较简单了,直接贴代码估计就看懂了,这里大致是转体三周半

        CABasicAnimation *rotateAnimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation"];
        rotateAnimation.removedOnCompletion = YES;
        rotateAnimation.fromValue = [NSNumber numberWithFloat:0];
        rotateAnimation.toValue = [NSNumber numberWithFloat:12];
        rotateAnimation.timingFunction=[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];
    

    2相关调用
    如果你的 superView 就是VC 的 self.view 那么你可以直接用

    /**
     *  开始动画
     *
     *  @param view        添加动画的view
     *  @param rect        view 的绝对frame
     *  @param finishPoint 下落的位置
     *  @param animationFinisnBlock 动画完成回调
     */
    -(void)startAnimationandView:(UIView *)view andRect:(CGRect)rect andFinisnRect:(CGPoint)finishPoint andFinishBlock:(animationFinisnBlock)completion;
    

    其中 rect 如果你添加动画的view 的superview 就是vc 的self.view 那么你可以直接动画的frame 赋值 不是的话则要计算出来,详情可以看一下我的demo

    https://github.com/heysunnyboy/PurchaseCarAnimation.git

    相关文章

      网友评论

      • Sunshine喵小喵:居然是你,给你点个赞
        Sunshine喵小喵:@嘿晴天 sunshine
        嘿晴天:@爱Sunshine兔 你是?
      • PGOne爱吃饺子:楼主,您好,请问您的finishPoint.x为什么是 ScreenWidth/4*2.5 ,finishPoint.x 对应的不应该是第三个tab么,我认为应该是 ScreenWidth/4*7.5啊 ,求楼主解答一下,🙏
        瓦力wali:convertPoint: toView:返回的CGPoint 是使用image.frame.orign.y + ScreenWidth/4*2.5,image.frame.orign.x + finisnPoint.x
      • 马铃薯蜀黍:哥们源码里这个单例...
        select刘冠:哥们,你不行啊,那怎么会是单例呢,楼主封装了一个构造方法而已
      • 尤先森:很棒
      • 夜生物:大神,在collectionview上添加动画,为什么图片的frame都是一样的?
        嘿晴天:@ChineseTiger 你取出图片的cell坐标 再取出,相对cell 图片坐标,计算出图片的绝对坐标
        夜生物:@嘿晴天 我是在collectionviewcell上面加的动画,图片是以cell为坐标的,运行的时候,它是以整个屏幕为坐标的,不管点击那个cell,图片坐标点都不变:sweat:
        嘿晴天:@ChineseTiger 什么意思?
      • 6df0d073b6fb:Hi, 感觉你写的源码很棒, 已收藏到 http://www.codedata.cn/cdetail/Objective-C/Demo/1472172964144355http://www.codedata.cn 是一个iOS源码分享平台
      • 温暖的弦Y:你好,如果startAnimationandView传入按钮的话,为什么没有关键帧动画效果呢
        婉卿容若:@别问我从哪里来 ok, 我使用了 UIButton 的 imageView 属性,这样 layer.contents 就不为 nil了
        婉卿容若:@别问我从哪里来 "需要把button的view转成Image 再进行相关赋值处理才行",请问这句怎么实现?把 UIButton 转成 UIImageView?还是怎么弄, 转 UIImageView 成功不了
        别问我从哪里来:因为layer.contents 赋值的时候,_layer.contents = view.layer.contents; 就这句之后layer.contents内容位nil,需要把button的view转成Image 再进行相关赋值处理才行。
      • scyworld:厉害
      • 靖锅锅_:很好 很棒
      • xxttw:很棒 学习一下思路

      本文标题:iOS 一分钟搞定加入购物车的交互动画

      本文链接:https://www.haomeiwen.com/subject/ookvsttx.html