//创建ScrollView的方法

-(void)createScrollView

{

UIScrollView *sv = [[UIScrollView alloc]initWithFrame:CGRectMake(5, 5, self.view.frame.size.width - 10, self.view.frame.size.height-10)];

//w代表sv.frame的宽度

CGFloat w = self.view.frame.size.width - 10;

//滑动的size的设置

//宽度 如果要横着滑动设置大于sv.frame的宽度

sv.contentSize = CGSizeMake(3*w, sv.frame.size.height-10);

//获得三个图放到UIImageView

for (int i =0; i<3; i++)

{

//获得三张图

UIImage*image =[UIImage imageNamed:[NSString stringWithFormat:@"43_%d.jpg",i+1]];

//三张图放到imageView上去

UIImageView *iv = [[UIImageView alloc]initWithImage:image];

//设定imageView的位置

iv.frame = CGRectMake(i*w, 0, w, self.view.frame.size.height-10);

//        iv.userInteractionEnabled = YES;

//iv放到父视图 ScrollView上面去

[sv addSubview:iv];

}

//水平滑动指示条

sv.showsHorizontalScrollIndicator = NO;

//垂直滑动指示条

sv.showsVerticalScrollIndicator = NO;

//设置按页滑动 page

//  sv.pagingEnabled = YES;

//弹性设置

sv.bounces = NO;

sv.userInteractionEnabled = YES;

//自带放大 缩小 option

//默认不自己放大缩小

//设置放大最大的倍数

sv.maximumZoomScale = 2;

//设置最小缩小到多大

sv.minimumZoomScale = 0.5;

//设置代理

sv.delegate = self;

//要不要返回顶部

sv.scrollsToTop = YES;

//添加背景色

sv.backgroundColor = [UIColor redColor];

//添加到主界面

[self.view addSubview:sv];

//

UIPageControl *pageC = [[UIPageControl alloc]initWithFrame:CGRectMake(0, 0, 200, 40)];

pageC.center=CGPointMake(150,300);

pageC.numberOfPages = 10;

pageC.currentPage =2;

pageC.tag = 200;

pageC.currentPageIndicatorTintColor = [UIColor greenColor];

[pageC addTarget:self action:@selector(pageC:) forControlEvents:UIControlEventValueChanged];

pageC.pageIndicatorTintColor = [UIColor blackColor];

pageC.backgroundColor = [UIColor redColor];

[self.view addSubview:pageC];

}

#pragma mark -delegate

//控制放缩 代理方法

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

{

//使得所有的界面都可以进行放缩

return scrollView.subviews[0];

}

//已经滑动

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

NSLog(@"开始滑动之后 执行的方法");

NSInteger index = scrollView.contentOffset.x /scrollView.frame.size.width;

UIPageControl *pc =(UIPageControl*) [self.view viewWithTag:200];

pc.currentPage =index;

}

//已经放缩

- (void)scrollViewDidZoom:(UIScrollView *)scrollView

{

NSLog(@"放缩之后 执行的方法");

}

//开始拖动的方法

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

{

NSLog(@"即将滑动的状态 指头轻轻一划");

}

// called on finger up if the user dragged. velocity is in points/millisecond. targetContentOffset may be changed to adjust where the scroll view comes to rest

- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset

{

//scrollview就是当前的scrollview

//velocity加速度

//offset 移动

NSLog(@"即将结束滑动,手指移开 惯性还在滑的时候");

}

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

{

NSLog(@"已经结束滑动");

}

- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView

{

NSLog(@"减速");

}

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

{

NSLog(@"减速完成 和滑动结束 状态基本一致");

}

- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView

{

NSLog(@"结束滑动的动画");

}

//- (nullable UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;     // return a view that will be scaled. if delegate returns nil, nothing happens

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

{

//

bigSmallV = view;

NSLog(@"即将开始缩放");

}

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

{

NSLog(@"已经结束缩放");

}

- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView

{

NSLog(@"返回是否可以滑动到顶部");

//返回YES表示可以滑动到顶部 返回No表示不可以滑动到顶部

return YES;

}

- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView

{

NSLog(@"已经返回到顶部");

}

#pragma mark - delegate

-(void)pageC:(UIPageControl *)pc

{

}

