加入购物车动画-UIBezierPath曲线的实用
来源:互联网 发布:下载微客多软件 编辑:程序博客网 时间:2024/06/13 16:27
作者:嘿晴天
原文链接:http://www.jianshu.com/p/bd650158d44c
交互动画,是一款吸引用户的装逼神技,这是最近弄了一个加入购物车的交互动画,并封装了一下,效果图如下
1 原理
这里是给屏幕 添加了一个 关键帧动画 和旋转动画的图层
(1)关键帧动画
这个动画主要描绘图层下落的路径 ,大致要确定三个点,通过 a,b,c 三个点来确立图层的下落路径,a 点图片 的图片的中心x 和y , b 点 是图片的屏幕一半作为 x 坐标 和 图片的y-80作为y,c 点 则是要下落的位置 ,我的demo 是下落在 第三个tarbar 大致计算一下即可
来看下关键代码
_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
- 加入购物车动画-UIBezierPath曲线的实用
- Android贝塞尔曲线实现加入购物车抛物线动画
- 京东到家,美团外卖等加入购物车的贝塞尔曲线view动画
- 加入购物车动画
- 加入购物车动画
- 商品加入购物车的动画
- 类似加入购物车的抛物线动画
- 购物车动画-贝塞尔曲线
- android 饿了么 加入购物车动画(贝塞尔曲线绘制)
- IOS 加入购物车动画
- js加入购物车动画
- 加入购物车 动画效果
- Android 加入购物车动画
- 加入购物车动画效果
- iOS开发 UIBezierPath曲线动画
- iOS一分钟搞定加入购物车的交互动画
- iOS 一分钟搞定加入购物车的交互动画
- iOS 一分钟搞定加入购物车的交互动画
- 欢迎使用CSDN-markdown编辑器
- MySQL基础二之数据类型与创建数据表
- 服务器负载均衡
- Xcode在playground的quick look框中显示对象自定义视图
- shell脚本删除指定目录下超过指定时间的文件
- 加入购物车动画-UIBezierPath曲线的实用
- linux上安装redis以及redis扩展
- style——继承
- HDU 5441 Travel(并查集)
- eclipse关于项目validate的过滤选择
- linux3.4版本内核make出现的错误----缺少compiler-gcc5.h
- fastboot 源码分析2
- HDU 1592 Half of and a Half(高精度)
- oracle字符窜操作