iOS开发-UIScrollView图片无限循环

简介:

关于UIScrollView图片浏览的例子有很多,之前也写过类似方面的文章,关于UIScrollView的图片循环在新闻类的App基本上是比较常见的一种情况就是图片浏览,然后根据不同的图片显示不同的内容显示不同的图片的介绍,因为属于比较常用的空间,先来看下需要实现的效果:

小圆点指示器是通过UIPageControl实现的,图片循环通过UIScrollView实现:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
-(UIPageControl *)pageControl{
     if  (!_pageControl) {
         _pageControl=[[UIPageControl alloc]initWithFrame:CGRectMake(0, 0, 150, 40)];
         _pageControl.currentPage=0;
         _pageControl.pageIndicatorTintColor=[UIColor whiteColor];
         _pageControl.currentPageIndicatorTintColor=[UIColor greenColor];
     }
     return  _pageControl;
}
-(UIScrollView *)scrollView{
     if  (!_scrollView) {
         CGRect   screenRect=[[UIScreen mainScreen]bounds];
         _scrollView=[[UIScrollView alloc]initWithFrame:CGRectMake(0, 64, CGRectGetWidth(screenRect), CGRectGetHeight(screenRect)-164)];
         [_scrollView setBounces:NO];
         [_scrollView setShowsHorizontalScrollIndicator:NO];
         [_scrollView setPagingEnabled:YES];
         _scrollView. delegate =self;
     }
     return  _scrollView;
}

关于分页的页面配置以及页数Label的设置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
self.screenRect=[[UIScreen mainScreen]bounds];
CGFloat width=self.scrollView.bounds.size.width;
CGFloat height=self.scrollView.bounds.size.height;
self.imageArr=@[ @"girl0.jpg" , @"girl1.jpg" , @"girl2.jpg" ];
[self.scrollView setContentSize:CGSizeMake([self.imageArr count]*width, height)];
 
for  (NSInteger i=0; i<[self.imageArr count]; i++) {
     UIImageView  *imageView=[[UIImageView alloc]initWithFrame:CGRectMake(i*width, 0, width,height)];
     imageView.image=[UIImage imageNamed:self.imageArr[i]];
     imageView.contentMode=UIViewContentModeScaleToFill;
     [self.scrollView  addSubview:imageView];
}
[self.view addSubview:self.scrollView];
 
self.pageControl.numberOfPages=[self.imageArr count];
self.pageControl.center=CGPointMake(self.scrollView.center.x, CGRectGetMaxY(self.scrollView.bounds)+50);
[self.view addSubview:self.pageControl];
self.pageLabel.text=[NSString stringWithFormat: @"%d/%lu" ,1,[self.imageArr count]];
[self.view addSubview:self.pageLabel];

实现UIScrollViewDelegate中scrollViewDidEndDecelerating的方法:

1
2
3
4
5
6
7
8
9
10
11
//博客园-FlyElephant 原文地址:http://www.cnblogs.com/xiaofeixiang/
-( void )scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
     if  (self.currentPage==[self.imageArr count]-1) {
         self.currentPage=0;
         self.scrollView.contentOffset=CGPointMake(0, 0);
     } else {
        self.currentPage=scrollView.contentOffset.x/CGRectGetWidth(self.screenRect);
     }
     self.pageControl.currentPage=self.currentPage;
     [self.pageLabel setText:[NSString stringWithFormat: @"%ld/%lu" ,self.currentPage+1,[self.imageArr count]]];
}

 简单的UIScrollView实现基本上ok了,当然关于UIScrollView根据不同场景去实现不同的功能代码量比这肯定更复杂~

本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4754451.html,如需转载请自行联系原作者

相关文章
|
8天前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
1天前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
16天前
|
安全 数据处理 Swift
深入探索iOS开发中的Swift语言特性
本文旨在为开发者提供对Swift语言在iOS平台开发的深度理解,涵盖从基础语法到高级特性的全面分析。通过具体案例和代码示例,揭示Swift如何简化编程过程、提高代码效率,并促进iOS应用的创新。文章不仅适合初学者作为入门指南,也适合有经验的开发者深化对Swift语言的认识。
36 9
|
12天前
|
设计模式 Swift iOS开发
探索iOS开发:从基础到高级,打造你的第一款App
【10月更文挑战第40天】在这个数字时代,掌握移动应用开发已成为许多技术爱好者的梦想。本文将带你走进iOS开发的世界,从最基础的概念出发,逐步深入到高级功能实现,最终指导你完成自己的第一款App。无论你是编程新手还是有志于扩展技能的开发者,这篇文章都将为你提供一条清晰的学习路径。让我们一起开始这段旅程吧!
|
15天前
|
Android开发 Swift iOS开发
探索安卓与iOS开发的差异和挑战
【10月更文挑战第37天】在移动应用开发的广阔舞台上,安卓和iOS这两大操作系统扮演着主角。它们各自拥有独特的特性、优势以及面临的开发挑战。本文将深入探讨这两个平台在开发过程中的主要差异,从编程语言到用户界面设计,再到市场分布的不同影响,旨在为开发者提供一个全面的视角,帮助他们更好地理解并应对在不同平台上进行应用开发时可能遇到的难题和机遇。
|
13天前
|
iOS开发 开发者
探索iOS开发中的SwiftUI框架
【10月更文挑战第39天】在苹果的生态系统中,SwiftUI框架以其声明式语法和易用性成为开发者的新宠。本文将深入SwiftUI的核心概念,通过实际案例展示如何利用这一框架快速构建用户界面,并探讨其对iOS应用开发流程的影响。
|
16天前
|
JSON 前端开发 API
探索iOS开发之旅:打造你的第一个天气应用
【10月更文挑战第36天】在这篇文章中,我们将踏上一段激动人心的旅程,一起构建属于我们自己的iOS天气应用。通过这个实战项目,你将学习到如何从零开始搭建一个iOS应用,掌握基本的用户界面设计、网络请求处理以及数据解析等核心技能。无论你是编程新手还是希望扩展你的iOS开发技能,这个项目都将为你提供宝贵的实践经验。准备好了吗?让我们开始吧!
|
iOS开发
iOS - 设置图片为背景色,且拉伸到指定大小
iOS - 设置图片为背景色,且拉伸到指定大小
301 0
|
编解码 iOS开发
iOS中图片(UIImage)拉伸技巧
iOS中图片(UIImage)拉伸技巧
352 0
iOS中图片(UIImage)拉伸技巧
下一篇
无影云桌面