UIScrollView的属性总结html
=====属性=====做用===ios
CGPoint contentOffSet----------监控目前滚动的位置app
CGSize contentSize--------------滚动范围的大小测试
UIEdgeInsets contentInset---------视图在scrollView中的位置动画
id<UIScrollerViewDelegate> delegate------设置协议3d
BOOL directionalLockEnabled---------指定控件是否只能在一个方向上滚动htm
BOOL bounces------------控制控件遇到边框是否反弹对象
BOOL alwaysBounceVertical-------控制垂直方向遇到边框是否反弹blog
BOOL alwaysBounceHorizontal------控制水平方向遇到边框是否反弹事件
BOOL pagingEnabled-------控制控件是否整页翻动
BOOL scrollEnabled---------控制控件是否能滚动
BOOL showsHorizontalScrollIndicator------控制是否显示水平方向的滚动条
BOOL showsVerticalScrollIndicator----------控制是否显示垂直方向的滚动条
UIEdgeInsets scrollIndicatorInsets-----------指定滚动条在scrollerView中的位置
UIScrollViewIndicatorStyle indicatorStyle-设定滚动条的样式
float decelerationRate----------改变scrollerView的减速点位置
BOOL tracking-----------监控当前目标是否正在被跟踪
BOOL dragging---------监控当前目标是否正在被拖拽
BOOL decelerating---------监控当前目标是否正在减速
BOOL delaysContentTouches-------控制视图是否延时调用开始滚动的方法
BOOL canCancelContentTouches------------控制控件是否接触取消touch的事件
float minimumZoomScale------------缩小的最小比例
float maximumZoomScale---------放大的最大比例
float zoomScale------------设置变化比例
BOOL bouncesZoom-----------控制缩放的时候是否会反弹
BOOL zooming---------判断控件的大小是否正在改变
BOOL zoomBouncing------------判断是否正在进行缩放反弹
BOOL scrollsToTop--------------控制控件滚动到顶部
这里把UIScrollView的几个要点总结下:
从你的手指touch屏幕开始,scrollView开始一个timer,若是:
1. 150ms内若是你的手指没有任何动做,消息就会传给subView。
2. 150ms内手指有明显的滑动(一个swipe动做),scrollView就会滚动,消息不会传给subView,这里就是产生问题二的缘由。
3. 150ms内手指没有滑动,scrollView将消息传给subView,可是以后手指开始滑动,scrollView传送touchesCancelled消息给subView,而后开始滚动。
观察下tableView的状况,你先按住一个cell,cell开始高亮,手不要放开,开始滑动,tableView开始滚动,高亮取消。
4.delaysContentTouches的做用:
这个标志默认是YES,使用上面的150ms的timer,若是设置为NO,touch事件当即传递给subView,不会有150ms的等待。
5.cancelsTouches的做用:
这个标准默认为YES,若是设置为NO,这消息一旦传递给subView,这scroll事件不会再发生。
======UIScrollViewDelegate 协议========
//1. scrollView滚动时,就调用该方法。任何offset值改变都调用该方法。即滚动过程当中,调用屡次
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
// 从中能够读取contentOffset属性以肯定其滚动到的位置。
// 注意:当ContentSize属性小于Frame时,将不会出发滚动
NSLog(@"=====视图正在滚动====");
}
// 2. 当开始滚动视图时,执行该方法。一次有效滑动(开始滑动,滑动一小段距离,只要手指不松开,只算一次滑动),只执行一次。
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{
NSLog(@"----将要开始拖动--------");
}
//3. 滑动scrollView,而且手指离开时执行。一次有效滑动,只执行一次。
// 当pagingEnabled属性为YES时,不调用,该方法
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{
//第一个参数 是它自己
//第二个参数 是惯性值
//第三个参数 是中止的点 提早就算好了中止的位置
NSLog(@"---------将要中止拖动-----------");
}
//4. 滑动视图,当手指离开屏幕那一霎那,调用该方法。一次有效滑动,只执行一次。
// decelerate,指代,当咱们手指离开那一瞬后,视图是否还将继续向前滚动(一段距离),通过测试,decelerate=YES
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{
NSLog(@"----------已经中止拖动-------------");
}
//5. 滑动减速时调用该方法
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView{
NSLog(@"------将要开始减速------");
}
//6. 滚动视图减速完成,滚动将中止时,调用该方法。一次有效滑动,只执行一次
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
//这里能够取到当前是第几页
_index = scrollView.contentOffset.x / scrollView.frame.size.width;
// scrollView.contentOffset 不带动画
//设置偏移量 动画版
[scrollView setContentOffset:CGPointMake(150, 150) animated:YES];
NSLog(@"------------已经结束减速-------------");
}
//7. 当滚动视图动画完成后,调用该方法,若是没有动画,那么该方法将不被调用
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{
NSLog(@"已经结束位移动画");
}
//8. 当scrollView缩放时,调用该方法。在缩放过程当中,回屡次调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView{
NSLog(@"发生缩放");
}
//9. 返回将要缩放的UIView对象。要执行屡次
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{
return scrollView.subviews[0];
}
//10. 当将要开始缩放时,执行该方法。一次有效缩放,就只执行一次
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view{
//将要开始缩放
}
//11. 当缩放结束后,而且缩放大小回到minimumZoomScale与maximumZoomScale之间后(咱们也许会超出缩放范围),调用该方法
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale{
//将要结束缩放
}
//12. 指示当用户点击状态栏后,滚动视图是否可以滚动到顶部。须要设置滚动视图的属性:_scrollView.scrollsToTop=YES;
- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView{
return YES;
}
//13. 当滚动视图滚动到最顶端后,执行该方法
- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView{
//已经回到顶点
}
下面我就说一下scrollView的用法,设置app的导航页,带有小白点
1.遵循协议--<UIScrollViewDelegate>
2.建立scrollView
通常状况下,咱们建立一个UIScrollView全局变量和UIPageControl的全局变量
以下图:
初始化
===添加图片视图===
这一步,内容较多
重点的地方都标注了
【注意】设置_scrollView的contentSize,若是不设置,滚动视图不能左右滑动
其余几个属性也很重要,页须要设置,都作了注释
代码以下图:
添加小白点,滑动图片后会随着变更
建立小白点
滑动图片后的回调方法