滚动视图的自动循环滚动

本文介绍了一种自定义滚动视图的实现方法,通过继承UIView并利用UIScrollView和UIPageControl来实现图片轮播功能。文章详细展示了如何设置滚动视图内的图片数量、创建滚动视图及页面控制器,并通过代码实现了滚动视图的循环播放。

自定义视图, 继承自UIView
@interface AdScrollView : UIView<UIScrollViewDelegate>
@property (nonatomic, assign) NSInteger numberOfBigImageView;//滚动视图内图片的数量
@property (nonatomic, retain) UIScrollView * scrollView;
@property (nonatomic, retain) UIPageControl * pageControl;
@property (nonatomic, retain) NSMutableArray * bigImageViewArray;//存放滚动视图里的图片,可以通过这个数组找到加在scrollView上的bigImageView
@property (nonatomic, assign) NSInteger count;
@end

在.m文件里使用了一个第三方的类目, self.width相当于self.frame.size.width, 其他的类似
#define kPageControllerWidth 100
#define kPageControllerHeight 30
@implementation AdScrollView

- (id)initWithFrame:(CGRect)frame
{
    self = [super initWithFrame:frame];
    if (self) {
        //创建滚动视图
        self.scrollView = [[[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, self.width, self.height)] autorelease];
        _scrollView.backgroundColor = [UIColor redColor];
        _scrollView.delegate = self;
        [self addSubview:_scrollView];
        //创建pageControl
        self.pageControl = [[[UIPageControl alloc] initWithFrame:CGRectMake((self.width - kPageControllerWidth)/2, self.height*3/4, kPageControllerWidth, kPageControllerHeight)] autorelease];
        [self addSubview:_pageControl];
    }
    return self;
}
//设置滚动视图上有几张图片
- (void)setNumberOfBigImageView:(NSInteger)number
{
    _numberOfBigImageView = number;
    _scrollView.pagingEnabled = YES;
    self.scrollView.contentSize = CGSizeMake(_scrollView.width * number, _scrollView.height);
    self.bigImageViewArray = [NSMutableArray arrayWithCapacity:1];
    //向滚动视图内添加imageView
    for (int i = 0; i < number; i++) {
        UIImageView * bigImageView = [[[UIImageView alloc] initWithFrame:CGRectMake(_scrollView.width * i, 0, _scrollView.width, _scrollView.height)] autorelease];
        [_scrollView addSubview:bigImageView];
        [_bigImageViewArray addObject:bigImageView];
    }
    _pageControl.numberOfPages = number;
    [_pageControl addTarget:self action:@selector(changePhoto:) forControlEvents:UIControlEventValueChanged];
    _count = 0;
   //设置定时器,实现循环滚动
    [NSTimer scheduledTimerWithTimeInterval:2 target:self selector:@selector(loopScroll) userInfo:nil repeats:YES];
    
}

#pragma mark - UIScrollViewDelegate
//视图结束减速时改变page
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
    int x = scrollView.contentOffset.x / _scrollView.width;
    _pageControl.currentPage = x;
    _count = x;
}

//点击pageControl改变滚动视图图片
- (void)changePhoto:(UIPageControl *)pageControl
{
    int page = pageControl.currentPage;
    NSLog(@"%d", pageControl.currentPage);
    [_scrollView setContentOffset:CGPointMake(_scrollView.width * page, 0) animated:YES];
    _count = page;
}

//滚动视图的循环滚动
- (void)loopScroll
{
    //NSLog(@"repeat");
    int a = _count % _numberOfBigImageView;
    _pageControl.currentPage = a;
    _count++;
    // NSLog(@"%d", _pageControl.currentPage);
    //[self change];
    //让scrollView随着page改变
    [_scrollView setContentOffset:CGPointMake(_scrollView.width * _pageControl.currentPage, 0) animated:YES];
}

使用方法
    self.adScrollView = [[[AdScrollView alloc] initWithFrame:CGRectMake(0, 0, 320, 138)] autorelease];
    [_adScrollView setNumberOfBigImageView:3];
    [self addSubview:_adScrollView];
效果如下:

[插入]
 使用属性 _adScrollView.bigImageViewArray可以给imageView上添加Image



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值