iOS开发-图片查看(ScrollView+UIPageControl)

简介:

上周没事写了一个简单的图片查看,上次的查看只用到了一个UIImageView,不断的替换背景图片,实现图片之间的切换。通过ScrollView可以很简单的是实现图片之间的查看,设置setPagingEnabled通过坐标,宽度的设置,可以简单实现一个图片的简单分页查看显示,当然如果你有需求说需要进行所谓的无限循环,在开始和结束的时候的设置一下事件,常用的新闻客户端,图片新闻查看的时候很少有进行最后的时候跳到第一页,一般都是最后的时候都是推荐相关内容,多说了两句,开始吧:

ScrollView图片分页

控件跟上篇文章一样,就是ScrollView:

拖入三张图片到项目中,之前的文章有演示,下次写博客的考虑换图,初始化ScrollView:

1
2
3
4
5
6
7
8
9
10
NSArray  *imageArr=@[@ "girl0.jpg" ,@ "girl1.jpg" ,@ "girl2.jpg" ];
CGFloat width= self .scrollView.bounds.size.width;
CGFloat height= self .scrollView.bounds.size.height;
for  ( NSInteger  i=0; i<[imageArr count]; i++) {
       UIImage *image=[UIImage imageNamed:imageArr[i]];
     UIImageView *imageView=[[UIImageView alloc] initWithImage:image];
     
     [imageView setFrame:CGRectMake(i*width, 0, width, height)];
     [_scrollView addSubview:imageView];
}

 这里没有写注释,稍微多说一句就是bounds是边界,可以理解为就是控件中的ScrollView的宽度和高度,也就是上一张图片展示的宽度和高度,设置周围的边界:

1
[ self .scrollView setBounces: NO ];

 设置水平方向的滚动条:

1
[ self .scrollView setShowsHorizontalScrollIndicator: NO ];

设置ScrollView的总体的宽度(关键):

1
[ self .scrollView setContentSize:CGSizeMake([imageArr count]*width, height)];

设置分页:

1
[ self .scrollView setPagingEnabled: YES ];

演示效果:

UIPageControl和ScrollView图片分页

UIPageControl如果稍微弄过点前端可以理解为焦点图,大概通过指示,iOS中是小圆点,Android需要美工给自己切图或者说自力更生,iOS相对来说还是比较人性的,先定义一个UIPageControl:

1
@property  ( nonatomic ,strong) UIPageControl *pageControl;

 初始化UIPageControl设置大小和位置:

1
2
3
4
5
self .pageControl=[[UIPageControl alloc] init];
   self .pageControl.backgroundColor=[UIColor clearColor];
   
   [ self .pageControl setBounds:CGRectMake(0, 0,200, 100)];
   [ self .pageControl setCenter:CGPointMake(width/2,height/2+200.0)];

 设置当前页和页大小:

1
2
self .pageControl.numberOfPages=[imageArr count];
    self .pageControl.currentPage=0;

设置当前指示和其他指示:

1
2
3
[ self .pageControl setCurrentPageIndicatorTintColor:[UIColor greenColor]];
  
  [ self .pageControl setPageIndicatorTintColor:[UIColor yellowColor]];

设置滑动的时候改变UIPageControl和通过UIPageControl改变ScrollView:

1
2
3
[_scrollView setDelegate: self ];
[ self .pageControl addTarget: self  action: @selector (switchPage:) forControlEvents:UIControlEventValueChanged];
[ self .view addSubview:_pageControl];

滑动的时候改变UIPageControl指示通过委托设置,具体可参考上篇文章:

1
2
3
4
-( void )scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
     NSInteger  currentPage=scrollView.contentOffset.x/ self .view.bounds.size.width;
     [ self .pageControl setCurrentPage:currentPage];
}

UIPageControl改变ScrollView:

1
2
3
4
5
- ( void )switchPage:( id )sender{
     UIPageControl *currentControl=(UIPageControl *)sender;
     NSInteger  currentPage=currentControl.currentPage;
     [_scrollView setContentOffset:CGPointMake(currentPage* self .view.bounds.size.width, 0)] ;
}

 看下具体的效果:

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

