全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

iOS中UIScrollView嵌套UITableView的实践教程

前言

最近因为工作项目中需要用到UIScrollView嵌套UItableView嵌套交互问题,顺便网上搜了下的demo,发现实现的效果并不是很理想,滑动偶尔会有延迟现象,所以自己想了个办法,顺便把自己实现写了个demo分享出来,一起来看看吧。

实现过程

最底部放置的为一个UIScrollView,设置ScrollView的contentSize属性,使可以发生横向滚动,同时隐藏横向滚动条,设置代理为当前控制器本身。然后,在最底部的UIScrollView上放置2个UITableView,因为只有2个所以没有考虑重用问题,如果数量大于3个建议写下UIScrollView子视图的重用。最后在最上面覆盖一个topView,使得它可以和tableView发生纵向滚动,为了实现最上面的topView可以随着tableView发生一起滚动,需要在tableView的scrollViewDidScroll代理方法中获取tableview的contentOffset偏移量,随便改变topView的frame。

当手势点开始落在从topView上时候,在controller的loadView方法中设置自定义view,通过在自定义view中重载hittest方法,判断是否需要让tableView进行交互。此时需要注意的是因为有自定义的左右选择segmentControl,这么设置的时候segmentController是不会相应点击方法的。为了让segmentController可以实现随着tableView滚动并且可以相应单击事件,我在在controller的view上添加了单击手势,判定是否点击在了自定义的segmentControll上(因为tableView本身不会相应- (void)touchesBegan:(NSSet<UITouch *> )touches withEvent:(UIEvent )event事件,所以也可以自定义一个tableVuew,重载touchBegin 等方法,然后把tableView继承自这个tableView, 这样就可以相应相应的touchbegin等方法了), 好了,下面直接上代码

controller中代码如下:

#pragma mark - 底部的scrollViuew的代理方法scrollViewDidScroll

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
 CGFloat placeholderOffset = 0;
 if (self.topView.getSelectedItemIndex == 0) {
  if (self.firstTableView.contentOffset.y > self.topView.height - kItemheight) {
   placeholderOffset = self.topView.height - kItemheight;
  }
  else {
   placeholderOffset = self.firstTableView.contentOffset.y;
  }
  [self.secondTableView setContentOffset:CGPointMake(0, placeholderOffset) animated:NO];
 }
 else {
  if (self.secondTableView.contentOffset.y > self.topView.height - kItemheight) {
   placeholderOffset = self.topView.height - kItemheight;
  }
  else {
   placeholderOffset = self.secondTableView.contentOffset.y;
  }
  [self.firstTableView setContentOffset:CGPointMake(0, placeholderOffset) animated:NO];
 }
}
#pragma mark - 底部的scrollViuew的代理方法scrollViewDidEndDecelerating

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{ 
 NSInteger index = ceilf(scrollView.contentOffset.x / kScreen_Width);
 self.topView.selectedItemIndex = index;
}

controller中view的代码如下

#pragma mark - 重载系统的hitTest方法

