XMGPageView.m 文件

#import "XMGPageView.h"

@interface XMGPageView () <UIScrollViewDelegate>
@property (weak, nonatomic) IBOutlet UIScrollView *scrollView;
@property (weak, nonatomic) IBOutlet UIPageControl *pageControl;


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

@end
@implementation XMGPageView

- (void)awakeFromNib
{

    self.scrollView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
    self.pageControl.autoresizingMask = UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleTopMargin;

    // 1.单页的时候是否隐藏pageControl
    self.pageControl.hidesForSinglePage = YES;

    // 2.设置pageControl的图片
    [self.pageControl setValue:[UIImage imageNamed:@"current"] forKeyPath:@"_currentPageImage"];
    [self.pageControl setValue:[UIImage imageNamed:@"other"]  forKeyPath: @"_pageImage"];

    // 3.开启定时器
    [self startTimer];

}

+ (instancetype)pageView
{
    return [[[NSBundle mainBundle] loadNibNamed:NSStringFromClass(self) owner:nil options:nil]  lastObject];
}

- (void)layoutSubviews
{
    [super layoutSubviews];
    // 根据最新的scrollView尺寸计算iamgeView的X
    CGFloat scrollViewW = self.scrollView.frame.size.width;  // 330
    for (int i = 0; i < self.scrollView.subviews.count; i ++) {
        UIImageView *imageView = self.scrollView.subviews[i];
        CGRect frame = imageView.frame;
        frame.origin.x = i * scrollViewW;
        imageView.frame = frame;
    }

    // 设置contentSize
    self.scrollView.contentSize = CGSizeMake(self.scrollView.subviews.count * scrollViewW, 0);

}
- (void)setImageNames:(NSArray *)imageNames
{
    _imageNames = imageNames;
    // 0.移除之前添加的
    // 让subviews这个数组中每一个对象都执行removeFromSuperview
    [self.scrollView.subviews makeObjectsPerformSelector:@selector(removeFromSuperview)];

    // 1.根据图片名数据创建ImageView添加到scrollView
    CGFloat scrollViewW = self.scrollView.frame.size.width;  // 300
    CGFloat scrollViewH = self.scrollView.frame.size.height; // 130
    NSUInteger count = imageNames.count;
    for (int i = 0; i < count; i ++) {
        UIImageView *imageView = [[UIImageView alloc] init];
        imageView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
        imageView.image = [UIImage imageNamed:imageNames[i]];
        imageView.frame = CGRectMake(i * scrollViewW, 0, scrollViewW, scrollViewH);
        [self.scrollView addSubview:imageView];
    }

    // 2.设置contentSize
    self.scrollView.contentSize = CGSizeMake(count * scrollViewW, 0);

    // 3.设置总页数
    self.pageControl.numberOfPages = count;
}

#pragma mark - 定时器相关的代码
- (void)startTimer
{
    // 返回一个自动执行的定时器对象
    self.timer = [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(nextPage:) userInfo:@"123" repeats:YES];

    [[NSRunLoop mainRunLoop] addTimer:self.timer forMode:NSRunLoopCommonModes];
}

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

/**
 *  滚动到下一页
 */
- (void)nextPage:(NSTimer *)timer
{
    // 1.计算下一页的页码
    NSInteger page = self.pageControl.currentPage + 1;

    // 2.超过了最后一页
    if ( page == self.imageNames.count) {
        page = 0;
    }

    // 3.滚动到下一页
    [self.scrollView setContentOffset:CGPointMake(page * self.scrollView.frame.size.width, 0) animated:YES];
}

#pragma mark - UIScrollViewDelegate

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    // 1.计算页码
    int page = (int)(scrollView.contentOffset.x / scrollView.frame.size.width + 0.5);

    // 2.设置页码
    self.pageControl.currentPage = page;
}

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

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

@end

ViewController.m文件

#import "ViewController.h"
#import "XMGPageView.h"

@interface ViewController () 

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    XMGPageView *pageView = [XMGPageView pageView];
    pageView.backgroundColor = [UIColor redColor];


    pageView.imageNames = @[@"img_01",@"img_02",@"img_03",@"img_04",@"img_05"];

    pageView.frame = CGRectMake(0, 20, 320, 150);
    [self.view addSubview:pageView];
}


@end

results matching ""

    No results matching ""