uiscrollview轮播自定义类.

原创 2015年07月08日 16:37:33

只需要几行代码解决所有定时,pagecontrol和uiscrollview的轮播滚动,手势等问题,SEL可自行添加图片动作.哈哈...

我的新浪博客地址:http://blog.sina.com.cn/s/blog_8da31aa30102voro.html


NSArray *array = @[@"http://ww3.sinaimg.cn/square/5ba8d1cbgw1etva081lhej21e00xctlp.jpg",

                       @"http://ww1.sinaimg.cn/square/5ba8d1cbgw1etva0oi7bfj20x20zk44u.jpg",

                       @"http://ww3.sinaimg.cn/thumbnail/46d7df02jw1etva9axtuvj20v80ngdne.jpg"];

//    NSArray *array = @[@"p1.png",@"p2.png",@"p3.png"];

    

    AutoScrollView *autos = [[AutoScrollView alloc] initWithFrame: CGRectMake(0, 0, SCREEN_WIDTH, scrollViewH) imageUrls:array];

    

    autos.timeInterval = 3.0f;

    

    [AutoScrollView autoScrollViewWithFrame:CGRectMake(0, 0, SCREEN_WIDTH, scrollViewH) imagePaths:array];

    

    [self.view addSubview:autos];




typedef NS_ENUM(NSInteger, AutoScorllViewPageControlAlignment) {

    AutoScrollViewPageControlAlignmentLeft = 0,

    AutoScrollViewPageControlAlignmentCenter = 1,

    AutoScrollViewPageControlAlignmentRight = 2

};


@interface AutoScrollView : UIView<UIScrollViewDelegate>


@property (nonatomic, copy) NSArray *imagePaths;

@property (nonatomic, copy) NSArray *imageNames;

@property (nonatomic, copy) NSArray *imageUrls;

@property (nonatomic, copy) NSArray *imageModels;

@property (nonatomic, assign) NSTimeInterval timeInterval;

@property (nonatomic, assign) BOOL showPageControl; //default is YES:

@property (nonatomic, assign) AutoScorllViewPageControlAlignment pageControlAlignment;


- (instancetype)initWithFrame:(CGRect)frame imageNames:(NSArray *)imageNames;

- (instancetype)initWithFrame:(CGRect)frame imagePaths:(NSArray *)imagePaths;

- (instancetype)initWithFrame:(CGRect)frame imageUrls:(NSArray *)imageUrls;


+ (instancetype)autoScrollViewWithFrame:(CGRect)frame imageNames:(NSArray *)imageNames;

+ (instancetype)autoScrollViewWithFrame:(CGRect)frame imagePaths:(NSArray *)imagePaths;


- (void)setTarget:(id)target action:(SEL)action;

- (NSInteger)pageNo;

#import "AutoScrollView.h"

#import "UIImageView+WebCache.h"


#define kPageControlHeight 10

#define kPageControlPadding 20


@interface UIScrollView (ScrollViewPageNo)


- (NSInteger)pageNo;


@end


@implementation UIScrollView (ScrollViewPageNo)


- (NSInteger)pageNo

{

    int pageNo = self.contentOffset.x / self.frame.size.width + 0.5;

    return pageNo;

}


@end


@interface AutoScrollView ()

{

    UIScrollView *_scrollView;

    NSTimer *_timer;

    BOOL _autoScrollFlag;


    id _target;

    SEL _action;

}


@property (nonatomic, strong) UIPageControl *pageControl;

@property (nonatomic, strong) UILabel *titleLabel;

@property (nonatomic, assign) NSInteger currentPage;


@end


@implementation AutoScrollView


//- (oneway void)release

//{

//    if (2 == self.retainCount) {

//        [_timer invalidate];

//    }

//

//    [super release];

//}


//- (void)dealloc

//{

//    [_scrollView release];

//    [_pageControl release];

//

//    [super dealloc];

//}


- (id)initWithFrame:(CGRect)frame

{

    self = [self initWithFrame:frame imageNames:nil];

    return self;

}


/**

 * 创建scrollview

 *

 * @return创建scrollview

 */



#pragma mark -创建scrollview


- (void)createScrollView

