1、简单介绍UIScrollView
移动设备的屏幕大小是有限的,因此直接展示在用户眼前的内容也相当有限。当展示的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容,普通的UIView不具备滚动功能,不能显示过多的内容。
UIScrollView是一个能够滚动的视图控件,可以用来展示大量的内容,并且可以通过滚动查看所有的内容。
2、UIScrollView常用属性和方法
内容视图相关
@property(nonatomic) CGSize contentSize; //这个属性用来表示UIScrollView内容的尺寸,滚动范围
@property(nonatomic) CGPoint contentOffset; //内容偏移量,表示UIScrollView滚动到的位置
@property(nonatomic) UIEdgeInsets contentInset; //内边距
// 设置内容视图的原点相对于scrollView的原点的偏移量
- (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated;
滑动相关
@property(nonatomic,getter=isDirectionalLockEnabled) BOOL directionalLockEnabled; //是否只允许同时滑动一个方向
@property(nonatomic,getter=isPagingEnabled) BOOL pagingEnabled; //是否分页
@property(nonatomic,getter=isScrollEnabled) BOOL scrollEnabled; //是否能滚动
@property(nonatomic) BOOL scrollsToTop;//是否允许点击状态栏让距离状态栏最近的scrollView滑动到顶部,默认为YES
@property(nonatomic) BOOL bounces; //是否有触底反弹效果,默认为YES
@property(nonatomic) BOOL alwaysBounceVertical;
@property(nonatomic) BOOL alwaysBounceHorizontal;
@property(nonatomic) CGFloat decelerationRate; //设置减速率
// 将指定区域滑动到刚好可见处(即距离边缘最近处)
- (void)scrollRectToVisible:(CGRect)rect animated:(BOOL)animated;
@property(nonatomic,readonly,getter=isTracking) BOOL tracking; //点击中
@property(nonatomic,readonly,getter=isDragging) BOOL dragging; //拖拽中
@property(nonatomic,readonly,getter=isDecelerating) BOOL decelerating; //减速滚动中
@property(nonatomic) BOOL delaysContentTouches; // 是否延迟事件传递,默认为YES
@property(nonatomic) BOOL canCancelContentTouches;// 是否可以取消内容视图被触摸,默认为YES
指示器相关
@property(nonatomic) BOOL showsHorizontalScrollIndicator; // 是否显示水平滚动条
@property(nonatomic) BOOL showsVerticalScrollIndicator; // 是否显示垂直滚动条
@property(nonatomic) UIEdgeInsets scrollIndicatorInsets; //为指示器周围增加可滚动区域
@property(nonatomic) UIScrollViewIndicatorStyle indicatorStyle; //指示器样式
// 闪一下指示器
- (void)flashScrollIndicators;
缩放相关
@property(nonatomic) CGFloat minimumZoomScale; // 能缩最小的倍数
@property(nonatomic) CGFloat maximumZoomScale; // 能放最大的倍数
@property(nonatomic) CGFloat zoomScale; //缩放比例
@property(nonatomic,readonly,getter=isZooming) BOOL zooming; // 缩放中
@property(nonatomic,readonly,getter=isZoomBouncing) BOOL zoomBouncing; // 是否允许触底反弹,默认为YES
// 设置缩放比例
- (void)setZoomScale:(CGFloat)scale animated:(BOOL)animated;
// 缩放到指定区域
- (void)zoomToRect:(CGRect)rect animated:(BOOL)animated;
键盘相关
@property(nonatomic) UIScrollViewKeyboardDismissMode keyboardDismissMode; //隐藏键盘模式
/*
UIScrollViewKeyboardDismissModeNone, //不隐藏键盘
UIScrollViewKeyboardDismissModeOnDrag, //当拖拽scrollView时隐藏键盘
UIScrollViewKeyboardDismissModeInteractive, //当拖拽键盘上方时隐藏键盘
*/
3、UIScrollView代理
滑动相关代理
// 当scrollView的contentOffset发生变化时调用
- (void)scrollViewDidScroll:(UIScrollView *)scrollView;
// 将要开始拖拽时调用(注: 该方法可能需要先滑动一段时间或距离才会被调用)
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView;
// 当用户停止拖拽时调用(注: 应用程序可以通过修改targetContentOffset参数的值来调整内容视图content view停止的位置)
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset;
// 当用户停止拖拽时调用(注: 如果内容视图content view在停止拖拽后继续移动,则decelerate参数为YES)
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate;
// 将要开始减速时调用(仅当停止拖拽后继续移动时才会被调用)
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView;
// 已经结束减速时调用(仅当停止拖拽后继续移动时才会被调用)
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;
// 返回是否允许点击状态栏让scrollView滑动到顶部,如果未实现该方法,则默认为YES(仅当scrollsToTop属性为YES时才调用)
- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView;
// 当scrollView已经滑动到顶部时调用(仅当点击状态栏让scrollView滑动到顶部才调用)
- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView;
// 当-setContentOffset:animated:/-scrollRectVisible:animated:方法动画结束时调用(仅当animated设置为YES时才调用)
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView;
缩放相关代理
// 当缩放比例更改时调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView;
// 参与缩放的子视图
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;
// 将要开始缩放时调用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;
// 已经结束缩放时调用
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale;