iOS开发UI篇—UIScrollView控件实现图片轮播

一、实现效果

实现图片的自动轮播


二、实现代码

storyboard中布局


代码:

 1 #import "YYViewController.h"  2  3 @interface YYViewController () <UIScrollViewDelegate>
 4 @property (weak, nonatomic) IBOutlet UIScrollView *scrollview;
 5 /**
 6  * 页码
 7 */  8 @property (weak, nonatomic) IBOutlet UIPageControl *pageControl;
 9  10 @property (nonatomic, strong) NSTimer *timer;
 11 @end  12  13 @implementation YYViewController
 14  15 - (void)viewDidLoad
 16 {
 17  [super viewDidLoad];
 18  19 // 图片的宽  20 CGFloat imageW = self.scrollview.frame.size.width;
 21 // CGFloat imageW = 300;
 22 // 图片高  23 CGFloat imageH = self.scrollview.frame.size.height;
 24 // 图片的Y  25 CGFloat imageY = 0;
 26 // 图片中数  27 NSInteger totalCount = 5;
 28 // 1.添加5张图片  29 for (int i = 0; i < totalCount; i++) {
 30 UIImageView *imageView = [[UIImageView alloc] init];
 31 // 图片X  32 CGFloat imageX = i * imageW;
 33 // 设置frame  34 imageView.frame = CGRectMake(imageX, imageY, imageW, imageH);
 35 // 设置图片  36 NSString *name = [NSString stringWithFormat:@"img_0%d", i + 1];
 37 imageView.image = [UIImage imageNamed:name];
 38 // 隐藏指示条  39 self.scrollview.showsHorizontalScrollIndicator = NO;
 40  41  [self.scrollview addSubview:imageView];
 42  }
 43  44 // 2.设置scrollview的滚动范围  45 CGFloat contentW = totalCount *imageW;
 46 //不允许在垂直方向上进行滚动  47 self.scrollview.contentSize = CGSizeMake(contentW, 0);
 48  49 // 3.设置分页  50 self.scrollview.pagingEnabled = YES;
 51  52 // 4.监听scrollview的滚动  53 self.scrollview.delegate = self;
 54  55  [self addTimer];
 56 }
 57  58 - (void)nextImage
 59 {
 60 int page = (int)self.pageControl.currentPage;
 61 if (page == 4) {
 62 page = 0;
 63 }else  64  {
 65 page++;
 66  }
 67  68 // 滚动scrollview  69 CGFloat x = page * self.scrollview.frame.size.width;
 70 self.scrollview.contentOffset = CGPointMake(x, 0);
 71 }
 72  73 // scrollview滚动的时候调用  74 - (void)scrollViewDidScroll:(UIScrollView *)scrollView
 75 {
 76 NSLog(@"滚动中");
 77 // 计算页码
 78 // 页码 = (contentoffset.x + scrollView一半宽度)/scrollView宽度  79 CGFloat scrollviewW = scrollView.frame.size.width;
 80 CGFloat x = scrollView.contentOffset.x;
 81 int page = (x + scrollviewW / 2) / scrollviewW;
 82 self.pageControl.currentPage = page;
 83 }
 84  85 // 开始拖拽的时候调用  86 - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
 87 {
 88 // 关闭定时器(注意点; 定时器一旦被关闭,无法再开启)
 89 // [self.timer invalidate];  90  [self removeTimer];
 91 }
 92  93 - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
 94 {
 95 // 开启定时器  96  [self addTimer];
 97 }
 98  99 /**
100  * 开启定时器
101 */ 102 - (void)addTimer{
103 104 self.timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];
105 106 }
107 /**
108  * 关闭定时器
109 */ 110 - (void)removeTimer
111 {
112  [self.timer invalidate];
113 }
114 @end


提示:以下两个属性已经和storyboard中的控件进行了连线。

@property (weak, nonatomic) IBOutletUIScrollView *scrollview;

@property (weak, nonatomic) IBOutletUIPageControl *pageControl;

补充:定时器NSTimer

定时器 适合用来隔一段时间做一些间隔比较长的操作

NSTimeInterval:多长多件操作一次

target :操作谁

selector : 要操作的方法

userInfo: 传递参数

repeats: 是否重复

self.timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(nextImage) userInfo:nil repeats:YES];

时间: 2024-08-03 19:00:55

iOS开发UI篇—UIScrollView控件实现图片轮播的相关文章

iOS开发UI篇—UIScrollView控件实现图片缩放功能