{

    _autoScrollFlag = YES;


    _scrollView = [[UIScrollView alloc] initWithFrame:self.bounds];

    [_scrollView setScrollsToTop:NO];

    [self addSubview:_scrollView];


    // 代理指针不能用retain只能用assign的原因是防止父对象做子对象代理的时候产生循环引用,当作没看见

    _scrollView.delegate = self;

    _scrollView.showsHorizontalScrollIndicator = NO;

    _scrollView.showsVerticalScrollIndicator = NO;

    // 设置是否分页显示

    [_scrollView setPagingEnabled:YES];

    [_scrollView setBounces:NO];

    [_scrollView setContentSize:CGSizeMake(self.bounds.size.width, 0)];


    //    UIView * view = [[UIView alloc] initWithFrame:CGRectMake(0, self.bounds.size.height * 0.9, self.bounds.size.width, self.bounds.size.height * 0.1)];

    //    view.backgroundColor = [UIColor blackColor];

    //    view.alpha = 0.6;

    //    [self addSubview:view];

    //    [view release];

    //

    //    self.titleLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, self.bounds.size.height * 0.9, self.bounds.size.width, self.bounds.size.height * 0.1)];

    //    self.titleLabel.backgroundColor = [UIColor clearColor];

    //    self.titleLabel.text = @"活动介绍轮播";

    //    self.titleLabel.textColor = [UIColor whiteColor];

    //    [self addSubview:self.titleLabel];

    //    [self.titleLabel release];


    UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tap)];

    [tap setNumberOfTouchesRequired:1];

    [_scrollView addGestureRecognizer:tap];

//    [tap release];

}


//  designate initializer

- (instancetype)initWithFrame:(CGRect)frame imageNames:(NSArray *)imageNames

{

    self = [self initWithFrame:frame imagePaths:nil];

    self.imageNames = imageNames;

    return self;

}


- (instancetype)initWithFrame:(CGRect)frame imagePaths:(NSArray *)imagePaths

{

    self = [super initWithFrame:frame];

    if (self) {

        [self createScrollView];

        self.showPageControl = YES;

        self.pageControlAlignment = AutoScrollViewPageControlAlignmentCenter;

        self.imagePaths = imagePaths;

    }

    return self;

}


- (instancetype)initWithFrame:(CGRect)frame imageUrls:(NSArray *)imageUrls

{

    self = [super initWithFrame:frame];

    if (self) {

        [self createScrollView];

        self.showPageControl = YES;

        self.pageControlAlignment = AutoScrollViewPageControlAlignmentCenter;

        self.imageUrls = imageUrls;

    }

    return self;

}



+ (instancetype)autoScrollViewWithFrame:(CGRect)frame imageNames:(NSArray *)imageNames

{

    AutoScrollView *autoScorllView = [[AutoScrollView alloc] initWithFrame:frame imageNames:imageNames];

    return autoScorllView;

}


+ (instancetype)autoScrollViewWithFrame:(CGRect)frame imagePaths:(NSArray *)imagePaths

{

    AutoScrollView *autoScorllView = [[AutoScrollView alloc] initWithFrame:frame imagePaths:imagePaths];

    return autoScorllView ;

}



- (NSArray *)imageNames2imagePaths:(NSArray *)imageNames

{

    NSMutableArray *imagePaths = [NSMutableArray arrayWithCapacity:imageNames.count];

    for (NSString *imageName in imageNames) {

        NSArray *nameArray = [imageName componentsSeparatedByString:@"."];

        NSString *imagePath = [[NSBundle mainBundle] pathForResource:[nameArray firstObject] ofType:[nameArray lastObject]];

        [imagePaths addObject:imagePath];

    }

    return imagePaths;

}


-(void)setImageUrls:(NSArray *)imageUrls{


    if (_imageUrls == imageUrls) {

        return;

    }

//    [_imageUrls release];

    _imageUrls = [imageUrls copy];

    self.imageNames = nil;

    //    self.imageNames = imageUrls;

    [self setScrollViewSubimages:_imageUrls isUrl:YES];

}



