现在基本每一个商业APP都会有循环滚动视图,放一些轮播广告之类的,都是放在UIScrollView之上。假如我要实现N张图片的轮播,我借鉴了几个博文,得到两种方法实现:

【第一种】:如下图(图片来源于kenshin cui‘s的博客),假如要实现3张图片轮播,我们就设置UIScrollView上的imageView为3+2个,图片顺序为31231。

初始加载UIScrollView时候,滚动到第二个imageView上。

当滚动到最后一个imageview时候,设置UIScrollView的ContentOffset到第二个imageView。

当往前滚动到第一个imageview时候,设置UIScrollView的ContentOffset到倒数第二个imageview。

具体代码如下:

 #import "ViewController.h"
//定义宏,获取屏幕宽高
#define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width
#define SCREEN_HEIGHT [UIScreen mainScreen].bounds.size.height @interface ViewController ()<UIScrollViewDelegate>
/** 滚动视图*/
@property (nonatomic,strong)UIScrollView *scrollView;
/** 图片数组*/
@property (nonatomic,strong)NSMutableArray *imageArray;
@end @implementation ViewController
//懒加载滚动视图
-(UIScrollView *)scrollView{
if (!_scrollView) {
_scrollView = [[UIScrollView alloc]init];
}
return _scrollView;
}
//懒加载图片数组
-(NSMutableArray *)imageArray{
if (!_imageArray) {
_imageArray = [NSMutableArray array];
}
return _imageArray;
} - (void)viewDidLoad {
[super viewDidLoad];
//先加载图片
[self loadImageArray];
//再设置滚动视图
[self setupScrollview];
}
//加载图片,假设有3张图片 welcome1 welcome2 welcome3
-(void)loadImageArray{
for (NSInteger i = ; i<; i++) {
UIImage *image = [UIImage imageNamed:[NSString stringWithFormat:@"welcome%ld",i+]];
[self.imageArray addObject:image];
}
}
//设置scrollview
-(void)setupScrollview{
//设置可见区域
self.scrollView.frame = self.view.bounds;
//设置容量
self.scrollView.contentSize = CGSizeMake(SCREEN_WIDTH*(self.imageArray.count + ), SCREEN_HEIGHT);
//翻页模式
self.scrollView.pagingEnabled = YES;
//代理
self.scrollView.delegate = self;
//边缘不能弹跳
self.scrollView.bounces = NO;
//隐藏水平滚动条
self.scrollView.showsHorizontalScrollIndicator = NO;
[self.view addSubview:self.scrollView];
//循环添加imageView
for (NSInteger i = ; i < self.imageArray.count + ; i++) {
UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(i *SCREEN_WIDTH, , SCREEN_WIDTH, SCREEN_HEIGHT)];
if (i == ) {//0->lastObject
imageView.image = self.imageArray.lastObject;
}else if (i == self.imageArray.count + ){//4->firstObject
imageView.image = self.imageArray.firstObject;
}else{//1->0 2->1 3->2
imageView.image = self.imageArray[i-];
}
[self.scrollView addSubview:imageView];
}
//设置初始滚动的位置为第二个imageView
self.scrollView.contentOffset = CGPointMake(SCREEN_WIDTH, );
}
//当停止滚动时候,重新设置 scrollview的ContentOffset
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
CGPoint point = scrollView.contentOffset;
if (point.x/SCREEN_WIDTH > self.imageArray.count) {//当滚动到最后的时候
[self.scrollView setContentOffset:CGPointMake(SCREEN_WIDTH, ) animated:NO];
}else if (point.x/SCREEN_WIDTH < ){//当滚动到最前的时候
[self.scrollView setContentOffset:CGPointMake(SCREEN_WIDTH*self.imageArray.count, ) animated:NO];
}
}

可以新建项目,直接复制该代码,在loadImageArray方法里面修改成加载自己的图片,运行即可。

【第二种】:假如有100张图片或者更多,就得加载100+2个imageview,显然对性能要求就得更高,因此衍生出了第二种。

就是无论你有多少张图片,imageview始终只有3个。

无论你怎么滚动,当滚动完毕的时候,UIScrollView的ContentOffset都是中间的一个imageview。

只是我们在UIScrollView的代理方法里面不断改变每一个imageview.image的图片而已。

第二种源码我会在后续博文补充。

其实,这个循环滚动学的不是会敲代码,而是一种思路。

最后推荐一个github很好用的类似第三方类库SDCycleScrollView,星星两千多,很不错。

