UI之 05 ScrollView

简介:
我们今天我们讲的是一个滚动屏幕的控件:UIScrollView
我们都知道我们的移动设备的屏幕大小是有限的,因此直接展示在用户眼前的内容也相当有限的
当我们的展示的内容较多,超出一个屏幕时,用户可以通过滚动收拾来查看屏幕以外的的内容
普通的UIView是不具备滚动的功能的,不能显示过多的内容

01程序介绍:

  • 大图展示
  • 喜马拉雅
  • 图片缩放
  • 图片轮播器

2. 展示效果:

**大图展示: **

Snip20160313_5.png

**喜马拉雅: **

Snip20160313_6.png

**图片缩放: **

Snip20160313_7.png

**图片轮播: **


Snip20160313_1.png

这个最上面的那个图片会每隔一段时间, 自动换成下一个图片, 这个就类似于我们手机中的APP某宝中最上面播放广告的程序一样


1. storyboard的设置

  • ScrollView在这个位置, 只用将其拖入storyboard里面就行了
    Snip20160313_2.png

我们就直接利用这四个程序来介绍我们今天的关于ScrollView的新知识

1. 知识点介绍

  • ScrollView的使用方法:

将需要展示的内容添加到UIScrollView中
设置UIScrollView的contentSize属性,告诉UIScrollView所有内容的尺寸,也就是告诉它滚动的范围(能滚多远,滚到哪里是尽头)

  • 在我们的这个ScrollView中, 其实有很多的知识点:
    首先我们将要介绍的就是代理: UIScrollViewDelegate
    其实当用户在与手机屏幕交互的时候, 就是图片随着用户的手而改变的时候, 这个ScrollView的代理, 就会告诉他我们的图片已经到了那个位置,
Snip20160313_9.png

其中这里面也牵扯到了:

  • 关于我们的ScrollView的坐标问题:
Snip20160313_11.png
@property(nonatomic)CGPointcontentOffset; 
这个属性用来表示UIScrollView滚动的位置

@property(nonatomic)CGSizecontentSize; 
这个属性用来表示UIScrollView内容的尺寸,滚动范围(能滚多远)

@property(nonatomic)UIEdgeInsetscontentInset; 
这个属性能够在UIScrollView的4周增加额外的滚动区域

大图展示很简单

  • 就是 直接将 我们的图片放到我们的storyboard里面
Snip20160313_8.png
  • 代码编写:
#import "MJViewController.h"
@interface MJViewController () <UIScrollViewDelegate>

@property (weak, nonatomic) IBOutlet UIImageView *minionView;
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;

@end

@implementation MJViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
//    NSTimer
    self.scrollView.contentSize =     self.minionView.frame.size;
    self.scrollView.delegate = self;
}

@end

如果我们的图片无法滚动可能存在以下一个问题:

Snip20160313_13.png

2. 喜马拉雅:

关于喜马拉雅的程序其实是比较简单的

storyboard设置:

Snip20160313_22.png

**代码: **

#import "MJViewController.h"

@interface MJViewController ()
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;

@end

@implementation MJViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    self.scrollView.contentSize = CGSizeMake(0, 560);
    self.scrollView.contentInset = UIEdgeInsetsMake(64, 0, 44, 0);
    self.scrollView.contentOffset = CGPointMake(0, -64);
}

@end

然后, 就没有然后了, 其实就是这么简单.

3. 图片缩放

Snip20160313_23.png

**代码: **

#import "MJViewController.h"

@interface MJViewController () <UIScrollViewDelegate>
@property (weak, nonatomic) IBOutlet UIImageView *minionView;
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;

@end

@implementation MJViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    self.scrollView.contentSize = self.minionView.frame.size;
    self.scrollView.maximumZoomScale = 2.0;
    self.scrollView.minimumZoomScale = 0.2;
}

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
{
    return self.minionView;
}

@end

这里我们详细介绍一下代理

很多时候,我们想在UIScrollView正在滚动的 或者 滚动到某个位置 或者 停止滚动 时做一写特定的操作
但是想要完成上述的功能,前提条件就是能够监听到UIScrollView的整个滚动的过程
当我们的UIScrollView发生一系列的滚动操作时,会自动通知它的代理(delegate)对象,给它的代理发送相应的消息,让代理得知它的情况
我们的这个代理是我们这个UIScrollView自己含有的一个属性,而这个属性主要工作就是监听我们的UIScrollView的滚动情况
注意的是在我们以前就说过我们的代理是需要我们的协议的,这个协议里面放的方法就是这些:

Snip20160313_24.png