- (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event
{
 ViewController *currentVC = (ViewController *)self.nextResponder;
 currentVC.printPoint = point;
 if ([self.topView pointInside:point withEvent:event]) {
  self.scrollView.scrollEnabled = NO;
  if (self.scrollView.contentOffset.x < kScreen_Width *0.5) {
   return self.firstTableView;
  } else {
   return self.secondTableView;
  }
 } else {
  self.scrollView.scrollEnabled = YES;
  return [super hitTest:point withEvent:event];
 }
}
#pragma mark - 添加手势的相应方法

- (void)tapGestureAction:(UITapGestureRecognizer *)gesture
{
 CGPoint point = [gesture locationInView:self.topView];
 if (CGRectContainsPoint(self.topView.leftBtnFrame, point)) {
  if (self.scrollView.contentOffset.x > 0.5 * kScreen_Width) {
   [self.scrollView setContentOffset:CGPointMake(0, 0) animated:NO];
   self.topView.selectedItemIndex = 0;
  }
 } else if (CGRectContainsPoint(self.topView.rightBtnFrame, point)) {
  if (self.scrollView.contentOffset.x < 0.5 * kScreen_Width) {
   [self.scrollView setContentOffset:CGPointMake(kScreen_Width, 0) animated:NO];
   self.topView.selectedItemIndex = 1;
  }
 }
}
#pragma mark - firstTableView的代理方法scrollViewDidScroll

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
 CGFloat placeHolderHeight = self.topView.height - self.topView.itemHeight;

 CGFloat offsetY = scrollView.contentOffset.y;

 if (offsetY >= 0 && offsetY <= placeHolderHeight) {
  self.topView.y = -offsetY;
 }
 else if (offsetY > placeHolderHeight) {
  self.topView.y = - placeHolderHeight;
 }
 else if (offsetY <0) {
  self.topView.y = - offsetY;
 }
}
#pragma mark - secondTableView的代理方法scrollViewDidScroll

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
 CGFloat placeHolderHeight = self.topView.height - self.topView.itemHeight;
 CGFloat offsetY = scrollView.contentOffset.y;
 if (offsetY >= 0 && offsetY <= placeHolderHeight) {
  self.topView.y = -offsetY;
 } else if (offsetY > placeHolderHeight) {
  self.topView.y = - placeHolderHeight;
 } else if (offsetY <0) {
  self.topView.y = - offsetY;
 }
}

完整项目下载地址如下:https://github.com/maxzhang123/nestScrollView  或者本地下载地址:http://xiazai./201705/yuanma/nestScrollView().rar

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# ios  # uiscrollview嵌套  # uiscrollview嵌套滚动  # iOS ScrollView嵌套tableView联动滚动的思路与最佳实践  # ios scrollview嵌套tableview同向滑动的示例  # scrollview tableView嵌套解决方案示例  # 自定义  # 单击  # 的是  # 会有  # 好了  # 本地下载  # 下载地址  # 不是很  # 落在  # 想了  # 写了  # 它可以  # 可以实现  # 这篇文章  # 谢谢大家  # 看看吧  # 需要注意  # 为有  # 就可以  # 滚动条 


相关文章: 香港服务器WordPress建站指南:SEO优化与高效部署策略  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  网站制作公司排行榜,抖音怎样做个人官方网站  北京的网站制作公司有哪些,哪个视频网站最好?  如何通过万网虚拟主机快速搭建网站?  专业公司网站制作公司,用什么语言做企业网站比较好?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  javascript中的try catch异常捕获机制用法分析  高防服务器如何保障网站安全无虞?  免费视频制作网站,更新又快又好的免费电影网站?  小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  网站制作话术技巧,网站推广做的好怎么话术?  宝塔新建站点为何无法访问?如何排查?  如何快速搭建响应式可视化网站?  建站之星会员如何解锁更多建站功能?  建站主机服务器选型指南与性能优化方案解析  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  如何通过虚拟主机快速完成网站搭建?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  网站按钮制作软件,如何实现网页中按钮的自动点击?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  C#怎么创建控制台应用 C# Console App项目创建方法  如何在景安云服务器上绑定域名并配置虚拟主机?  如何破解联通资金短缺导致的基站建设难题?  Python文件管理规范_工程实践说明【指导】  如何获取开源自助建站系统免费下载链接?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何在局域网内绑定自建网站域名?  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  如何通过VPS建站无需域名直接访问?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  如何通过可视化优化提升建站效果?  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  简单实现Android验证码  高端智能建站公司优选:品牌定制与SEO优化一站式服务  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  宝塔Windows建站如何避免显示默认IIS页面?  建站之星导航菜单设置与功能模块配置全攻略  网站企业制作流程,用什么语言做企业网站比较好?  如何快速搭建高效简练网站?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  实惠建站价格推荐:2025年高性价比自助建站套餐解析  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  北京网站制作网页,网站升级改版需要多久?  高性价比服务器租赁——企业级配置与24小时运维服务 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。