简化原生效果_集成UITableViewCell左滑多个按钮

原创 2016年06月02日 10:39:18

实现侧滑效果,资源来自网络。

侧滑删除是iOS中非常容易实现的一种效果,为UITableViewDataSource重写这个方法,系统就会自动添加这种操作。

    - (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath

gif_01.gif

从iOS8开始,苹果开放了这样一个API:

- (nullable NSArray<UITableViewRowAction *> *)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath

返回一个UITableViewRowAction数组,每一个"Action"代表一个侧滑删除的Button。这样侧滑每一行Cell可以有更多按钮提供给用户交互。


gif_02.gif



在侧滑出来的View(那个红色的"Delete" button),上面增加若干个我们想要的Button,所以需要找到一个合适的时机去做这个事情,我们知道,UITableViewCell有一个
- (void)willTransitionToState:(UITableViewCellStateMask)state

方法,当用户在某一行刚开始进行侧滑并且侧滑的Button还没有展现出来时,state的值就为 UITableViewCellStateShowingDeleteConfirmationMask,这个时机就再合适不过,但是,由于Cell的侧滑View是懒加载,所以这时它还没有被创建出来,但要等到与之对应的方法

- (void)didTransitionToState:(UITableViewCellStateMask)state

调用的话,却又已经展现给用户了,为时已晚,能想到的最好、最稳定的时机就是只要一过 willTransitionToState:这个方法,就开始“改造”这个View,所以最好的办法就是延时,只要这个方法一过,侧滑的View就会被创建了,之后我们可以通过遍历UICollectionViewCell的Subviews找到这个View,我们在这里模拟UITableView调用一次UITableViewDataSource的这个方法来获取外部创建的UITableViewRowAction数组:

- (nullable NSArray<UITableViewRowAction *> *)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath

pic_01.png

根据数组里的每一个"rowAction"在这个View上面增加对应个数的UIButton就可以了。

但是这样返回的数组会永远是空,没错,因为UITableViewRowAction这个类在iOS8以下根本不存在,所以我们需要自己创建一个叫做UITableViewRowAction的类,再把它当作普通NSObject帮我们储存一些信息就好了,新建一个与UITableViewRowAction接口一模一样的类JZTableViewRowAction,在程序运行时创建一个叫UITableViewRowAction的类作为JZTableViewRowAction的子类,最后把它注册到运行时中去,这样我们就拥有了一个“很像”UITableViewRowAction类。


pic_03.png

pic_02.png

这里可能有些朋友会有疑问,为什么要创建一个JZTableViewRowAction并且根本没有用到?这个问题可以这样回答你:如果你不创建它的话,你就需要写更多的运行时代码来为你新创建的UITableViewRowAction增加方法、属性等等,所以,相比于这个情况,我更喜欢利用继承的特性来做。这样就实现了我们想要的效果:


gif_03.gif

最后JZTableViewRowAction同时也支持给侧滑控件的按钮设置图片,设置enable状态,除非必要,未来也许会增加更多可自定义接口,


感谢:J_雨。
版权声明:本文为博主原创文章,未经博主允许不得转载。

TableViewCell之左滑多个按钮

1.默认样式为左滑出现删除按钮,需要实现以下两个方法: - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editi...
  • sinat_25544827
  • sinat_25544827
  • 2015年02月05日 20:08
  • 2916

UITableView左滑出现多个按钮

UITableView左滑出现多个按钮
  • lvdezhou
  • lvdezhou
  • 2015年11月09日 15:05
  • 2144

UITableViewCell左滑button的定制

如果你重写了tableView: commitEditingStyle: forRowAtIndexPath:函数,那么UITableViewCell在非编辑状态从右向左侧滑,右边会出现红色的“删除”...
  • lyqfly07
  • lyqfly07
  • 2015年11月24日 15:28
  • 1302

简单方法实现 uitableviewcell 左滑出现各种自定义功能视图

一 先继承 tableviewcell 二
  • wjszf
  • wjszf
  • 2014年08月09日 11:27
  • 1434

TableViewCell添加2个和多个侧滑菜单按钮

一、添加两个按钮(删除、编辑) - (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath...
  • dddxinlin
  • dddxinlin
  • 2015年08月24日 17:34
  • 831

在UITableView里面 定制滑动显示出来的 按钮的底色。

在项目中定制一个 tableview的cell。 这个cell支持手势滑动后,显示一个按钮的功能。 不做修改的话,出现的 按钮后面有个方块区域,底色是白色的。 显的很突兀。 基本思路是...
  • remote_roamer
  • remote_roamer
  • 2013年07月27日 02:12
  • 3087

UITableViewCell左滑多个按钮

轻松学习之四--最简化原生效果集成UITableViewCell左滑多个按钮 侧滑删除是iOS中非常容易实现的一种效果,你只需要为你的UITableViewDataSource重写这...
  • Lu_Ca
  • Lu_Ca
  • 2016年05月13日 10:51
  • 1373

uitableViewCell 左滑多个按钮

轻松学习之四--最简化原生效果集成UITableViewCell左滑多个按钮 字数1113 阅读2256 评论3 喜欢38 侧滑删除是iOS中非常容易实现的一种效果,你只需要为你的UI...
  • u012891546
  • u012891546
  • 2015年11月16日 15:33
  • 349

iOS 自定意义cell左右滑动,添加自定意义button

方案一  左滑支持文字 先付上 iOS8自带的 cell滑动  [objc] view plain copy   // 主要代码   #pra...
  • Amydom
  • Amydom
  • 2016年10月13日 10:27
  • 463

轻松学习之最简化原生效果集成UITableViewCell左滑多个按钮

侧滑删除是iOS中非常容易实现的一种效果,你只需要为你的UITableViewDataSource重写这个方法,系统就会自动添加这种操作。 1 - (void)tableView...
  • cheng6023
  • cheng6023
  • 2016年08月06日 10:24
  • 94
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:简化原生效果_集成UITableViewCell左滑多个按钮
举报原因:
原因补充:

(最多只允许输入30个字)