移动设备的屏幕大小是极其有限的,因此直接展示在用户眼前的内容也相当有限
当展示的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容
普通的UIView不具备滚动功能,不能显示过多的内容
UIScrollView是一个能够滚动的视图控件,可以用来展示大量的内容,并且可以通过滚动查看所有的内容
举例:手机上的“设置”、其他示例程序
UIScrollView的基本使用
UIScrollView的使用很简单,直接讲需要显示的UI内容添加到UIScrollView中即可。设置UIScrollView的contentSize属性,告诉UIScrollView所有内容的尺寸,也就是告诉它滚动范围。
UIScrollView无法滚动的原因:1:没有设置UIScrollView的contentSize属性。
2:UIScrollView的scrollviewEnaael属性为NO。
3:没有接受到点击事件 userInteractionEnabled属性为NO
4:在XIB的情况下,没有取消autolayout功能呢。(若要UIScrollView滚动)必须取消此功能
UIScrollView的常见属性
(内容偏移量:内容左上角减去scoreView左上角差的值,用户只要稍微动一下,图片就会再次弹回原始的位置)
@property(nonatomic) CGPoint contentOffset;
这个属性用来设置UIScrollView能滚动到的范围
@property(nonatomic)CGSize contentSize;
这个属性用来记录UIScrollView滚到的位置(能在四周添加额外的滚动区域)
@property(nonatomic) UIEdgeInsets contentInset;
代理
@property(nullable,nonatomic,weak)id<UIScrollViewDelegate> delegate;
UIScrollView其他属性
设置UIScrollView是否需要弹簧效果
@property(nonatomic) BOOL bounces;
当值是 YES 会自动滚动到 subview 的边界。默认是NO
@property(nonatomic,getter=isPagingEnabled)BOOL pagingEnabled__TVOS_PROHIBITED;
设置UIScrollView是否能滚动
@property(nonatomic,getter=isScrollEnabled)BOOL scrollEnabled;
设置是否显示水平滚动条
@property(nonatomic) BOOL showsHorizontalScrollIndicator;
设置是否显示垂直滚动条
@property(nonatomic)BOOL showsVerticalScrollIndicator;
touch的时还没有拖动的时候是YES 否则是NO
@property(nonatomic,readonly,getter=isTracking)BOOL tracking;
正在缩放的时候是YES 否则是NO
@property(nonatomic,readonly,getter=isZooming)BOOL zooming;
当滚动后,手指放开但是还在继续滚动中。这个时候是 YES,其它时候是 NO
@property(nonatomic,readonly,getter=isDecelerating)BOOL decelerating;
设置手指放开后的减速率
@property(nonatomic) GFloat decelerationRateNS_AVAILABLE_IOS(3_0);
一个浮点数,表示能缩最小的倍数
@property(nonatomic)CGFloat minimumZoomScale;
一个浮点数,表示能放最大的倍数
@property(nonatomic)CGFloat maximumZoomScale;
需要动画 第一个参数是你要滚动到的位置 第二个参数是是否要动画效果
[self.scrollView setContentOffset:CGPointMake(0,self.scrollView.contentOffset.y)animated:YES];
是否有弹簧效果
self.scrollView.bounces =NO;
不管有没有contentSize,都能拥有弹簧效果(一般适用于下拉刷新功能,上拉刷新)
self.scrollView.alwaysBounceVertical= YES; (弹簧效果)
self.scrollView.alwaysBounceHorizontal= YES;(水平效果可以滚来滚去)
是否要显示滚动条
self.scrollView.showsHorizontalScrollIndicator =NO;
self.scrollView.showsVerticalScrollIndicator =NO;
self.scrollView.indicatorStyle =UIScrollViewIndicatorStyleWhite;
NSLog(@"%@",self.scrollView.subviews);
[[self.scrollView.subviews firstObject]removeFromSuperview];
/**
UIControlStateNormal;
UIControlStateHighlighted;
UIControlStateDisabled;禁止状态//只能通过enabled=NO达到这个状态
设置userInteractionEnabled=NO,可以禁止一些事件,比如点击和拉拽(意思是禁止和用户交互)
*/
UISCrollView的代理
1.代理一般都是控制器对象
2.代理一般都是id类型 (注意代理是弱指针,如果是强指针会内存泄露)
遵守代理
@interface ViewController ()<UIScrollViewDelegate>
设置代理
scrollview.delegate = self;
/**
只要视图在滚动就会一直掉用这个方法
@param scrollView 滚动视图
*/
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
NSLog(@"滚动");
}
/**
即将开始拖拽的时候调用
@param scrollView UIScrollView
*/
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
}
/**
用户即将停止拖拽UIScrollView会调用此方法
@param scrollView 停止拖拽的UIScrollView
@param velocity 速度
@param targetContentOffset 内容偏移
*/
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset
{
NSLog(@"即将停止拖拽");
}
/**
用户已经停止拖拽UIScrollView掉用这个方法
@param scrollView 停止拖拽的UIScrollView
@param decelerate 停止拖拽之后的减速速率
*/
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
NSLog(@"停止拖拽,做减速运动");
}
/**
UIScrollView即将做减速运动的时候调用
@param scrollView 做减速的UIScrollView
*/
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
{
NSLog(@"将要开始做减速运动");
}
/**
结束减速运动时候调用
@param scrollView UIScrolleView
*/
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
NSLog(@"减速运动结束");
}
/**
结束滚动动画的时候调用
@param scrollView UIScrollView
*/
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView
{
}
/**
设置缩放视图
@param scrollView UIScrollView
@return 缩放视图
*/
- (nullable UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
{
return nil;
}
/**
视图开始缩放的时候调用
@param scrollView UIScrpllView
@param view 缩放的视图
*/
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(nullable UIView *)view
{
}
/**
结束缩放的时候调用
@param scrollView UIScrollView
@param view 缩放的视图
@param scale 规模
*/
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(nullable UIView *)view atScale:(CGFloat)scale
{
}
/**
缩放的时候一直调用
@param scrollView UIScrollView
*/
- (void)scrollViewDidZoom:(UIScrollView *)scrollView
{
}
/**
滚动视图是否能滚动到顶部
@param scrollView UIScrollView
@return YES OR NO
*/
- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView
{
return YES;
}
/**
滚动到顶部的时候调用
@param scrollView UIScrolliew
*/
- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView
{
}
UIScrollView和delegate的通信
UIScrollView的内容缩放当我们用UIScrollView浏览一些内容的时候,有时候需要对内容进行缩放。
UIScrollew不仅能显示大量的内容,还能对其内容进行缩放处理。只要将需要缩放的内容添加到UIScrollew上即可。
缩放实现步骤
跟缩放相关的其他代理方法
准备开始缩放的时候调用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view
正在缩放的时候调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView
核心代码:设置内容大小
contentSize.height == 0 设置为0仅仅代表竖直方向上不能滚动
self.scrollView.contentSize = CGSizeMake(count * w, 0);
UIScrollerView的分页功能
每一页的尺寸都是跟scrollView的frame.size一样的
self.scrollView.pagingEnabled = YES;
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
--四舍五入为整数的方法-- (int)(小数 + 0.5)
0.3 -> (int)(0.3 + 0.5) == 0
0.4 -> (int)(0.4 + 0.5) == 0
1.5 -> (int)(1.5 + 0.5) == 2
0.7 -> (int)(0.7 + 0.5) == 1
小数加上0.5再转换成整数,这样页码显示的就是正确的页数(仔细想)
int page = (int)(scrollView.contentOffset.x / scrollView.frame.size.width + 0.5);
self.pageControl.currentPage = page;
}
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
int page = scrollView.contentOffset.x / scrollView.frame.size.width;
self.pageControl.currentPage = page;
}
分页
只要将UIScrollView的pageEnabled属性设置为YES,UIScrollView会被分割成多个独立页面,里面的内容就能进行分页展示
一般会配合UIPageControl增强分页效果,UIPageControl常用属性如下
一共有多少页
@property(nonatomic) NSInteger numberOfPages;
当前显示第几页
@property(nonatomic) NSIntegercurrentPage;
只有一页时,是否需要隐藏页码指示器
@property(nonatomic) BOOL hidesForSinglePage;
其他页码指示器的颜色
@property(nonatomic,retain) UIColor *pageIndicatorTintColor;
当前页码指示器的颜色
@property(nonatomic,retain) UIColor *currentPageIndicatorTintColor;