UIScrollview自定义分页大小

Demo中UIScrollview的frame大小为屏幕大小:

1、自定义水平分页pageWidth = 300效果:

这里写图片描述

2、自定义垂直分页pageHeight = 400效果:

这里写图片描述

默认ios的UIScrollview系统只支持bound宽度或高度的分页,不能自定义分页大小,这种不能满足某些情况下交互需求,要实现自定义分页有以下两种方法:

方法1

  1. 将UIScrollview的bounds设置为需要分页的大小
  2. pagingEnabled = YES
  3. clipsToBounds = NO,从而能显示超出bounds的内容
  4. 此时自定义分页效果已经实现了,但是超出bounds的部分没办法响应触摸效果,这时候要重写UIScrollview的superView的hitTest:withEvent方法,通过重写hitTest, 就可以将superView接受到的触摸事件传递给UIScrollView
//这边注意重写的是滚动视图的父视图响应链方法
 - (UIView *) hitTest:(CGPoint) point withEvent:(UIEvent *)event {//这边根据需求自己改写
   if ([self pointInside:point withEvent:event]) {
     return scrollView;
   }
   return nil;
 }

方法2

  1. 创建一个UIScrollView的子类,重写delegate的get,set方法
  2. 在改子类里面实现滚动视图的delegate,通过在合适的时机人为设置偏移量,已达到自定义分页效果
  3. 要注意的点,一个是delegate设置,二是customPagingEnabled与系统分页不能同时开启,会产生拉到最后回弹的一个bug.
  4. 这边测试代码是用swift写的,OC也可以用,附上DEMO
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值