UIScrollView循环滚动1的更多相关文章

  1. UIScrollView 循环滚动,代码超简单

    如今非常多应用里面多多少少都用到了循环滚动,要么是图片.要么是view,或者是其它,我总结一下,写了个demo分享给大家. 先看代码之后在讲原理: 1.创建一个空的项目(这个我就不多说了). 2.加入 ...

  2. iOS之UIScrollView循环滚动

    #import "ViewController.h" #define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width #d ...

  3. 使用UIScrollView 结合 UIImageView 实现图片循环滚动

    场景: 在开发工作中,有时我们需要实现一组图片循环滚动的情况.当我们使用 UIScrollView 结合 UIImageView 来实现时,一般 UIImageView 会尽量考虑重用,下面例子是以( ...

  4. UIScrollView实现自动循环滚动广告

    实现效果如下: 功能说明: 程序运行,图片自动循环播放,采用定时器实现; 当用户用手势触摸滑动时,定时器的自动播放取消,停止触摸时,自动无限播放; 代码如下 : 采用封装视图,外部进行调用即可: 1. ...

  5. IOS实现自动循环滚动广告--ScrollView的优化和封装

    一.问题分析 在许多App中,我们都会见到循环滚动的视图,比如广告,其实想实现这个功能并不难,用ScrollView就可以轻松完成,但是在制作的过程中还存在几个小问题,如果能够正确的处理好这些小问题, ...

  6. NGUI实现的一套不同大小 Item 的循环滚动代码

    测试: 数据 & Item  的 Ctrl : using UnityEngine; public class ScrollViewItemData { public int index; p ...

  7. Jquery制作--循环滚动列表

    自己模仿JQ插件的写法写了一个循环滚动列表插件,支持自定义上.下.左.右四个方向,支持平滑滚动或者间断滚动两种方式,都是通过参数设置.JQ里面有些重复的地方,暂时没想到更好的方法去精简.不过效果还是可 ...

  8. UIScrollView无法滚动的解决办法

    如果UIScrollView无法滚动,可能是以下原因: 没有设置contentSize scrollEnabled = NO 没有接收到触摸事件:userInteractionEnabled = NO ...

  9. UIScrollView无法滚动的解决办法及UIScrollView的代理(delegate)

    1•如果UIScrollView无法滚动,可能是以下原因: Ø没有设置contentSize ØscrollEnabled = NO Ø没有接收到触摸事件:userInteractionEnabled ...

随机推荐

  1. 聊一聊google的Knowledge Graph

    什么是Knowledge Graph? 它是google用于增强它的搜索引擎的功能和提高搜索结果质量的一种技术.在2012年5月16日提出,除了提供基本的与主题相关的链接服务之外,它还能结构化与主题相 ...

  2. 【原创】14. MYSQL++之SSQLS(原理解析)

    从之前所介绍的SSQLS的介绍中我们可以感受到,SSQLS的精髓应该在sql_create_#这个宏,他所创建出来的这个结构体将会是突破的关键,所以我将会从以下顺序入手. 1. sql_create_ ...

  3. SpringMVC Controller 返回值的可选类型

    spring mvc 支持如下的返回方式:ModelAndView, Model, ModelMap, Map,View, String, void. ModelAndView @RequestMap ...

  4. Linux高级编程--04.GDB调试程序(查看数据)

    查看栈信息 当程序被停住了,你需要做的第一件事就是查看程序是在哪里停住的.当你的程序调用了一个函数,函数的地址,函数参数,函数内的局部变量都会被压入"栈"(Stack)中.你可以用 ...

  5. 你或许不了解的C++函数调用(1)

    这篇博客名字起得可能太自大了,搞得自己像C++大牛一样,其实并非如此.C++有很多隐藏在语法之下的特性,使得用户可以在不是特别了解的情况下简单使用,这是非常好的一件事情.但是有时我们可能会突然间发现一 ...

  6. 网络通信分享(二):外网ip和内网ip

    一.内网ip包括两类: 1:tcp/ip协议中,专门保留了三个IP地址区域作为私有地址,其地址范围如下: 10.0.0.0/8:10.0.0.0-10.255.255.255  172.16.0.0/ ...

  7. 2014.7.12 敏捷个人奥森健步走&敏友分享会.活动报道

    今天是个阳光明媚的日子,正式开起了敏捷个人2014年每月一次的健步走&读书分享活动. 周老师一大早8点就到了森林公园南门,一边看书一边等候敏友们的到来.时间走到了9点半,大家基本到齐了,我们准 ...

  8. fcitx 无法启动

    困扰了好久的问题,终于解决了. 问题描述: 在fcitx的输入法配置栏里,输入法列表是空的,使用Ctrl+space无法启用任何的输入法, 当然此截图中的是有的,这是问题已经解决后的状态了. 解决方法 ...

  9. mysql 线上not in查询中的一个坑

    今天早上开发又过来说,怎么有个语句一直没有查询出结果,数据是有的呀,并发来了如下的sql(为了方法说明,表名及查询均做了修改): select * from t2 where t2.course no ...

  10. 第二sprint总结

    总结:在第二轮sprint中,团队的开发工作出现了极大的懈怠,团队成员分配的工作完成情况较差,进度较慢,希望能在最后一周中,完成预定的功能模块 个人贡献分: 124陈彦生:22=20*5*22% 14 ...