这篇博文实在不知道该起什么名字才能概况我的意思。。。挫语文水平
类似于淘宝一样,我们在写一些购物、订餐之类的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在控制器中处理是不能实现这个需求的。