-(void)setImageModels:(NSArray *)imageModels{

    if (_imageModels == imageModels) {

        return;

    }

//    [_imageModels release];

    _imageModels = [imageModels copy];

    NSMutableArray *images = [NSMutableArray array];

    for (NSDictionary *dic in imageModels) {

        [images addObject:[dic objectForKey:@"ImgUrl"]];

    }

    self.imageUrls = images;

}



- (void)setImageNames:(NSArray *)imageNames

{

    if (_imageNames == imageNames) {

        return;

    }


//    [_imageNames release];

    _imageNames = [imageNames copy];


    self.imagePaths = [self imageNames2imagePaths:self.imageNames];

}


- (void)setImagePaths:(NSArray *)imagePaths

{

    if (_imagePaths == imagePaths) {

        return;

    }


//    [_imagePaths release];

    _imagePaths = [imagePaths copy];

    [self setScrollViewSubimages:_imagePaths isUrl:NO];

}


- (void)setScrollViewSubimages:(NSArray *)array isUrl:(BOOL)isUrl{

    for (UIView *aView in _scrollView.subviews) {

        [aView removeFromSuperview];

    }

    CGSize contentSize = _scrollView.bounds.size;

    contentSize.width *= [array count] + 2;

    // 设置可滚动区域

    [_scrollView setContentSize:contentSize];


    CGRect rect = _scrollView.bounds;


    // 在最前面添加最后一页

    UIImageView *aView = [[UIImageView alloc] initWithFrame:rect];

    aView.userInteractionEnabled = YES;

    NSString *imagePath = [array lastObject];

    if (isUrl) {

        [aView setImageWithURL:[NSURL URLWithString:imagePath] placeholderImage:[UIImage imageNamed:nil]];//placeholderImage:default_big_photo

    }else {

        UIImage *image = [UIImage imageWithContentsOfFile:imagePath];

        [aView setImage:image];

    }


    [_scrollView addSubview:aView];


    for (int i = 0; i < array.count; i++) {

        //rect.origin.x += rect.size.width;

        rect.origin.x = i * rect.size.width;  // 修改过

        UIImageView *aView = [[UIImageView alloc] initWithFrame:rect];

        //        UIImage *image = [UIImage imageNamed:[_imageNames objectAtIndex:i]];  // 初始化成功后会被系统缓存不能释放

        aView.userInteractionEnabled = YES;

        NSString *imagePath = array[i];

        if (isUrl) {

            [aView setImageWithURL:[NSURL URLWithString:imagePath] placeholderImage:[UIImage imageNamed:@"default_big_photo"]];

            //            [aView setBackgroundColor:[UIColor redColor]];

        }else {

            UIImage *image = [UIImage imageWithContentsOfFile:imagePath];

            [aView setImage:image];

        }


        [_scrollView addSubview:aView];

    }


    // 在最后面添加最后一页

    rect.origin.x += rect.size.width;

    UIImageView *bView = [[UIImageView alloc] initWithFrame:rect];

    bView.userInteractionEnabled = YES;

    imagePath = [array firstObject];


    if (isUrl) {

        [bView setImageWithURL:[NSURL URLWithString:imagePath] placeholderImage:[UIImage imageNamed:nil]];//default_big_photo

    }else {

        UIImage *image = [UIImage imageWithContentsOfFile:imagePath];

        [bView setImage:image];

    }


    [_scrollView addSubview:bView];


    [_scrollView setContentOffset:CGPointMake(_scrollView.bounds.size.width, 0)];


    [_pageControl setNumberOfPages:array.count];

    self.pageControlAlignment = self.pageControlAlignment;

}




- (void)setTimeInterval:(NSTimeInterval)timeInterval

{

    _timeInterval = timeInterval;

    [_timer invalidate]; _timer = nil;

    if (_timeInterval > 0.0) {

        _timer = [NSTimer scheduledTimerWithTimeInterval:_timeInterval target:self selector:@selector(timeUp:) userInfo:nil repeats:YES];

    }

}


- (void)setShowPageControl:(BOOL)showPageControl

