UIScrollView之轮转图片
在iOS开发中,经常会在APP首页看到多张图片进行轮换。刚开始做的时候,感觉很麻烦,不是很好做,查阅资料后,我总结了一下,自己封装了一个简单的轮转图片库;
UIScrollView无限滑动 ,只需要三个View,左视图,中视图,右视图。无论向左滑动,还是向右滑动,都显示中间的一个View;
( _scrollView.contentOffset =CGPointMake(scrollView.bounds.size.width,0); )
// CircleScrollView.h
#import <UIKit/UIKit.h> #import "UIImageView+WebCache.h" // 当使用网络图片的时候,才会用到SDWebImage @protocol CircleScrollViewDelegate <NSObject> @optional /** * 滚动图片总数 * @return 要滚动的图片的个数 */ - (NSInteger) numberOfImagesInScrollView; /** * 返回索引位置的图片,仅当滚动的为图片时使用 * @param index 索引位置 * @return 索引位置的图片 */ -(UIImage *)imageForIndex:(NSInteger) index; /** * 返回索引位置的图片URL,仅当滚动的为图片时使用 * @param index 索引位置 * @return 索引位置对应的图片URL */ -(NSURL *)imageURLForIndex:(NSInteger)index; /** * 选中相应的视图的操作 * @param index 选中的相应的视图 */ - (void)didSelectAtIndex:(NSInteger) index; @end @interface CircleScrollView :UIView <UIScrollViewDelegate> @property (nonatomic,strong,readonly)UIScrollView *scrollView; @property (nonatomic,strong,readonly)UIPageControl *pageControl; @property (nonatomic,strong,readonly)UIImageView *leftView; @property (nonatomic,strong,readonly)UIImageView *middleView; @property (nonatomic,strong,readonly)UIImageView *rightView; @property (nonatomic,assign)int currentPageNo; @property (nonatomic,assign,getter=isAutoLoop)BOOL autoLoop;//是否自动轮动 //@property (nonatomic,copy) NSArray *scrollImgs; @property (nonatomic,weak)id<CircleScrollViewDelegate> delegate;//代理 @end
// CircleScrollView.m
#import "CircleScrollView.h" @interfaceCircleScrollView () { NSTimer *_timer; } @end @implementation CircleScrollView /* 自定义的ScrollView。功能如下: 循环滑动 使用分两步: (1)创建数据源(数据源中存放要滚动的图片) (2)_circleScrollView = [[CircleScrollView alloc] initWithFrame:CGRectMake(20, 20, 128, 128)]; (3)设置代理 _circleScrollView.delegate = self; */ -(instancetype)initWithFrame:(CGRect)frame{ self = [superinitWithFrame:frame]; if (self) { _scrollView = [[UIScrollViewalloc]initWithFrame:self.bounds]; _scrollView.delegate =self; _scrollView.showsHorizontalScrollIndicator =NO; _pageControl = [[UIPageControlalloc]initWithFrame:CGRectMake(0,self.frame.size.height-10,self.frame.size.width,10)]; _pageControl.backgroundColor = [UIColorlightGrayColor]; _pageControl.pageIndicatorTintColor = [UIColorredColor]; _pageControl.currentPageIndicatorTintColor = [UIColorblueColor]; _pageControl.alpha =0.5; _leftView = [[UIImageViewalloc]initWithFrame:CGRectMake(self.frame.size.width*0,0,self.frame.size.width,self.frame.size.height)]; _middleView = [[UIImageViewalloc]initWithFrame:CGRectMake(self.frame.size.width*1,0,self.frame.size.width,self.frame.size.height)]; _rightView = [[UIImageViewalloc]initWithFrame:CGRectMake(self.frame.size.width*2,0,self.frame.size.width,self.frame.size.height)]; [_scrollViewaddSubview:_leftView]; [_scrollViewaddSubview:_middleView]; [_scrollViewaddSubview:_rightView]; _scrollView.pagingEnabled =YES; _scrollView.contentSize =CGSizeMake(self.frame.size.width*3,self.frame.size.height); _scrollView.contentOffset =CGPointMake(self.frame.size.width,0); [selfaddSubview:_scrollView]; [selfaddSubview:_pageControl]; } returnself; } -(void)setDelegate:(id<CircleScrollViewDelegate>)delegate { // NSLog(@"设置代理"); _delegate = delegate; if ([_delegaterespondsToSelector:@selector(numberOfImagesInScrollView)]) { NSInteger number = [_delegatenumberOfImagesInScrollView]; _pageControl.numberOfPages = number; _pageControl.currentPage =0; _currentPageNo =0; // _leftView.image = [_delegate imageForIndex:number-1]; // _middleView.image = [_delegate imageForIndex:_currentPageNo]; int nextNo =_currentPageNo; if (number >2) { nextNo = _currentPageNo+1; } // _rightView.image = [_delegate imageForIndex:nextNo]; if ([self.delegaterespondsToSelector:@selector(imageURLForIndex:)]) { [_leftViewsd_setImageWithURL:[_delegateimageURLForIndex:number-1]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { // NSLog(@""); }]; [_middleViewsd_setImageWithURL:[_delegateimageURLForIndex:_currentPageNo]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { }]; [_rightViewsd_setImageWithURL:[_delegateimageURLForIndex:nextNo]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { }]; } elseif ([self.delegaterespondsToSelector:@selector(imageForIndex:)]){ _leftView.image = [_delegateimageForIndex:number-1]; _middleView.image = [_delegateimageForIndex:_currentPageNo]; _rightView.image = [_delegateimageForIndex:nextNo]; } } if ([_delegaterespondsToSelector:@selector(didSelectAtIndex:)]) { _middleView.userInteractionEnabled =YES; UITapGestureRecognizer *tap = [[UITapGestureRecognizeralloc]initWithTarget:selfaction:@selector(selectAction:)]; [_middleViewaddGestureRecognizer:tap]; } } -(void)selectAction:(UITapGestureRecognizer *)gesture { if ([self.delegaterespondsToSelector:@selector(didSelectAtIndex:)]) { [self.delegatedidSelectAtIndex:_currentPageNo]; } } -(void)autoLoop{ _currentPageNo++; //自动循环 [_scrollViewscrollRectToVisible:CGRectMake(_scrollView.bounds.size.width*2,0,_scrollView.bounds.size.width,_scrollView.bounds.size.height)animated:YES]; } - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ // NSLog(@"scrollViewDidEndDecelerating"); int pageNo = scrollView.contentOffset.x/scrollView.bounds.size.width; long imgCount = [_delegatenumberOfImagesInScrollView]; // NSLog(@"pageNo : %i",pageNo); if (pageNo ==0) { _currentPageNo--; } elseif (pageNo ==2){ _currentPageNo++; } if (_currentPageNo <0) { _currentPageNo = (int)(imgCount -1); } elseif (_currentPageNo > imgCount -1) { _currentPageNo =0; } int previousPage =_currentPageNo -1; if (previousPage <0) { previousPage = (int)(imgCount -1); } int nextPage =_currentPageNo +1; if (nextPage > imgCount-1) { nextPage = 0; } _pageControl.currentPage =_currentPageNo; if ([self.delegaterespondsToSelector:@selector(imageURLForIndex:)]) { [_leftViewsd_setImageWithURL:[_delegateimageURLForIndex:previousPage]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { }]; [_middleViewsd_setImageWithURL:[_delegateimageURLForIndex:_currentPageNo]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { }]; [_rightViewsd_setImageWithURL:[_delegateimageURLForIndex:nextPage]placeholderImage:[UIImagenew]completed:^(UIImage *image,NSError *error,SDImageCacheType cacheType,NSURL *imageURL) { }]; } elseif ([self.delegaterespondsToSelector:@selector(imageForIndex:)]){ _leftView.image = [_delegateimageForIndex:previousPage]; _middleView.image = [_delegateimageForIndex:_currentPageNo]; _rightView.image = [_delegateimageForIndex:nextPage]; } _scrollView.contentOffset =CGPointMake(scrollView.bounds.size.width,0); } @end
关于自动循环,我们可以自定义,其实就是加一个NSTimer定时器,每过一定的时间让scrollView滑向下一个View,即:
[_scrollViewscrollRectToVisible:CGRectMake(_scrollView.bounds.size.width*2,0,_scrollView.bounds.size.width,_scrollView.bounds.size.height)animated:YES];
scrollView会自动的滑向第三个View。然后图片就可以自动定时滑动了。 使用上述自定义的轮转图片时,一定要遵守UIScrollViewDelegate协议并实现代理方法,否则不可用。
UIScrollView之轮转图片的更多相关文章
- 常错-UIScrollView中得图片不能被拖动
经常在开发中,发现自己UIScrollView里面的图片不能被拖动 在这里做个备忘,第一种可能是contentSize没有设置,第二种可能是contentSize设置的太小了. 测试后发现,与user ...
- iOS下uiview和uiscrollview设置背景图片的源码
1.uiscrollview 设置背景图片 // Setup the Scroll ViewUIScrollView*tempScrollView=(UIScrollView*)self.view;t ...
- UIScrollView浏览一组图片,且图片与图片之间有间隔
---恢复内容开始--- UIScrollView是可以浏览一组view的,只要将其属性 pagingEnabled设置为true就可以了.具体过程是这样的, 1:将一组图片按照从左到右的顺序添加到U ...
- 【iOS开发-54】案例学习:通过UIScrollView的缩放图片功能练习代理模式的详细实现
案例:(在模拟器中按住option键,点击鼠标就会出现缩放的手势) (1)在ViewController.m中: --缩放东西是UIScrollView除了滚动之外的还有一个功能,所以须要缩放的东西应 ...
- UIScrollView做循环图片
#import "ViewController.h" #define IMAGE_COUNT 6 @interface ViewController () { UIImageVie ...
- iOS:UIScrollView控件和UIPageControl控件的详解
UIScrollView滚动视图控件和UIPageControl分页视图控件: UIScrollView用于显示多于一个屏幕的内容,超出屏幕范围的内容可以通过滑动进行查看,当然UIPagecon ...
- iOS开发——UI基础-UIScrollView
一.UIScrollView使用的步骤 1.创建UIScrollView 2.将需要展示的内容添加到UIScrollView中 3.设置UIScrollView的滚动范围 (contentSize) ...
- iOS开发-UITableView顶部图片下拉放大
关于顶部图片下拉放大,在用户展示的个人中心显示用户个人头像信息,设置UITableView的headerView实现,UITableView继承自UIScrollView,同样的设置UIScrollV ...
- ScrollView图片分页显示-简单
用到的控件: 1>UIScrollView:宽度和图片的宽度一样,因为分页的代码就一句 // 设置分页,这个分页的原理实际上是按照ScrollView的宽进行分页的,这里的图片的宽由于和Scro ...
随机推荐
- 解析导航栏的url--selnium,beautifulsoup实战
前段时间做ui自动化测试的时候,导航栏菜单始终有点问题,最后只好直接获取到url,然后直接使用driver.get(url)进入页面: 包括做压测的时候,比如我要找出所有报表菜单的url,这样不可能手 ...
- 用php怎么写一个用户注册登录的页面呢?
想写就会尽快去写.如果用php写了就一定要用nodejs写出来啊,不写是小狗啊! 补充一下,想要实现的功能: 1.用户名重复检测 2.检测信息填写是否完整 3.邮箱是否已经被注册 4.实现ajax无刷 ...
- OS初识
参考: 操作系统的故事(1-4):
- Widget的点击事件
本文实现Widget中的按钮点击事件,点击一次下面的按钮,上面的数字减少1. 首先是Manifest文件: <?xml version="1.0" encoding=&quo ...
- oracle 数据类型详解---日期型(转载)
oracle 数据类型详解---日期型 oracle数据类型看起来非常简单,但用起来会发现有许多知识点,本文是我对ORACLE日期数据类型的一些整理,都是开发入门资料,与大家分享: 注:由于INTER ...
- JavaScript深究系列 [一]
1. JavaScript中 = = = 首先,== equality 等同,=== identity 恒等. ==, 两边值类型不同的时候,要先进行类型转换,再比较. ===,不做类型转换,类型不同 ...
- java 用 jxl poi 进行excel 解析 *** 最爱那水货
/** * 解析excel文件 ,并把数据放入数组中 格式 xlsx xls * @param path 从ftp上下载到本地的文件的路径 * @return 数据数组集合 */ public Lis ...
- mysql易混淆知识点
1,join 和 union join连接属于表之间的水平操作,而union 是表之间的垂直操作.简单讲就是水平操作主要是为了获得列数据,垂直操作是为了获得行数据 cross join ...
- get传递中文产生乱码的解决方式汇总
1 最基本的乱码问题. 这个乱码问题是最简单的乱码问题.一般新会出现.就是页面编码不一致导致的乱码. <%@ page language="java" pageEncodin ...
- 对jQuery选择器的总结
jQuery基础选择器 $("div*")获取div下面的所有元素 $(".red,.green").html("怎么") // 需要注意的 ...