1.继承链:UIview:UIresponder:NSObject

引言

UIScrollView的是几个UIKit类包括的UITableView和UITextView中的超类。

一个UIScrollView对象(或者,简单地说,一个滚动视图)的核心概念是,它是一个视图,其起源是可调过的内容视图。它剪辑的内容,它的框架,这通常(但不一定)恰逢该应用程序的主窗口。滚动视图跟踪手指的变动,并相应调整原点。这正显示出它的内容“,通过”滚动视图的视图绘制的基础上,新的原点,它被固定在内容视图的偏移部分本身。滚动视图本身没有绘制,除了显示垂直和水平滚动的指标。滚动视图必须知道的内容视图的大小,所以它知道何时停止滚动,默认情况下,它“反弹”回来时,滚动超出了内容的范围。

用于管理内容的绘制有关的对象显示在一个滚动视图应该瓦片的内容的子视图,以便没有视图超过屏幕的大小。当用户在滚动滚动视图,这个对象应该添加和删除子视图是必要的。

由于滚动视图没有滚动条,它必须知道是否触摸信号的意图与滚动意图在内容跟踪一个子视图。做出此决定,它暂时拦截触摸按下事件通过启动一个定时器,并在定时器触发之前,看是否触摸手指做任何运动。如果定时器触发无位置显著的变化,滚动视图将跟踪事件的内容视图的感动子视图。然后,如果用户在定时器期满前拉着自己的手指远远不够,滚动视图将取消任何跟踪的子视图,并进行滚动本身。子类可以重写touchesShouldBegin : withEvent:方法inContentView :,pagingEnabled和touchesShouldCancelInContentView :方法(这是由滚动视图调用)来影响滚动视图如何处理滚动手势。

滚动视图还处理缩放和平移的内容。当用户使一个夹在或向外挤压手势,滚动视图调整偏移量和内容的标度。当手势结束,管理内容视图中的对象应该要更新的内容为必要的子视图。 (请注意,手势可以结束和手指仍可能下跌。 )虽然手势正在进行中,滚动视图不发送任何跟踪调用子视图。

该UIScrollView的类可以有必须采取UIScrollViewDelegate协议的委托。对于缩放和平移工作,委托必须实现viewForZoomingInScrollView :和scrollViewDidEndZooming : withView : atScale : ,此外,最大( maximumZoomScale )和最小( minimumZoomScale )变焦倍数必须是不同的。

方法&&属性:

