IOS微博项目之UIScrollView&UIPageControl

使用UIscrollView&UIPageControl实现版本新特性展示

/**
 *  设置UIScrollView
 */
- (void)setupScrollView {
    // 设置UIScrollView
    UIScrollView *scrollView = [[UIScrollView alloc] init];
    [self.view addSubview:scrollView];
    self.scrollView = scrollView;
    scrollView.frame = self.view.bounds;
    // 添加UIScrollView内容
    CGFloat w = self.view.frame.size.width;
    CGFloat h = self.view.frame.size.height;
    CGFloat x = 0;
    CGFloat y = 0;
    int imageCount = 3;
    for (int i = 1; i <= imageCount; i++) {
        NSString *named = [NSString stringWithFormat:@"new_feature_%d", i];
        UIImageView *imageView = [[UIImageView alloc] initWithImage:[UIImage imageWithNamed:named]];
        imageView.frame = CGRectMake(x, y, w, h);
        [scrollView addSubview:imageView];
        x = i * w;
        if (i == imageCount) {
            [self setupSubviewsWithImageView:imageView];
        }
    }
    // 设置UIScrollView属性
    scrollView.contentSize = CGSizeMake(scrollView.subviews.count * w, 0);
    // 隐藏横向滚动条
    scrollView.showsHorizontalScrollIndicator = NO;
    // 分页设置
    scrollView.pagingEnabled = YES;
    // 禁止滚动超出边缘
    scrollView.bounces = NO;
    // 设置代理
    scrollView.delegate = self;
}

/**
 *  设置UIPageControl
 */
- (void)setupPageControl {
    UIPageControl *pageControl = [[UIPageControl alloc] init];
    [self.view addSubview:pageControl];
    self.pageControl = pageControl;
    CGSize size = self.view.frame.size;
    pageControl.frame = CGRectMake(0, size.height * 0.9, size.width, 44);
    // 设置UIPageControl属性
    pageControl.numberOfPages = self.scrollView.subviews.count;
    pageControl.currentPage = 0;
    // 设置分页图片
    pageControl.pageIndicatorTintColor = UIColorFromRGB(189, 189, 189);
    pageControl.currentPageIndicatorTintColor = UIColorFromRGB(253, 98, 42);
    // 禁止用户交互
    pageControl.userInteractionEnabled = NO;
}

#pragma mark - UIScrollView代理方法
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    self.pageControl.currentPage = (scrollView.contentOffset.x / self.view.bounds.size.width + 0.5);
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值