iosUIScrollView以及UIPageControl的基本使用以及所有代理方法
//创建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的基本使用以及所有代理方法的更多相关文章
- iOS- UIScrollView、UIPageControl分页浏览图片
1.先介绍下UIScrollView的常见属性 @property(nonatomic) CGPoint contentOffset; // 记录UIScrollView滚动的位置 @property ...
- iOS-UIScrollView和UIPageControl的综合实力,滚动图,轮播图
本代码主要实现图片之间的切换 目录结构 代码 ViewController.m文件 #import "ViewController.h" @interface ViewContro ...
- iOS--UIScrollView基本用法和代理方法
主要是为了记录下UIScrollView的代理方法吧 在帮信息学院的学长做东西的时候需要大量用到分块浏览,所以就涉及到很多的关于scrollview,所以也就有了这篇文章 - (void)view ...
- UIPageControl简单使用
1.添加一个UIPageControl到view中 -(void)addPageControl { UIPageControl* page=[[UIPageControl alloc]init]; p ...
- UI:UIScrollView、UIPageControl
一.UIScrollView的常⽤用属性 二.UIScrollView的常⽤用代理方法 三.UIPageControl的使⽤用 四.UIPageControl与UIScrollView的结合使⽤用 U ...
- IOS-UIScrollView实现图片分页
1.设置可以分页 _scrollView.pagingEnabled = YES; 2.添加PageControl UIPageControl *pageControl = [[UIPageContr ...
- 使用UIPageControl UIScrollView制作APP引导界面
1. 新建两个视图控制器类(继承自UIViewController), 在AppDelegate.m中指定根视图控制器 #import "AppDelegate.h" #impor ...
- 利用UIScrollView和UIPageControl实现多页图片欢迎页面
在.h文件当中实现UIScrollViewDelegate协议,让控制器充当代理: #import <UIKit/UIKit.h> @interface RPRootViewControl ...
- UIScrollView 和 UIPageControl
UIScrollView [滚动视图]非常重要 UIScrollView是滚动视图,是其它带有滚动功能视图的父类, 本身不显示或者只显示背景,主要负责子视图的滚动和翻页. 一.常用属性 1.基本方法 ...
随机推荐
- vs2008编译FileZilla服务端源码
vs2008编译FileZilla服务端源码 FileZilla服务端下载地址:https://download.filezilla-project.org/server/.FileZilla服务端源 ...
- HDU - 3966 Aragorn's Story(树链剖分入门+线段树)
HDU - 3966 Aragorn's Story Time Limit: 3000MS Memory Limit: 32768KB 64bit IO Format: %I64d & ...
- java 方法学习
手写随机代码 public class suiji{private static final int N = 200;private static final int LEFT = 40;privat ...
- javaWEB总结(11):JSP简介及原理
前言 本文主要通过一个简单小例子,介绍JSP的原理. 1.项目结构 2.web.xml <?xml version="1.0" encoding="UTF-8&qu ...
- MySQL5.5.28启动错误 The server quit without updating PID file
今天重新安装了一次 MySQL5.5.28 ,但启动的时候老是报错 Starting MySQL.. ERROR! The server quit without updating PID file ...
- HDU 5831 Rikka with Parenthesis II
如果左括号数量和右括号数量不等,输出No 进行一次匹配,看匹配完之后栈中还有多少元素: 如果n=2,并且栈中无元素,说明是()的情况,输出No 如果n=2,并且栈中有元素,说明是)(的情况,输出Yes ...
- scp免密码传送文件
一.单向 ssh-keygen -t rsa 单向无密码访问远程服务器操作比较简单,比如服务器A需要无密码访问服务器B(A–>B),那么只需要在服务器A生成密钥对,将生成的公钥上传到服务器B的相 ...
- linux搭建phantomjs+webdriver+testng+ant自动化工程
因为项目的原因,需要将脚本在linux环境无浏览器化去跑,那么原有的在windows系统下有浏览器化的自动化脚本场景就不适用了,这里给出linux系统下搭建phantomjs+webdriver+te ...
- Google科学家前腾讯副总裁吴军将出席第二届万物互联创新大会
当越来越多的科技产品注入互联网的基因,"万物互联"的模式悄然兴起.第二届万物互联创新大会(B12大会)将于2016-11-13日在杭州市余杭区隆重召开.Google科学家前腾讯副总 ...
- 2016腾讯we大会的时间——2016年11月6日
作为腾讯公司主办的一场国际化创新盛会,WE大会由腾讯公司自2013年以来每年举办,WE大会已迎来第四年,每年大会都会邀请全球互联网思想家.前沿创新团队来进行现场演讲和分享,分享最前沿的思想和技术,创造 ...