iosUIScrollView以及UIPageControl的基本使用以及所有代理方法的更多相关文章

  1. iOS- UIScrollView、UIPageControl分页浏览图片

    1.先介绍下UIScrollView的常见属性 @property(nonatomic) CGPoint contentOffset; // 记录UIScrollView滚动的位置 @property ...

  2. iOS-UIScrollView和UIPageControl的综合实力,滚动图,轮播图

    本代码主要实现图片之间的切换 目录结构 代码 ViewController.m文件 #import "ViewController.h" @interface ViewContro ...

  3. iOS--UIScrollView基本用法和代理方法

    主要是为了记录下UIScrollView的代理方法吧 在帮信息学院的学长做东西的时候需要大量用到分块浏览,所以就涉及到很多的关于scrollview,所以也就有了这篇文章   - (void)view ...

  4. UIPageControl简单使用

    1.添加一个UIPageControl到view中 -(void)addPageControl { UIPageControl* page=[[UIPageControl alloc]init]; p ...

  5. UI:UIScrollView、UIPageControl

    一.UIScrollView的常⽤用属性 二.UIScrollView的常⽤用代理方法 三.UIPageControl的使⽤用 四.UIPageControl与UIScrollView的结合使⽤用 U ...

  6. IOS-UIScrollView实现图片分页

    1.设置可以分页 _scrollView.pagingEnabled = YES; 2.添加PageControl UIPageControl *pageControl = [[UIPageContr ...

  7. 使用UIPageControl UIScrollView制作APP引导界面

    1. 新建两个视图控制器类(继承自UIViewController), 在AppDelegate.m中指定根视图控制器 #import "AppDelegate.h" #impor ...

  8. 利用UIScrollView和UIPageControl实现多页图片欢迎页面

    在.h文件当中实现UIScrollViewDelegate协议,让控制器充当代理: #import <UIKit/UIKit.h> @interface RPRootViewControl ...

  9. UIScrollView 和 UIPageControl

    UIScrollView [滚动视图]非常重要 UIScrollView是滚动视图,是其它带有滚动功能视图的父类, 本身不显示或者只显示背景,主要负责子视图的滚动和翻页. 一.常用属性 1.基本方法 ...

随机推荐

  1. vs2008编译FileZilla服务端源码

    vs2008编译FileZilla服务端源码 FileZilla服务端下载地址:https://download.filezilla-project.org/server/.FileZilla服务端源 ...

  2. HDU - 3966 Aragorn's Story(树链剖分入门+线段树)

    HDU - 3966 Aragorn's Story Time Limit: 3000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & ...

  3. java 方法学习

    手写随机代码 public class suiji{private static final int N = 200;private static final int LEFT = 40;privat ...

  4. javaWEB总结(11):JSP简介及原理

    前言 本文主要通过一个简单小例子,介绍JSP的原理. 1.项目结构 2.web.xml <?xml version="1.0" encoding="UTF-8&qu ...

  5. MySQL5.5.28启动错误 The server quit without updating PID file

    今天重新安装了一次 MySQL5.5.28 ,但启动的时候老是报错 Starting MySQL.. ERROR! The server quit without updating PID file ...

  6. HDU 5831 Rikka with Parenthesis II

    如果左括号数量和右括号数量不等,输出No 进行一次匹配,看匹配完之后栈中还有多少元素: 如果n=2,并且栈中无元素,说明是()的情况,输出No 如果n=2,并且栈中有元素,说明是)(的情况,输出Yes ...

  7. scp免密码传送文件

    一.单向 ssh-keygen -t rsa 单向无密码访问远程服务器操作比较简单,比如服务器A需要无密码访问服务器B(A–>B),那么只需要在服务器A生成密钥对,将生成的公钥上传到服务器B的相 ...

  8. linux搭建phantomjs+webdriver+testng+ant自动化工程

    因为项目的原因,需要将脚本在linux环境无浏览器化去跑,那么原有的在windows系统下有浏览器化的自动化脚本场景就不适用了,这里给出linux系统下搭建phantomjs+webdriver+te ...

  9. Google科学家前腾讯副总裁吴军将出席第二届万物互联创新大会

    当越来越多的科技产品注入互联网的基因,"万物互联"的模式悄然兴起.第二届万物互联创新大会(B12大会)将于2016-11-13日在杭州市余杭区隆重召开.Google科学家前腾讯副总 ...

  10. 2016腾讯we大会的时间——2016年11月6日

    作为腾讯公司主办的一场国际化创新盛会,WE大会由腾讯公司自2013年以来每年举办,WE大会已迎来第四年,每年大会都会邀请全球互联网思想家.前沿创新团队来进行现场演讲和分享,分享最前沿的思想和技术,创造 ...