iOS:一用就上瘾的BottomSheetView

百家 作者:iOS开发 2018-08-20 13:00:30

点击上方“iOS开发”,选择“置顶公众号”

关键时刻,第一时间送达!


作者:pujiaxin33

链接:https://github.com/pujiaxin33/JXBottomSheetView

iOS开发整理发布,转载请联系作者获得授权


项目中有类似于外卖软件的已点菜品列表,类似于下图:



可以看到列表的显示与隐藏,都只能通过按钮触发。不能通过手势驱动。不能设置最小可显示范围。针对以上问题,就有了这个项目。


其实以上的需求核心问题就一个,如何优雅的解决:当内容还未到最大可显示范围时,列表里的内容不能滚动;当内容显示到最大的时候,如何不断开当前滚动手势,继续滚动列表里的内容。


之前写了一个类似的底部列表滚动视图,地址:https://github.com/pujiaxin33/JXBottomSheetTableView 里面的实现方案还是挺有趣的,对外完全封装了里面的滚动控制细节,且以UITableView的子类实现。无奈越骚的操作越容易翻车。里面的应用场景比较狭窄,需求一变动就GG了。


所以重新写了这个库,使用场景更大,使用更方便,交互更友善,好了,不说了,快上车吧!


原理


为JXBottomSheetView添加一个UIPanGestureRecognizer,成为其delegate,并让shouldRecognizeSimultaneouslyWithOtherGestureRecognizer方法返回true;
如此一来,内容承载视图与列表视图的滚动手势可以同时响应了。接着,我们需要处理好当内容承载视图未显示到最大值时,列表视图(UITableView、UICollectionView)的contentOffset.y会被强制设置为0,营造一种列表内容未滚动的假象;
当内容承载视图滚动到最大的时候,就放开对列表视图的滚动限制。
其他一些细节可以参看源码了解;


Github地址


https://github.com/pujiaxin33/JXBottomSheetView


特性


  • 支持长距离滚动,不断手势:当列表视图滚动到规定的最高点时,停止视图移动,转而滚动里面的内容;

  • 内容自适应:当列表的数据源发生变动时,会根据最新的contentSize调整布局;

  • 切换流畅:最大、最小的手势切换,借鉴了系统UIScrollView的PagingEnabled切换效果;


预览


  • 普通短距离滚动

  • 长距离滚动,手势没有停掉。滚动到顶部的时候,继续滚动里面的内容

  • 内容自适应,根据contentView的contentSize自动调整布局


属性/方法



使用

        tableView = UITableView.init(frame: CGRect.zero, style: .plain)

        let bottomSheet = JXBottomSheetView(contentView: tableView)
        bottomSheet.defaultMininumDisplayHeight = 100
        bottomSheet.defaultMaxinumDisplayHeight = 300
        bottomSheet.displayState = .minDisplay
        bottomSheet.frame = self.view.bounds
        view.addSubview(bottomSheet)


注意

  • 内部会影响到外部的代码

if let tableView = contentView as? UITableView {
          tableView.estimatedRowHeight = 0
      }
  • 数据源的增删,请使用reloadData,而不是insertRows、deleteRows刷新页面。因为...你试一下就知道了。

【点击成为源码大神】

▼点击「阅读原文」进入程序员商城

关注公众号:拾黑(shiheibook)了解更多

[广告]赞助链接:

四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/

公众号 关注网络尖刀微信公众号
随时掌握互联网精彩
赞助链接