滚动视图(UIScrollView)通常用于显示内容尺寸大于屏幕尺寸的视图。

一、基本属性

1、CGSize contentSize :设置UIScrollView的滚动范围

2、CGPoint contentOffset :UIScrollView当前滚动的位置

3、UIEdgeInsets contentInset :设置内容的边缘

4、BOOL bounces 当超出边界时表示是否可以反弹

5、BOOL scrollEnabled 是否能滚动

6、BOOL showsHorizontalScrollIndicator 是否显示水平方向的滚动条

7、BOOL showsVerticalScrollIndicator     是否显示垂直方向的滚动条

8、UIScrollViewIndicatorStyle indicatorStyle  设定滚动条的样式

9、BOOL tracking  监控当前目标是否正在被跟踪

10、BOOL dragging 监控当前目标是否正在被拖拽

11、BOOL decelerating 监控当前目标是否正在减速

12、BOOL zooming 判断控件的大小是否正在改变

13、BOOL zoomBouncing 判断是否正在进行缩放反弹

14、minimumZoomScale  缩小的最小比例

15、maximumZoomScale 放大的最大比例

16、BOOL scrollsToTop 点击设备的状态栏时,是scrollsToTop = YES的控件滚动返回至顶部

 //初始化,设置尺寸和大小
scrollView = [[UIScrollView alloc] initWithFrame:(CGRect){,,frame.size.width,frame.size.height}];
//添加到视图
[self.view addSubview:scrollView];
//背景颜色
scrollView.backgroundColor = [UIColor orangeColor];
//滚动范围
scrollView.contentSize = CGSizeMake(frame.size.width+, frame.size.height+);
//设置代理
scrollView.delegate = self;
//是否分页
scrollView.pagingEnabled = YES;
//是否滚动
scrollView.scrollEnabled = YES;
//是否显示滚动条
scrollView.showsHorizontalScrollIndicator = YES;
scrollView.showsVerticalScrollIndicator = NO;
//滚动条风格
scrollView.indicatorStyle = UIScrollViewIndicatorStyleWhite;
//内容边缘和indicator边缘
scrollView.contentInset = UIEdgeInsetsMake(, , , );
scrollView.scrollIndicatorInsets = UIEdgeInsetsMake(, , , );

二、常见方法

1、返回一个放大或者缩小的视图

- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;

2、开始放大或者缩小

- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;

3、缩放结束时

- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale;

4、视图已经放大或缩小

- (void)scrollViewDidZoom:(UIScrollView *)scrollView;

5、是否支持滑动至顶部

- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView;

6、滑动到顶部时调用该方法

- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView;

7、scrollView 已经滑动

- (void)scrollViewDidScroll:(UIScrollView *)scrollView;

8、scrollView 开始拖动

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView;

9、scrollView 结束拖动

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate;

10、scrollView 开始减速

- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView;

11、scrollview 减速停止

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;

三、UIScrollView和UIPageControl实现图片切换

首先简单介绍下UIPageControl:

UIPageControll 是继承于UIControl的一个IOS系统UI控件,可以提供给开发者设计分页效果的功能。

     //初始化
pageCtrl=[[UIPageControl alloc] initWithFrame:CGRectMake(, , , )];
[self.view addSubview:pageCtrl];
//设置控制器页数(默认为0)
pageCtrl.numberOfPages=;
//设置当前所在页码
pageCtrl.currentPage = ;
//设置当总页数为1时,是否自动隐藏控制器
pageCtrl.hidesForSinglePage = YES;
//设置控制器页码点得颜色
pageCtrl.pageIndicatorTintColor = [UIColor orangeColor];
//设置控制器当前所在页码点的颜色
pageCtrl.currentPageIndicatorTintColor = [UIColor greenColor];
pageCtrl.tag=; //给pageControl添加点击事件
[pageCtrl addTarget:self action:@selector(turnPage:) forControlEvents:UIControlEventTouchUpInside];

