UIScrollview自定义分页大小

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

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

UIScrollview自定义分页大小_第1张图片

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

UIScrollview自定义分页大小_第2张图片

默认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

你可能感兴趣的:(【开发技术】IOS)