UIScrollView的基本使用

UIScrollView作为iOS开发里基本控件,是我们第六个需要学习的。下面我来为大家介绍一下UIScrollView的一些常用属性和它们的用法。

这里附上UI控件演示的源码地址:https://github.com/LOLR2017/UIKitDemo。源码持续更新中...

因为部分代码是从Xcode直接拷贝出来的样式有误请谅解。

self.scrollView.frame = CGRectMake(0, 0, CGRectGetWidth(self.view.frame), CGRectGetHeight(self.view.frame));

    //设置scrollView的内容大小,这个大小我们只是演示展示多张图片时的内容大小,普通的可以根据自身的需要来设置大小

    self.scrollView.contentSize = CGSizeMake(CGRectGetWidth(self.view.frame) * 4, CGRectGetHeight(self.view.frame));

    //这里只是我们设置里面标签的位置,只是为了演示效果

    for (int i=0; i<self.scrollView.subviews.count; i++) {

        UIView *view = self.scrollView.subviews[i];

        view.frame = CGRectMake(100 + CGRectGetWidth(self.view.frame) * i, 100, 100, 30);

        [view sizeToFit];

    }

}


- (void)viewDidLoad {

    [super viewDidLoad];

    // Do any additional setup after loading the view, typically from a nib.

    

    self.scrollView = [[UIScrollView alloc] init];

    //因为我们的内容有四个屏幕那么大,所以我们添加四个标签

    for (int i=0; i<4; i++) {

        UILabel *label = [[UILabel alloc] init];

        label.textColor = [UIColor blackColor];

        label.font = [UIFont systemFontOfSize:17];

        label.text = [[NSString alloc] initWithFormat:@"这是第%d个标签",i];

        [self.scrollView addSubview:label];

    }

    

    //设置不能滚动到边界外面,当然你也可以只设置某一个方向滚动到边界外面(这里指的是手拖)

    self.scrollView.bounces = NO;

//    self.scrollView.alwaysBounceVertical = YES;

//    self.scrollView.alwaysBounceHorizontal = YES;

    //我们可以给一个背景颜色来看下bounces的效果

    self.scrollView.backgroundColor = [UIColor redColor];

    //设置是否显示水平和垂直显示条

    self.scrollView.showsVerticalScrollIndicator = NO;

    self.scrollView.showsHorizontalScrollIndicator = NO;

    //设置是否可以分页滚动

    self.scrollView.pagingEnabled = YES;

    

    

    //可以看做是内边距,这个属性一般用于调整界面使用

//    self.scrollView.contentInset = UIEdgeInsetsMake(0, -20, 0, 0);

    //设置滚动的偏移量,一般配合事件的触发使用

//    [self.scrollView setContentOffset:CGPointMake(0, 0) animated:YES];

    //设置scrollview的代理

    self.scrollView.delegate = self;

    [self.view addSubview:self.scrollView];

    

    //当然这里也有放大和缩小的属性

//    self.scrollView.minimumZoomScale = 1.0;

    //当最大缩放比例大于最小缩放比例时,就会打开缩放

//    self.scrollView.maximumZoomScale = 2.0;

    //当缩放时,需要在代理方法里指定那个空间缩放


下面是一些常用的代理方法:

//滚动时就会执行该方法

-(void)scrollViewDidScroll:(UIScrollView *)scrollView {

    

}


//即将开始滚动

-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView {

    NSLog(@"开始滚动");

}


//滚动已经完成

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {

    NSLog(@"滚动已经完成");

}


//即将滚动完成

-(void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView {

    NSLog(@"滚动即将完成");

}


这里附上UI控件演示的源码地址:https://github.com/LOLR2017/UIKitDemo。源码持续更新中...

写在结尾:本文初衷是提供给一些新手或者需要某些资料查询者,代码或者思想有不足之处请大家谅解,希望大家多多原谅。最后希望大家可以共同进步,快乐工作。

上一篇文章《UITextField的基本使用》

下一篇文章《UITableView的基本使用》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值