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.基本方法 ...
随机推荐
- chrome devtools
Elements chrome devtools 中 Elements panel 是审查 dom 元素和 css 的, 可以实时修改 dom/css. windows: ctrl + shift + ...
- selenium+python在Windows的环境搭建
1 python下载安装 python早已安装,不再多说.因为开发使用的python2.7,所以同样使用2.7 2 打开Powershell, 输入python -m pip install sele ...
- 理解iaas paas saas三种云服务区别
其实搞懂这个问题也不难,我们可以把云计算理解成一栋大楼,而这栋楼又可以分为顶楼.中间.低层三大块.那么我们就可以把Iass(基础设施).Pass(平台).Sass(软件)理解成这栋楼的三部分.基础设施 ...
- hive-1.2.1安装步骤
一.Hive安装和配置 1.先决条件 已经安装好hadoop-2.4.1,hbase-1.0.0. 2.下载Hive安装包 当前Hive可到apache官网下载,选择的是hive-1.2.1.运行: ...
- ZZNU 1995: cots' times
题目描述 XX年XX月XX日小cot学会了回文数,eg:121. 小cot上课容易走神, 经常看看这个,瞧瞧那个.在小cot某一次走神的过程中他发现电子表上的时间也有回文数... 当然,并不是每次走神 ...
- 自定义按钮~自适应布局~常见bug
一.元件 自定义按钮可用button或a display为 inline-block 方便设置格式,通过 padding,height,line-height,font-size设置按钮的大小 & ...
- 《Windows编程循序渐进》——进度条
界面布局如下:
- 【🉐】 彻底理解webservice SOAP WSDL
原文: http://wenku.baidu.com/view/f87b55f19e31433239689314.html WebServices简介 先给出一个概念 SOA ,即Service Or ...
- C++ 内存分析-valgrind
valgrind包括了以下几个比较重要的模块:memcheck, cachegrind, callgrind, helgrind, drd, massif, dhat, sgcheck, bbv. 还 ...
- 测试word 2013发布blog
测试图片和各种格式 使用Windows Live Writer 2012和Office Word 2013 发布文章到博客园全面总结 (亲测可用) 我的一些感受: 缺点 (1) Word201 ...