一.缩放 1.简单说明: 有些时候,我们可能要对某些内容进行手势缩放,如下图所示 UIScrollView不仅能滚动显示大量内容,还能对其内容进行缩放处理.也就是说,要完成缩放功能的话,只需要将需要缩放的内容添加到UIScrollView中 2.缩放原理 当用户在UIScrollView身上使用捏合手势时,UIScrollView会给代理发送一条消息,询问代理究竟要缩放自己内部的哪一个子控件(哪一块内容) 当用户在UIScrollView身上使用捏合手势时,UIScrollView会调用代理的v

iOS开发UI篇—UIScrollView控件介绍

一.知识点简单介绍 1.UIScrollView控件是什么? (1)移动设备的屏幕⼤大⼩小是极其有限的,因此直接展⽰示在⽤用户眼前的内容也相当有限 (2)当展⽰示的内容较多,超出⼀一个屏幕时,⽤用户可通过滚动⼿手势来查看屏幕以外的内容 (3)普通的UIView不具备滚动功能,不能显⽰示过多的内容 (4)UIScrollView是一个能够滚动的视图控件,可以⽤用来展⽰示⼤大量的内容,并且可以通过滚 动查看所有的内容 (5) 举例:手机上的"设置".其他⽰示例程序 2.UIScrollVi

iOS开发UI篇—UITableview控件简单介绍

一.基本介绍 在众多移动应⽤用中,能看到各式各样的表格数据 . 在iOS中,要实现表格数据展示,最常用的做法就是使用UITableView,UITableView继承自UIScrollView,因此支持垂直滚动,⽽且性能极佳 . UITableview有分组和不分组两种样式,可以在storyboard或者是用代码设置. 二.数据展示 UITableView需要⼀一个数据源(dataSource)来显示数据 UITableView会向数据源查询一共有多少行数据以及每⼀行显示什么数据等 没有设置数据

iOS开发UI篇—UITableview控件基本使用

一.一个简单的英雄展示程序 NJHero.h文件代码(字典转模型) 1 #import <Foundation/Foundation.h> 2 3 @interface NJHero : NSObject 4 /** 5 * 头像 6 */ 7 @property (nonatomic, copy) NSString *icon; 8 /** 9 * 名称 10 */ 11 @property (nonatomic, copy) NSString *name; 12 /** 13 * 描述 1

iOS开发UI之日期控件的使用(UIDatePicker)

iOS日期控件UIDatePicker用法总结 @property (nonatomic) UIDatePickerMode datePickerMode;  设置控件模式,枚举如下: ? 1 2 3 4 5 6 typedef NS_ENUM(NSInteger, UIDatePickerMode) {     UIDatePickerModeTime,           //时间模式,显示时分和上下午     UIDatePickerModeDate,           //日期模式显示

iOS应用开发中使用UIScrollView控件来实现图片缩放_IOS

一.知识点简单介绍 1.UIScrollView控件是什么? (1)移动设备的屏幕⼤大⼩小是极其有限的,因此直接展⽰示在⽤用户眼前的内容也相当有限 (2)当展⽰示的内容较多,超出⼀一个屏幕时,⽤用户可通过滚动⼿手势来查看屏幕以外的内容 (3)普通的UIView不具备滚动功能,不能显⽰示过多的内容 (4)UIScrollView是一个能够滚动的视图控件,可以⽤用来展⽰示⼤大量的内容,并且可以通过滚 动查看所有的内容  (5)  举例:手机上的"设置".其他⽰示例程序 2.UIScroll

iOS开发UI篇—popoverController使用注意

iOS开发UI篇-popoverController使用注意 iOS开发UI篇-popoverController使用注意 一.设置尺寸 提示:不建议,像下面这样吧popover的宽度和高度写死. 1 //1.新建一个内容控制器 2 YYMenuViewController *menuVc=[[YYMenuViewController alloc]init]; 3 4 //2.新建一个popoverController,并设置其内容控制器 5 self.popover=[[UIPopoverCo

iOS开发UI篇—UITableviewcell的性能优化和缓存机制

iOS开发UI篇-UITableviewcell的性能问题 一.UITableviewcell的一些介绍 UITableView的每一行都是一个UITableViewCell,通过dataSource的 tableView:cellForRowAtIndexPath:方法来初始化每⼀行 UITableViewCell内部有个默认的子视图:contentView,contentView是UITableViewCell所显示内容的父视图,可显示一些辅助指示视图 辅助指示视图的作⽤是显示一个表示动作的

iOS开发UI篇:APP主流UI框架结构

一.简单示例 说明:使用APP主流UI框架结构完成简单的界面搭建 搭建页面效果: 开发UI篇:APP主流UI框架结构-"> 查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/OS/extra/