热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

UIScrollView嵌套滑动手势冲突的简易实现

明确需求现在有较多的商城类app有如下需求,界面上带有headerView,并且有一个barView可悬停,最下方为多个可左右滑动的tableVie

明确需求

现在有较多的商城类app有如下需求,界面上带有headerView,并且有一个barView可悬停,最下方为多个可左右滑动的tableView,具体可参考下图

技术分享图片

另类实现

在网上关于此类需求的实现较多,大多数为使用UIScrollView手势穿透(多个视图响应一个手势)来达到效果。

此前笔者也是用类似方法实现,最近想到了另一种实现方案(实现和学习成本很低)。

界面层次

技术分享图片

实现方案

通过界面层次就很容易明白笔者的思路了,在界面上只有一个tableView存在,同时在tableView之上还有一个HeaderView(包含广告和按钮位),当使用手势滑动时,再做动画切换对应的tableView视图(此种方式没有复用效果,当然如果有追求极致者也可去实现),HeaderView保持不变。当tableView滑动的同时,改变HeaderView坐标,这样就可以保证手势丝滑,不存在任何卡顿。

具体思路



  • 协议类


遵循此协议的UIViewController都可以成为界面上的tableView。自定义的tableView只需要关心标示符即可

@protocol SwipTableViewDelegate
@property (nonatomic, strong) UITableView * tableView;
@property (nonatomic, copy) NSString * itemTitle; ///<子视图标示符,也可用其他类型代替
@property (nonatomic, assign) CGFloat headerHeight; ///<头部视图高度(包含广告位和按钮位)
@property (nonatomic, assign) BOOL needScrollBlock; ///<滑动时是否需要回调
/* 更新数据源方法 */
- (void)reloadWithDatas:(NSArray *)datas;
/* 当tableView上下滑动时需回调此方法中的block */
- (void)scrollViewDidScrollBlock:(void(^)(CGFloat offsetY))block;
@end


  • SwipeSubTableVc(主容器)


此处创建SwipeSubTableVc,自定义headerView和barView,传入自己配置的UIViewController(需遵守SwipTableViewDelegate协议)

@interface SwipeSubTableVc : UIViewController
@property (nonatomic, strong) UIView * headerView;
@property (nonatomic, strong) UIView * barView;
@property (nonatomic, strong) NSArray *> * tabArrs;
- (void)resetTabArrs:(NSArray *> *)tabArrs;
- (void)switchToTabVc:(NSInteger)index;
- (void)tabVcWillSwitchToIndex:(void(^)(NSInteger index))changeBlock;
@end


  • 内部实现思路

    • 1.添加headerView和barView,并保证在最上层

    • 2.添加对应的tableView视图,并给tableView一个空的头部视图

    • 3.在tableView滚动同时改变上层头视图frame

    • 4.左右滑动时,切换为对应tableView做出动画效果


整体思路如上所述,有思路了代码就不贴了。如有需要下载demo

如有错误之处请指出,谢谢


推荐阅读
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 本文介绍了 AngularJS 中的 $compile 服务及其用法,通过示例代码展示了如何使用 $compile 动态编译和链接 HTML 元素。 ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • Manacher算法详解:寻找最长回文子串
    本文将详细介绍Manacher算法,该算法用于高效地找到字符串中的最长回文子串。通过在字符间插入特殊符号,Manacher算法能够同时处理奇数和偶数长度的回文子串问题。 ... [详细]
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • 本文介绍了多种开源数据库及其核心数据结构和算法,包括MySQL的B+树、MVCC和WAL,MongoDB的tokuDB和cola,boltDB的追加仅树和mmap,levelDB的LSM树,以及内存缓存中的一致性哈希。 ... [详细]
  • Python多线程详解与示例
    本文介绍了Python中的多线程编程,包括僵尸进程和孤儿进程的概念,并提供了具体的代码示例。同时,详细解释了0号进程和1号进程在系统中的作用。 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • A*算法在AI路径规划中的应用
    路径规划算法用于在地图上找到从起点到终点的最佳路径,特别是在存在障碍物的情况下。A*算法是一种高效且广泛使用的路径规划算法,适用于静态和动态环境。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • 数字资产量化交易通过大数据分析,以客观的方式制定交易决策,有效减少人为的主观判断和情绪影响。本文介绍了几种常见的数字资产量化交易策略,包括搬砖套利和趋势交易,并探讨了量化交易软件的开发前景。 ... [详细]
author-avatar
王立君淑霖_189
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有