跟着苹果API & YYKit学习UIScrollView

作者两年iOS开发经验,通过阅读苹果api重温各个知识点,如果你喜欢这个系列,请关注我。有任何建议请留言。转载请注明来源。
本来这个系列只是单纯的苹果api学习笔记,后来想学习一下YYKit的源码,所以在文章中一并加入

作者:Roger


Managing the Display of Content

  • contentOffset
  • contentSize
  • contentInset

ScorllView最基本的三个属性:contentOffset表示ScorllView所展示区域左上角的坐标,contentSize表示ScrollView实际的尺寸,contentInset表示边界的偏移量。这三个概念需要自己多理解,包括字面意思和呈现的效果。附一张图方便理解:


scrollView.png

Managing Scrolling

  • scrollEnabled

    判断ScrollView是否可以滑动

  • directionalLockEnabled

    如果为NO,ScrollView可以随意的横向或纵向滑动。如果为YES,那么在一次滑动动作完成之前(即用户拖动完成并将手指从屏幕上举起),ScrollView只能响应其第一个接收到的滑动响应。即如果用户首先拖动ScrollView横向滑动,如果用户没有提起手指,那么用户无法再纵向拖动ScrollView,反之亦然。如果用户是斜线拖动,那么用户可以在一次滑动动作完成之前随意横行或纵向滑动。

  • scrollsToTop

    如果为YES,用户点击状态栏时,ScrollView会自动滑动到顶部,如果为NO,scrollViewShouldScrollToTop:方法返回NO,另一种返回NO的情况是ScrollView已经在顶部了。当滑动结束时会触发代理方法scrollViewDidScrollToTop:。此属性默认为YES。在iphone上如果屏幕上有多个ScrollView且scrollsToTop为YES,那么点击状态栏时无法触发滑动至顶的动作。

  • scrollRectToVisible:animated:

    定义一个矩形(包括大小和左上角位置),将ScrollView滑动到能展示这个矩形的区域内。如果这个矩形已经在ScrollView上展示出来,那么这个方法不做任何操作。

  • pagingEnabled

    判断ScrollView是否分页滑动

  • bounces

    判断ScrollView滑动到边缘时,是否有回弹的效果。

  • alwaysBounceHorizontal && alwaysBounceVertical

    如果bounces为YES,且这个属性也是YES,那么即使contentSize小于或等于sontentOffset,ScrollView滑动到边缘时,也会有回弹的效果。

  • touchesShouldBegin:withEvent:inContentView:

    如果想要将ScrollView的手势下传到ContentView,则返回YES


- (BOOL)touchesShouldBegin:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event inContentView:(UIView *)view{

    NSLog(@"secondView touchesShouldBegin");

    if ([view isKindOfClass:[UIButton class]]) {

        return YES;
    }
        return NO;
}

  • touchesShouldCancelIncontentView:

    填坑中...

  • canCancelContentTouches

    填坑中...

  • delaysContentTouches

    填坑中...

  • decelerationRate

    用户滑动到边界松手时,回弹的速度。范围在0.0到1.0之间。

  • draging

    判断用户是否正在滑动ScrollView(只读)。

  • tracking

    判断用户是否已经触碰在ScrollView上准备滑动(未滑动)(只读)。

  • decelerating

    判断用户滑动ScrollView且举起手指后,ScrollView是否正在滑动中。

Managing the Scroll Indicator

  • indicatorStyle

    枚举,设置滑动条样式

  • scrollIndicatorInsets

    设置滑动条的偏移量

  • showHorizontalScrollIndicator && showVerticalScrollIndicator

    展示横向/纵向的滑动条

  • - flashScrollIndicators

    闪一下滚动条,暗示是否有可滚动的内容。可以在ViewDidAppear或[table reload]之后调用。

Zooming and Panning

  • panGestureRecognizer && pinchGestureRecognizer

    填坑中...

  • zoomToRect:animated:

    将内容视图缩放到指定的Rect中。

  • zoomScale

    ScrollView的缩放比例,默认值为1.0。

  • setZoomScale:animated:

    设置程序缩放比例。

  • maximumZoomScale

    最大放大比例,默认值为1.0,不得小于minimumZoomScale。

  • minimumZoomScale

    最小放大比例,默认值为1,不得大于maxmumZoomScale。

  • zoomBouncing

    只读,当缩放超过最大或者最小范围的时候,回弹到最大最小范围的过程中,该值返回YES。

  • zooming

    只读,判断用户是否正在进行缩放手势。

  • bouncesZoom:

    描述在缩放超过缩放比例时,是否有bounce(回弹效果),默认值为YES。如果值为NO,则达到最大或最小缩放比例时会立即停止缩放。否则,产生回弹效果。

Managing the Keyboard

  • keyboardDismissMode

iOS 7.0新属性,枚举,设置ScrollView键盘收起的方式

  • UIScrollViewKeyboardDismissModeNone,
  • UIScrollViewKeyboardDismissModeOnDrag,
  • UIScrollViewKeyboardDismissModeInteractive
    OnDrag表示ScrollView滑动的时候收起键盘,Interactive表示随着ScollView的滑出一同收起键盘(实际操作触发条件是下拉ScrollView至顶部出发回弹效果时,回收键盘)。

Constants

  • UIScrollViewIndicatorStyle

    枚举,通过设置indicatorStyle,设置滑动条的风格

    • UIScrollViewIndicatorStyleDefault,
    • UIScrollViewIndicatorStyleBlack,
    • UIScrollViewIndicatorStyleWhite
  • Deceleration Constants

    枚举常量,通过属性decelerationRate设置回弹效果的回弹速度

    _scrollView.decelerationRate = UIScrollViewDecelerationRateNormal;
  • UIScrollViewDecelerationRateNormal,
  • UIScrollViewDecelerationRateFast

YYKit For UIScrollView

在UITableview中,有滑动到顶部的方法。在YYKit中,也给ScrollView添加了滑动到顶,底,左,右部的方法。
我们拿滑动到顶部的方法举例:

- (void)scrollToTop {
    [self scrollToTopAnimated:YES];
}

- (void)scrollToTopAnimated:(BOOL)animated {
    CGPoint off = self.contentOffset;
    off.y = 0 - self.contentInset.top;
    [self setContentOffset:off animated:animated];
}

其实实现方法很简单,就是将ScrollView的左上角坐标移动到ScrollView在顶部的(0+偏移量)的位置上。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容