{

    if (showPageControl == _showPageControl) {

        return;

    }


    _showPageControl = showPageControl;

    if (_showPageControl) {

        self.pageControl = [[UIPageControl alloc] initWithFrame:CGRectMake(0, self.frame.size.height - 2 * kPageControlHeight, self.frame.size.width, kPageControlHeight)];

        [_pageControl setPageIndicatorTintColor:[UIColor grayColor]];

        [_pageControl setCurrentPageIndicatorTintColor:[UIColor whiteColor]];

        [self addSubview:self.pageControl];


    } else {

        [self.pageControl removeFromSuperview];

        self.pageControl = nil;

    }

}


- (void)timeUp:(id)sender

{

    if (_autoScrollFlag) {

        CGPoint contentOffset = CGPointMake((_scrollView.pageNo + 1) * _scrollView.bounds.size.width, 0);

        [_scrollView setContentOffset:contentOffset animated:YES];

    }

}


- (void)setTarget:(id)target action:(SEL)action

{

    _target = target;

    _action = action;

}


- (void)tap

{

    [_target performSelector:_action withObject:self];

}


- (void)setPageControlAlignment:(AutoScorllViewPageControlAlignment)pageControlAlignment

{

    if (_pageControlAlignment == pageControlAlignment) {

        return;

    }


    if (! _showPageControl) {

        return;

    }


    self.showPageControl = YES;

    CGRect rect = self.pageControl.frame;

    CGSize size = [self.pageControl sizeForNumberOfPages:_imagePaths.count];

    rect.size.width = size.width + kPageControlPadding * 2;

    _pageControlAlignment = pageControlAlignment;

    switch (_pageControlAlignment) {

        case AutoScrollViewPageControlAlignmentLeft:

            rect.origin.x = 0;

            break;

        case AutoScrollViewPageControlAlignmentCenter:

            rect.origin.x = (self.bounds.size.width - rect.size.width) / 2;

            break;

        case AutoScrollViewPageControlAlignmentRight:

            rect.origin.x = self.bounds.size.width - rect.size.width;

            break;

    }

    [_pageControl setFrame:rect];

}


- (NSInteger)pageNo

{

    return self.pageControl.currentPage;

}


#pragma mark -

#pragma mark scrollView delegate method


- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

{

    _autoScrollFlag = NO;

}


- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset

{

    _autoScrollFlag = YES;

}


- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

    //    NSLog(@"%@", NSStringFromCGPoint(scrollView.contentOffset));

    int pageCount = 0;

    if (self.imageUrls) {

        pageCount = self.imageUrls.count;

    } else if (self.imageNames) {

        pageCount = self.imageNames.count;

    }


    int pageNo = scrollView.pageNo;

    if (pageNo == _currentPage) {

        return;

    }

    _currentPage = pageNo;

    pageNo--;

    CGPoint contentOffset = scrollView.contentOffset;

    if (-1 == pageNo) {

        contentOffset.x += scrollView.frame.size.width * pageCount;

        [scrollView setContentOffset:contentOffset];

        pageNo = pageCount - 1;

    }else if (pageCount == pageNo){

        contentOffset.x -= scrollView.frame.size.width * pageCount;

        [scrollView setContentOffset:contentOffset];

        pageNo = 0;

    }

    

    if (_pageControl) {

        [_pageControl setCurrentPage:pageNo];

    }

}



版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

自定义轮播

  • 2015-05-28 15:55
  • 187KB
  • 下载

自定义ViewPager实现轮播效果

前言这种轮播效果多应用于展示电影海报,但是效果并不好,有些没有手势动画,更加没有fling效果。我将ViewPager的源码拷贝出来,做了修改,实现了这两个效果。 一屏显示三个page,让中间一个pa...

Android自定义轮播广告

  • 2015-10-10 16:31
  • 2.99MB
  • 下载

关于自定义无限轮播图_Android

首先看一下效果图下载地址Demo 废话不多说上代码了首先看我们自定义的可以设置是否可以滑动的viewpagerpackage cn.yuan.banner;import android.cont...

自定义Banner广告轮播图

  • 2016-08-16 18:50
  • 2.78MB
  • 下载

ViewPager无限轮播+自定义小圆点+ListView展示

ViewPager无限轮播+自定义小圆点+ListView
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)