YYKit源码探究(二十) —— UIScrollView分类(一)

版本记录

版本号 时间
V1.0 2018.03.25

前言

iOS圈内有几个人大家基本都知道,比如说王巍、唐巧,还有YYKit框架的作者现任职于滴滴的郭曜源 - ibireme等。这里有一篇唐巧对他的专访,还有他的 GitHub - Yaoyuan博客,这里贴出来框架YYKit 框架。接下来几篇我们就一起来看一下这个框架。感兴趣的可以看上面写的几篇。
1. YYKit源码探究(一) —— 基本概览
2. YYKit源码探究(二) —— NSString分类之Hash(一)
3. YYKit源码探究(三) —— NSString分类之Encode and decode(二)
4. YYKit源码探究(四) —— NSString分类之Drawing(三)
5. YYKit源码探究(五) —— NSString分类之Regular Expression(四)
6. YYKit源码探究(六) —— NSString分类之NSNumber Compatible(五)
7. YYKit源码探究(七) —— NSString分类之Utilities(六)
8. YYKit源码探究(八) —— NSNumber分类(一)
9. YYKit源码探究(九) —— UIFont分类之架构分析和Font Traits(一)
10. YYKit源码探究(十) —— UIFont分类之Create font(二)
11. YYKit源码探究(十一) —— UIFont分类之Load and unload font(三)
12. YYKit源码探究(十二) —— UIFont分类之Dump font data(四)
13. YYKit源码探究(十三) —— UIImage分类之框架结构和Create image部分(一)
14. YYKit源码探究(十四) —— UIImage分类之Image Info(二)
15. YYKit源码探究(十五) —— UIImage分类之Modify Image(三)
16. YYKit源码探究(十六) —— UIImage分类之Image Effect(四)
17. YYKit源码探究(十七) —— UIImageView分类之架构和image部分(一)
18. YYKit源码探究(十八) —— UIImageView分类之highlight image部分(二)
19. YYKit源码探究(十九) —— UIScreen分类(一)

回顾

上一篇主要介绍了UIScreen分类,这一篇主要看一下UIScrollView部分。


API

下面我们看一下API。

/**
 Scroll content to top with animation.
 */
- (void)scrollToTop;

/**
 Scroll content to bottom with animation.
 */
- (void)scrollToBottom;

/**
 Scroll content to left with animation.
 */
- (void)scrollToLeft;

/**
 Scroll content to right with animation.
 */
- (void)scrollToRight;

/**
 Scroll content to top.
 
 @param animated  Use animation.
 */
- (void)scrollToTopAnimated:(BOOL)animated;

/**
 Scroll content to bottom.
 
 @param animated  Use animation.
 */
- (void)scrollToBottomAnimated:(BOOL)animated;

/**
 Scroll content to left.
 
 @param animated  Use animation.
 */
- (void)scrollToLeftAnimated:(BOOL)animated;

/**
 Scroll content to right.
 
 @param animated  Use animation.
 */
- (void)scrollToRightAnimated:(BOOL)animated;

下面我们就看一下这个API文档。

1. - (void)scrollToTop;

该方法的作用就是滚动内容到顶部。

方法实现

这个方法的实现还是很好理解的吧。

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

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

2. - (void)scrollToBottom;

该方法的作用就是滚动内容到底部。

方法实现

- (void)scrollToBottom {
    [self scrollToBottomAnimated:YES];
}

- (void)scrollToBottomAnimated:(BOOL)animated {
    CGPoint off = self.contentOffset;
    off.y = self.contentSize.height - self.bounds.size.height + self.contentInset.bottom;
    [self setContentOffset:off animated:animated];
}

3. - (void)scrollToLeft;

该方法的作用就是滚动内容到左侧。

方法实现

- (void)scrollToLeft {
    [self scrollToLeftAnimated:YES];
}

- (void)scrollToLeftAnimated:(BOOL)animated {
    CGPoint off = self.contentOffset;
    off.x = 0 - self.contentInset.left;
    [self setContentOffset:off animated:animated];
}

4. - (void)scrollToRight;

该方法的作用就是滚动内容到右侧。

方法实现

- (void)scrollToRight {
    [self scrollToRightAnimated:YES];
}

- (void)scrollToRightAnimated:(BOOL)animated {
    CGPoint off = self.contentOffset;
    off.x = self.contentSize.width - self.bounds.size.width + self.contentInset.right;
    [self setContentOffset:off animated:animated];
}

5. - (void)scrollToTopAnimated:(BOOL)animated;

滚动到顶部,可以选择是否动画。

方法实现

这个的实现上面已经给出过了,这里就不多说了。

6. - (void)scrollToBottomAnimated:(BOOL)animated;

滚动到底部,可以选择是否动画。

方法实现

这个的实现上面已经给出过了,这里就不多说了。

7. - (void)scrollToLeftAnimated:(BOOL)animated;

滚动到左边,可以选择是否动画。

方法实现

这个的实现上面已经给出过了,这里就不多说了。

8. - (void)scrollToRightAnimated:(BOOL)animated;

滚动到右边,可以选择是否动画。

方法实现

这个的实现上面已经给出过了,这里就不多说了。

后记

本篇主要内容就是UIScrollView分类,感兴趣的可以关注和给个赞~~~~

推荐阅读更多精彩内容