如果有人不大清楚代理模式(详见我的文集OC学习笔记)里面有关于我们的代理模式的笔记
一般我们都是用我们的控制器做我们的UIScrollView代理
协议的命名规范:一般是以我们的这个代理者的名称开头
三个步骤:
1、遵守协议:

  @interface MJViewController () <UIScrollViewDelegate>

2、设置控制器ScrollView的delegate:

Snip20160313_25.png

3、实现代理的协议里面的方法。
作用:1、监听(监听我们任何时间的任何事件监听)让一个对象A监听另一个对象B的行为
2、通知思想(一个对象做了某件事情通知另一个对象)

所以以上就是关于代理的知识点, 和他的使用方法

重点: 图片轮播器

注意:我们的这个图片轮播器将我们的图片一张一张的显示出来
我们如果是直接将我们的UIView拖进去的话,我们不好控制,而且以后我们的图片增加的时候,我们不容易改变
所以我们分几步:
1、将一个UIScrollView放到我们的storyboard里面
2、我们利用我们的代码将我们的图片添加到这个里面
2.1、注意下面的代码中有一个控件:这个是我们分页的时候,当用户翻到多少页的时候的一个索引(Page Control)

Snip20160313_26.png

2.2、我们的分页功能是怎么做出来的?
就是我们的代码中没有告诉我们的控制器在何时、何处分页,他是怎么做到分页的?
我们的分页这个操作,我们的控制器是按照我们的UIScrollView的尺寸选择何处分页的,所以一般我们在给我们的UIScrollView设置尺寸的时候一定要按照我们的图片的尺寸来

即: 我们的scrollView每一次分页都是按照自己的尺寸来的, 所以我们将scrollView的尺寸设置的和我们所要播放的图片的尺寸大小一致, 就可以完成我们想要的效果

3、让我们的小按钮(索引)监听我们的图片的滚动

其他的麻烦大家看我自己原来的笔记吧, 抱歉, 我真的是混乱的不行了, 对不起了各位:

Snip20160313_40.png
Snip20160313_41.png
Snip20160313_41.png
Snip20160313_42.png

抱歉了, 各位. 我现在真的有点混乱了, 我会将代码全部写出来的, 大家, 看着代码理解吧. 真的很抱歉

图片轮播器的storyboard:

Snip20160313_43.png
代码:
#import "MJViewController.h"

const int MJImageCount = 5;

@interface MJViewController () <UIScrollViewDelegate>
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;
@property (weak, nonatomic) IBOutlet UIPageControl *pageControl;
@property (strong, nonatomic) NSTimer *timer;
@end

@implementation MJViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    // 1.添加图片
    CGFloat imageW = 300;
    CGFloat imageH = 130;
    CGFloat imageY = 0;
    for (int index = 1; index <= MJImageCount; index++) {
        CGFloat imageX = (index - 1) * imageW;
    
        UIImageView *imageView = [[UIImageView alloc] init];
        imageView.frame = CGRectMake(imageX, imageY, imageW, imageH);
        imageView.image = [UIImage imageNamed:[NSString stringWithFormat:@"img_%02d", index]];
    
        [self.scrollView addSubview:imageView];
    }

    // 2.设置内容尺寸
    self.scrollView.contentSize = CGSizeMake(imageW * MJImageCount, 0);
    self.scrollView.pagingEnabled = YES;

    // 3.分页
    self.pageControl.numberOfPages = MJImageCount;

    // 4.定时器
    self.timer = [NSTimer timerWithTimeInterval:1.5 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];
    [[NSRunLoop mainRunLoop] addTimer:self.timer     forMode:NSRunLoopCommonModes];
}

- (void)nextImage
{
    // 1.下一页
    if (self.pageControl.currentPage == MJImageCount - 1) {
        self.pageControl.currentPage = 0;
    } else {
        self.pageControl.currentPage++;
    }

    // 2.设置滚动
    CGPoint offset = CGPointMake(self.scrollView.frame.size.width * self.pageControl.currentPage, 0);
    [self.scrollView setContentOffset:offset animated:YES];
}

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    self.timer = [NSTimer timerWithTimeInterval:1.5 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];
    [[NSRunLoop mainRunLoop] addTimer:self.timer     forMode:NSRunLoopCommonModes];
}

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    [self.timer invalidate];
    self.timer = nil;
}

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    if (self.timer) return;
    self.pageControl.currentPage =     (scrollView.contentOffset.x +     scrollView.frame.size.width * 0.5) / scrollView.frame.size.width;
}
@end

作者说:

抱歉了各位, 真的很抱歉, 如果你点开了这篇文章, 如果你感觉浪费了你的流量, 真的很抱歉, 在写这篇文章的时候, 脑子确实有点乱, 真的很抱歉...
下一次,讲的是我这学期刚学的TableView, 那个文章会有条理一点. 这次真的很抱歉

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

推荐阅读更多精彩内容