相关文章
|
4天前
|
开发工具 Android开发 iOS开发
探索Android与iOS开发的差异与挑战
【7月更文挑战第11天】在移动应用开发的广阔天地中,Android和iOS两大平台如同双子星座般耀眼,各自拥有独特的开发生态和用户群体。本文将深入分析这两个平台的显著差异,从技术架构到开发工具,再到市场定位,揭示它们之间的异同。通过比较,我们不仅能够更好地理解各自的优势和局限,还能洞察未来移动应用开发的趋势。
|
7天前
|
Java Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【7月更文挑战第8天】在移动应用开发的广阔天地中,Android与iOS两大平台各自占据着半壁江山。本文将深入探讨这两个平台在开发环境、用户界面设计、性能优化以及市场覆盖等方面的根本差异,并分析这些差异如何影响项目的成功。通过比较和分析,旨在为开发者在选择平台时提供更全面的视角,帮助他们根据项目需求和目标市场做出更明智的决策。
|
2天前
|
前端开发 开发工具 Swift
学习iOS开发的准备
准备学习iOS开发?确保有Mac和最新Xcode,先学好编程基础特别是Swift。利用Apple官方文档、在线课程和书籍作为资源。熟悉Xcode及Git,通过实践项目和开源代码积累经验。深研架构模式、核心框架和优化技巧。加入开发者社区,关注行业动态,持续学习。
14 1
|
8天前
|
开发工具 Swift iOS开发
探索iOS开发中的SwiftUI框架
【7月更文挑战第7天】在iOS应用开发的广阔天地中,SwiftUI框架以其现代化的设计理念和强大的功能特性,正逐步改变着开发者构建用户界面的方式。本文将深入探讨SwiftUI的核心概念、优势以及在实际项目中的应用,帮助读者理解这一框架如何简化iOS开发流程并提升用户体验。
187 7
|
7天前
|
移动开发 开发工具 Android开发
探索安卓与iOS开发的差异:平台特性与编程实践
【7月更文挑战第8天】在移动开发的广阔天地中,安卓和iOS这两大操作系统各自占据着半壁江山。它们在用户界面设计、系统架构及开发工具上展现出截然不同的特色。本文将深入探讨这两个平台在技术实现和开发生态上的关键差异,并分享一些实用的开发技巧,旨在为跨平台开发者提供有价值的见解和建议。
|
4天前
|
Java 开发工具 Android开发
探索Android与iOS开发的差异与挑战
【7月更文挑战第11天】在移动应用开发的广阔天地中,Android和iOS两大平台各领风骚。本文将深入探讨这两个平台的开发差异,从编程语言、用户界面设计到开发工具等方面进行比较,并分析开发者面临的挑战。通过对比分析,旨在为开发者提供一个全面的视角,帮助他们更好地选择适合自己项目需求的开发平台。
8 0
|
4天前
|
iOS开发 开发者 UED
探索iOS开发中的SwiftUI框架
【7月更文挑战第11天】本文将深入探讨SwiftUI框架,这是苹果公司为iOS开发者提供的一个现代化、声明式的用户界面工具。我们将了解SwiftUI如何简化界面设计流程,提升代码的可读性和可维护性,并讨论其在实际应用中的优势和局限性。通过实际案例分析,本文旨在帮助读者更好地理解SwiftUI的核心概念和应用实践。
|
5天前
|
机器学习/深度学习 人工智能 iOS开发
探索iOS开发的未来:SwiftUI的革新之旅
在数字时代的浪潮中,iOS开发正经历一场由SwiftUI引领的变革。本文将深入探讨SwiftUI如何重塑移动应用开发,提升开发者的生产力,并展望其对iOS生态的影响。通过分析SwiftUI的核心特性、实际案例和未来趋势,我们将揭示这一现代框架如何定义用户体验的新标准,同时为iOS开发者指明技术进阶之路。
|
6天前
|
搜索推荐 Android开发 iOS开发
探索Android与iOS开发的差异:平台特性与用户体验的对比分析
【7月更文挑战第9天】在移动应用开发的浩瀚海洋中,Android和iOS两大操作系统如同两座灯塔,指引着开发者们的航向。本文将深入探讨这两个平台在开发环境、用户界面设计、性能优化以及市场策略上的根本差异。我们将通过比较分析,揭示各自平台的独特优势和潜在挑战,为开发者提供决策支持,同时也为用户体验的提升指明方向。
|
10天前
|
移动开发 Android开发 iOS开发
探索安卓与iOS开发的差异:平台选择对应用性能的影响
在移动开发的广阔舞台上,安卓与iOS这两大操作系统各据一方,引领着技术潮流与市场需求。本文深入探讨了这两个平台在开发过程中的关键差异,并分析了这些差异如何影响应用的性能和用户体验。通过对比分析,我们将揭示开发者在选择平台时应考虑的技术细节,以及这些选择如何塑造最终产品的命运。文章不仅为开发者提供了实用的指导,也为那些对移动开发感兴趣的读者提供了深刻的洞见。