您当前的位置: 首页 >  ui

white camel

暂无认证

  • 1浏览

    0关注

    442博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

UI 一一 使用ScrollView和PageController实现引导页分页效果

white camel 发布时间:2017-08-08 21:33:21 ,浏览量:1

实现这样的功能(图片轮播器)

话不多少直接上代码:

#import "ViewController.h"

@interface ViewController () 

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

@property (weak, nonatomic) IBOutlet UIPageControl *pageController;

/** 定时器 */
@property (nonatomic,weak) NSTimer *timer;


@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    //1.添加图片
    CGFloat scrollViewW = self.scrollView.frame.size.width;
    CGFloat scrollViewH = self.scrollView.frame.size.height;
    
    int count = 5;
    for (int i = 0; i < count; ++i) {
        UIImageView *imageView = [[UIImageView alloc] init];
        NSString *name = [NSString stringWithFormat:@"img_0%d",i + 1];
        imageView.image = [UIImage imageNamed:name];
        imageView.frame = CGRectMake(i * scrollViewW, 0, scrollViewW, scrollViewH);
        [self.scrollView addSubview:imageView];
    }
    
    //2. 设置contentSize
    // 这个0表示竖直方向不可以滚动,当contentSize的尺寸   1万个0.0001s

#pragma -mark 定时器相关代码

- (void)startTimer
{
    // 返回一个自动执行的定时器对象
    self.timer = [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(nextPage:) userInfo:@"桂阳" repeats:YES];
    
    // NSDefaultRunLoopMode(默认): 同一时间只能执行一个任务
    // NSRunLoopCommonModes(公用): 可以分配一定的时间执行其他任务
    // 作用:修改timer在runLoop中的模式为NSRunLoopCommonModes
    // 目的:不管主线程在做什么操作,都会分配一定的时间处理定时器
    [[NSRunLoop mainRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];

}

- (void)stopTimer
{
    [self.timer invalidate];
    self.timer = nil;
}


/**
    滚到下一页
 */
- (void)nextPage : (NSTimer *)timer
{
//    NSLog(@"%@",timer.userInfo);
    //1. 计算下一页的页码
    NSInteger page = self.pageController.currentPage + 1;
    
    //2. 超过了最后一页
    if (page == 5) {
        page = 0;
    }
    
    //3. 滚动到下一页
    [self.scrollView setContentOffset:CGPointMake(page * self.scrollView.frame.size.width, 0) animated:YES];
}


#pragma mark - UIScrollViewDelegate

/*
    当下一张图片大于可视区域,设置页码
 */
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    // 内容偏移量的x / 可视区域宽度 + 0.5
    // 四舍五入: int(小数 + 0.5)

        // 1.计算页码
        int page = scrollView.contentOffset.x / scrollView.frame.size.width + 0.5;
        // 2.设置页码
        self.pageController.currentPage = page;
}


/**
    用户即将开始拖拽scrollView时,停止定时器
 */
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    [self stopTimer];
}


/**
    用户已经停止拖拽scrollView时,开启定时器
 */
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    [self startTimer];
}

@end

关注
打赏
1661428283
查看更多评论
立即登录/注册

微信扫码登录

0.0387s