// 监控目前滚动的位置(默认CGPointZero)

  1. CGPoint contentOffset;
  2. - (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated;

// 滚动范围的大小(默认CGSizeZero)

  1. CGSize contentSize;

// 视图在scrollView中的位置(UIEdgeInsetsZero)

  1. UIEdgeInsets contentInset;

// 设置协议

  1. id<UIScrollViewDelegate> delegate;

// 指定控件是否只能在一个方向上滚动(默认为NO)

  1. BOOL directionalLockEnabled;

// 控制控件遇到边框是否反弹(默认为YES)

  1. BOOL bounces;

// 控制垂直方向遇到边框是否反弹(默认为NO,如果为YES,bounces也是YES)

  1. BOOL alwaysBounceVertical;

// 控制水平方向遇到边框是否反弹(默认为NO,如果为YES,bounces也是YES)

  1. BOOL alwaysBounceHorizontal;

// 控制控件是否整页翻动(默认为NO)

  1. BOOL pagingEnabled;

// 控制控件是否能滚动

  1. BOOL scrollEnabled;

// 控制是否显示水平方向的滚动条

  1. BOOL showsHorizontalScrollIndicator;

// 控制是否显示垂直方向的滚动条

  1. BOOL showsVerticalScrollIndicator;

// 指定滚动条在scrollerView中的位置

  1. UIEdgeInsets scrollIndicatorInsets;

// 设定滚动条的样式

  1. UIScrollViewIndicatorStyle indicatorStyle;

UIScrollViewDelegate详解

  1. //scrollView滚动时,就调用该方法。任何offset值改变都调用该方法。即滚动过程中,调用多次
  2. - (void)scrollViewDidScroll:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewDidScroll");
  4. CGPoint point=scrollView.contentOffset;
  5. NSLog(@"%f,%f",point.x,point.y);
  6. // 从中可以读取contentOffset属性以确定其滚动到的位置。
  7. // 注意:当ContentSize属性小于Frame时,将不会出发滚动
  8. }
  1. // 当scrollView缩放时,调用该方法。在缩放过程中,回多次调用
  2. - (void)scrollViewDidZoom:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewDidScroll");
  4. float value=scrollView.zoomScale;
  5. NSLog(@"%f",value);
  6. }
  1. // 当开始滚动视图时,执行该方法。一次有效滑动(开始滑动,滑动一小段距离,只要手指不松开,只算一次滑动),只执行一次。
  2. - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewWillBeginDragging");
  4. }
  1. // 滑动scrollView,并且手指离开时执行。一次有效滑动,只执行一次。
  2. // 当pagingEnabled属性为YES时,不调用,该方法
  3. - (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{
  4. NSLog(@"scrollViewWillEndDragging");
  5. }
  1. // 滑动视图,当手指离开屏幕那一霎那,调用该方法。一次有效滑动,只执行一次。
  2. // decelerate,指代,当我们手指离开那一瞬后,视图是否还将继续向前滚动(一段距离),经过测试,decelerate=YES
  3. - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{
  4. NSLog(@"scrollViewDidEndDragging");
  5. if (decelerate) {
  6. NSLog(@"decelerate");
  7. }else{
  8. NSLog(@"no decelerate");
  9. }
  10. CGPoint point=scrollView.contentOffset;
  11. NSLog(@"%f,%f",point.x,point.y);
  12. }
  1. // 滑动减速时调用该方法。
  2. - (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewWillBeginDecelerating");
  4. // 该方法在scrollViewDidEndDragging方法之后。
  5. }
  1. // 滚动视图减速完成,滚动将停止时,调用该方法。一次有效滑动,只执行一次。
  2. - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewDidEndDecelerating");
  4. [_scrollView setContentOffset:CGPointMake(0, 500) animated:YES];
  5. }
  1. // 当滚动视图动画完成后,调用该方法,如果没有动画,那么该方法将不被调用
  2. - (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewDidEndScrollingAnimation");
  4. // 有效的动画方法为:
  5. // - (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated 方法
  6. // - (void)scrollRectToVisible:(CGRect)rect animated:(BOOL)animated 方法
  7. }
  1. // 返回将要缩放的UIView对象。要执行多次
  2. - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{
  3. NSLog(@"viewForZoomingInScrollView");
  4. return self.imgView;
  5. }
  1. // 当将要开始缩放时,执行该方法。一次有效缩放,就只执行一次。
  2. - (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view{
  3. NSLog(@"scrollViewWillBeginZooming");
  4. }
  1. // 当缩放结束后,并且缩放大小回到minimumZoomScale与maximumZoomScale之间后(我们也许会超出缩放范围),调用该方法。
  2. - (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale{
  3. NSLog(@"scrollViewDidEndZooming");
  4. }
  1. // 指示当用户点击状态栏后,滚动视图是否能够滚动到顶部。需要设置滚动视图的属性:_scrollView.scrollsToTop=YES;
  2. - (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView{
  3. return YES;
  4. }
  1. // 当滚动视图滚动到最顶端后,执行该方法
  2. - (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView{
  3. NSLog(@"scrollViewDidScrollToTop");
  4. }

Tip:判断uiscrollview是向上滚动还是向下滚动

  1. int _lastPosition; //A variable define in headfile
  2. - (void)scrollViewDidScroll:(UIScrollView *)scrollView{
  3. int currentPostion = scrollView.contentOffset.y;
  4. if (currentPostion - _lastPosition > 25) {
  5. _lastPosition = currentPostion;
  6. NSLog(@"ScrollUp now");
  7. }
  8. else if (_lastPosition - currentPostion > 25)
  9. {
  10. _lastPosition = currentPostion;
  11. NSLog(@"ScrollDown now");
  12. }
  13. }
  14. // 25 可以是任意数字,可根据自己的需要来设定。
  1. // 升级版:到达顶部或底部时不会反弹
  2. - (void)scrollViewDidScroll:(UIScrollView *)scrollView
  3. {
  4. int currentPostion = scrollView.contentOffset.y;
  5. if (currentPostion - _lastPosition > 20 && currentPostion > 0) { //这个地方加上 currentPostion > 0 即可)
  6. _lastPosition = currentPostion;
  7. NSLog(@"ScrollUp now");
  8. }
  9. else if ((_lastPosition - currentPostion > 20) && (currentPostion <= scrollView.contentSize.height-scrollView.bounds.size.height-20) ){
  10. _lastPosition = currentPostion;
  11. NSLog(@"ScrollDown now");
  12. }
  13. }
  14.  
  15. 2.UIScrollViewIndicatorStyle的类型:
        UIScrollViewIndicatorStyleDefault:黑色白框
        UIScrollViewIndicatorStyleBlack:黑色的滚动框
        UIScrollViewIndicatorStyleWhite :白色的滚动条
    3.Deceleration Constants的类型:
        const float UIScrollViewDecelerationRateNormal:正常的拖动速度
        const float UIScrollViewDecelerationRateFast:快速的拖动
    UIScrollViewKeyboardDismissModeNone:拖动的时候不解除键盘
    UIScrollViewKeyboardDismissModeOnDrag:开始拖动的时候解除键盘
    UIScrollViewKeyboardDismissModeInteractive  :点击画面以外的地方就解除键盘

UIkit框架之UIScrollView的更多相关文章

  1. iOS开发概述UIkit动力学,讲述UIKit的Dynamic特性,UIkit动力学是UIkit框架中模拟真实世界的一些特性。

    转发:http://my.oschina.net/u/1378445/blog/335014 iOS UIKit动力学 Dynamics UIAttachmentBehavior 实现iMessage ...

  2. 79、iOS 的Cocoa框架、Foundation框架以及UIKit框架

    Cocoa框架是iOS应用程序的基础 1. Cocoa是什么? Cocoa是 OS X和ios 操作系统的程序的运行环境. 是什么因素使一个程序成为Cocoa程序呢?不是编程语言,因为在Cocoa开发 ...

  3. UIKit框架使用总结--看看你掌握了多少

    一.经常使用的,基本就是每次项目迭代都需要使用的 UIView.UILabel.UIImage.UIColor.UIFont.UIImageView.UITextField.UIButton. UIS ...

  4. Swift - 重写UIKit框架类的init初始化方法(以UITabBarController为例)

    原来写了篇文章讲UITabBarController的用法,当时是从UIViewController跳转到UITabBarController页面,代码如下: 1 self.presentViewCo ...

  5. UIKit框架

    在今后的应用程序构建中,会陆续使用各式各样的控件,因此UIKit框架的引入是必不可少的! 一.简介 UIKitk框架提供一系列的Class(类)来建立和管理iPhone OS应用程序的用户界面接口.应 ...

  6. iOS学习32之UIKit框架-可视化编程-XIB

    1. Interface Builder 可视化编程 1> 概述 GUI : 图形用户界面(Graphical User Interface, 简称GUI, 又称图形化界面) 是指采用图形方式显 ...

  7. 基础框架Fundation和UIkit框架的定义和使用

    Foundation 框架为所有应用程序提供基本的系统服务 您的应用程序以及 UIKit 和其他框架,都建立在 Foundation 框架的基础结构之上.Foundation 框架提供许多基本的对象类 ...

  8. iOS开发UIKit框架-可视化编程-XIB

    1. Interface Builder 可视化编程 1> 概述 GUI : 图形用户界面(Graphical User Interface, 简称GUI, 又称图形化界面) 是指采用图形方式显 ...

  9. UIKit 框架之UIView二

    下面这些都是UIView一些基本的东西,具体的可以参考UIKit 框架之UIView一博客 一.自定义一个View // // MyView.m // UIView // // Created by ...

随机推荐

  1. javascript之with的使用 弊端

    妹的,昨天都快写完了,一不小心点了个关闭,然后...就没有然后了 wordpress的自动保存功能咋就这么不靠谱呢 记得还在懵懂学习JavaScript基础之时,坊间便有传言“with语句是低效率语句 ...

  2. HTML5自学笔记[ 20 ]canvas绘图实例之绘制倒影

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  3. Windows安装Python图像处理库:PIL模块

    平常一般都在Linux下用Python,今天女票突然说让帮忙把一些图片全部弄成一个分辨率的,作为程序员,这种重复的工作还是交给计算机吧. 废话不多说,打开Cmd看下Windows的python下面是否 ...

  4. hdu 3908 Triple(组合计数、容斥原理)

    Triple Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 125536/65536 K (Java/Others) Total Su ...

  5. Populating Next Right Pointers in Each Node II [Leetcode]

    Problem Description http://oj.leetcode.com/problems/populating-next-right-pointers-in-each-node-ii/ ...

  6. jquery UI datepicker时间控件的使用

    参考: http://api.jqueryui.com/datepicker/#method-show 英文 http://www.helloweba.com/view-blog-168.html 中 ...

  7. word文档中查找和替换空格符和回车符

    空格符:^l 回车符:^p

  8. centos彻底删除文件夹、文件命令

    [1]新建文件夹 格式:mkdir 文件名 view source1 mkdir /home/test     新建一个名为test的文件夹在home下 [2]新建文本 vi /home/test.s ...

  9. 《JavaScript权威指南》读书笔记(四)

    日期:2015-12-06 事件传播:1.捕捉阶段2.运行阶段3.起泡阶段cookie和客户端持久性::HTML5引入了web应用缓存.LocalStorage.SessionStorage:使用XM ...

  10. Laravel

    Laravel是一套简洁.优雅的PHP Web开发框架(PHP Web Framework).它可以让你从面条一样杂乱的代码中解脱出来:它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁.富于 ...