视图载入:

 @interface ViewController ()<UIScrollViewDelegate>{

     UIScrollView *scrollView;
UIPageControl *pageCtrl; NSArray *imageArray; } @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib. //初始化
scrollView = [[UIScrollView alloc] initWithFrame:(CGRect){,,self.view.frame.size.width,self.view.frame.size.height}];
[self.view addSubview:scrollView];
//代理
scrollView.delegate = self;
//滑动范围
scrollView.contentSize = CGSizeMake(*, );
//背景颜色
scrollView.backgroundColor = [UIColor clearColor];
//是否分页
scrollView.pagingEnabled = YES;
//是否显示滚动条
scrollView.showsHorizontalScrollIndicator = NO;
scrollView.showsVerticalScrollIndicator = NO; //图片数组
imageArray = @[@"u=1522827729,398642494&fm=21&gp=0", @"u=498354980,1967037110&fm=21&gp=0", @"u=455056084,2054881807&fm=21&gp=0"]; //加载图片
for (int i=; i<; i++) {
UIImageView *imageView=[[UIImageView alloc] initWithFrame:CGRectMake(i*, , , )];
//imageView.image=[UIImage imageNamed:[NSString stringWithFormat:@"image%d.jpg",i+1]];
NSString *image = [imageArray objectAtIndex:i];
imageView.image = [UIImage imageNamed:image]; [scrollView addSubview:imageView]; }
//初始化
pageCtrl=[[UIPageControl alloc] initWithFrame:CGRectMake(, , , )];
[self.view addSubview:pageCtrl];
//设置控制器页数(默认为0)
pageCtrl.numberOfPages=;
//设置当前所在页码
pageCtrl.currentPage = ;
//设置当总页数为1时,是否自动隐藏控制器
pageCtrl.hidesForSinglePage = YES;
//设置控制器页码点得颜色
pageCtrl.pageIndicatorTintColor = [UIColor orangeColor];
//设置控制器当前所在页码点的颜色
pageCtrl.currentPageIndicatorTintColor = [UIColor greenColor];
pageCtrl.tag=; //给pageControl添加点击事件
[pageCtrl addTarget:self action:@selector(turnPage:) forControlEvents:UIControlEventTouchUpInside]; }

图片切换:

 //UIScrollViewDelegate的scrollViewDidEndDecelerating函数,用户滑动页面停下后调用该函数
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)ScrollView
{
//更新UIPageControl的当前页
int current=scrollView.contentOffset.x/scrollView.frame.size.width;
NSLog(@"scrollview :%f",scrollView.contentOffset.x);
UIPageControl *pageControl = (UIPageControl*)[self.view viewWithTag:];
pageControl.currentPage = current; } //点击UIPageControl时的响应函数turnPage
- (void)turnPage:(UIPageControl*)change{
///令UIScrollView做出相应的滑动显示
CGSize size = scrollView.frame.size;
CGRect rect = (CGRect){change.currentPage*size.width,,size.width,size.height};
[scrollView scrollRectToVisible:rect animated:YES]; }

如图:

