iOS开发——仿淘宝添加到购物车的动画效果实现

这篇博文实在不知道该起什么名字才能概况我的意思。。。挫语文水平尴尬

类似于淘宝一样,我们在写一些购物、订餐之类的app的时候,在用户选择购买或者加入购物车时可以添加一个商品飞到购物车中的动画效果,如下图所示:



实现这个效果还是不算难的,但涉及的问题比较多,还是挺有学习价值的。主要面对的问题有以下几点

1、cell中有button,如何获得该button,即如何知道用户点击的是哪一个button。

2、坐标系的转换,这里频繁使用坐标系转换,主要原因是这里需要涉及三个视图——cell、tableView、view

3、Bezier曲线的应用。

下面我们一一来解决这些问题。

正好这学期图形学刚刚结课,虽然没有什么关联,不过也算复习了- -。


一、获取cell中的button

这个问题也是个老问题了,方法也非常多,比较常见的是自定义cell,然后将button作为cell的property,这样我们可以在创建cell的时候为button设tag值,根据indexPath来设即可,通过tag来区分。这样在很多情况下也能解决问题。不过这次我们用的并不是这种方法。

分析:每个cell的button有自己的处理逻辑,比如,当点击收藏按钮时要将选中的FoodModel保存起来,要改变button的标题……,从MVC的原则以及职责单一化的原则来看,这些写在cell之外的地方都是不合适的,而上面的动画很明显是在控制器层级的动画,也就是动画代码不能写在cell中,而是在某某Controller中的。如果只是设tag在控制器中处理是不能实现这个需求的。

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值