iOS基础篇(十五)——UIScrollView的基本用法的更多相关文章

  1. IOS基础之 (十五)知识点

    一 SEL 1. 方法的存储位置 每个类的方法地址列表都存储在类对象中. 每个方法都有一个与之对应的SEL类型的对象. 根据一个SEL对象就可以找到方法的地址,进而调用方法. Person.h #im ...

  2. ios基础篇(五)——UITextField的详细使用

    UItextFieldField通常用于外部数据输入,以实现人机交互. 以下是UItextFieldField的属性及常见用法: 1.textField :设置文本框的默认文本. 2.Placehol ...

  3. Bootstrap <基础二十五>警告(Alerts)

    警告(Alerts)以及 Bootstrap 所提供的用于警告的 class.警告(Alerts)向用户提供了一种定义消息样式的方式.它们为典型的用户操作提供了上下文信息反馈. 您可以为警告框添加一个 ...

  4. 小猪猪C++笔记基础篇(五)表达式、语句

    小猪猪C++笔记基础篇(五) 关键词:表达式.语句 本章的内容比较简单,基本上没有什么理解上的困难,都是知识上的问题.先开始想要不要写呢,本来是不准备写的,但是既然读了书就要做笔记,还是写一写,毕竟还 ...

  5. Java15-java语法基础(十五)——内部类

    java16-java语法基础(十五)内部类 一.内部类: 可以在一个类的内部定义另一个类,这种类称为内部类. 二.内部类分为两种类型: 1.静态内部类: 静态内部类是一个具有static修饰词的类, ...

  6. python基础篇(五)

    PYTHON基础篇(五) 算法初识 什么是算法 二分查找算法 ♣一:算法初识 A:什么是算法 根据人们长时间接触以来,发现计算机在计算某些一些简单的数据的时候会表现的比较笨拙,而这些数据的计算会消耗大 ...

  7. Java基础之十五 泛型

    第十五章 泛型 一般的类和方法,只能使用具体的类型:要么是基本类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制对代码的束缚就会很大. 在面对对象编程语言中,多态算是一种泛化机 ...

  8. Python基础篇(五)_文件和数据格式化

    Python基础篇_文件和数据格式化 文件的使用:文件打开.关闭.读写 文件打开:通过open()函数打开文件,并返回一个操作文件的变量. 使用语法:<变量名> = (<文件路径以及 ...

  9. 《手把手教你》系列基础篇(五)-java+ selenium自动化测试- 创建首个自动化脚本(详细教程)

    1.简介 前面几篇宏哥介绍了两种(java和maven)环境搭建和三大浏览器的启动方法,这篇文章宏哥将要介绍第一个自动化测试脚本.前边环境都搭建成功了,浏览器也驱动成功了,那么我们不着急学习其他内容, ...

随机推荐

  1. 初识轻量级Java开源框架 --- Spring

    初识轻量级Java开源框架 --- Spring 作者:egg 微博:http://weibo.com/xtfggef 出处:http://blog.csdn.net/zhangerqing spri ...

  2. Matlab中图片保存的5种方法

    matlab的绘图和可视化能力是不用多说的,可以说在业内是家喻户晓的. Matlab提供了丰富的绘图函数,比如ez**系类的简易绘图函数,surf.mesh系类的数值绘图函数等几十个.另外其他专业工具 ...

  3. Python快速建站系列-Part.Two-结构化和布局

    |版权声明:本文为博主原创文章,未经博主允许不得转载. 首先明确我们要建一个什么样的站,作为教程(也算自己使用tornado的一个小总结),自然功能不能太多,但又满足一个普通网站需要的就行了. 目前想 ...

  4. Web开发的常见面试题HTML和HTML5等

    作为一名前端开发人员,HTML,HTML5以及网站优化都是必须掌握的技术,下面列举一下HTML, HTML5, 网站优化等常见的面试题: HTML常见面试题: 1. 什么是Semantic HTML( ...

  5. JS变量、内存、作用域小结

    确保占用最少的内存可以让页面获得更好的性能,优化内存占用的最佳方式:为执行中的代码 只保存必要的数据.一旦数据不再有用,最好通过将其值置为null来释放其引用.适用于大多 数全局变量和全局对象的属性. ...

  6. 8 个最棒的 .NET 开发相关工具

    本文向你介绍 8 款跟 .NET 开发相关的一些工具. 1) Open Source – Sharp Develop SharpDevelop是一个用于开发C#或者VB.NET项目而设计的一个编辑器, ...

  7. LeetCode----263. Ugly Number(Java)

    package isUgly263; /* * Write a program to check whether a given number is an ugly number. Ugly numb ...

  8. 上传图片预览设置src不显示

    使用滤镜效果解决: window.parent.document.body.focus(); var imgurl = (document.selection.createRange().text). ...

  9. 搭建自己本地yum源

    1.挂载系统光盘(注:medi下的cdrom是我自己创建的,可以挂载在任意目录) [root@liutao ~]# mount /dev/cdrom /media/cdrom/ 2.修改yum配置文件 ...

  10. 解决一道leetcode算法题的曲折过程及引发的思考

    写在前面 本题实际解题过程是 从 40秒 --> 24秒 -->1.5秒 --> 715ms --> 320ms --> 48ms --> 36ms --> ...