##DAY6 UIScrollView
##DAY6 UIScrollView
#pragma mark ———————UIScrollView———————————
属性:
contentSize 内容滚动范围
contentOffset 滚动视图的偏移量,如果不设置,默认开始是偏移(0,0)
contentInset 设置保留区域,在动态效果结束后,会在开头或结尾保留以下设置的值,UIEdgeInsetsMake(60, 0, 80, 0)
bounces 关闭滚动视图的回弹效果,默认开启
pagingEnabled 设置整页滚动,分页属性,是按照UIScrollView的frame的宽度分页的。
scrollEnabled 设置是否能滚动,默认YES
showsHorizontalScrollIndicator 关闭横向显示条
showsVerticalScrollIndicator 关闭竖向滚动条
tag tag值
delegate 设置滚动视图的代理
/*
如果想实现滚动视图的缩放功能,必须指定缩放的视图以及缩放的比例
指定缩放视图需要实现的代理方法,指定缩放比例,是为滚动设置缩放比例
*/
minimumZoomScale 最小缩放比例
maximumZoomScale 最大缩放比例
zoomScale 当前比例
代理中监控滚动的方法:
//滚动过程中触发的方法
scrollViewDidScroll:
//即将开始进行拖拽,此时的滚动视图即将加速
scrollViewWillBeginDragging:
//结束拖拽的方法,不再进行加速
scrollViewDidEndDragging:willDecelerate:
//即将开始减速
scrollViewWillBeginDecelerating:
//结束减速,停止滚动
scrollViewDidEndDecelerating:
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
NSLog(@"结束减速");
// 先从负责滚动的⼤scrollView找到他的⼦视图
for (UIScrollView *sView in scrollView.subviews){
// 在根据⼦类的对象类型进⾏判断
if ([sView isKindOfClass:[UIScrollView class]]){
// 把视图的尺⼨恢复到原有尺⼨
sView.zoomScale = 1.0;
}
}
}
代理中监控视图缩放的方法:
//指定缩放视图
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{
return [scrollView.subviews firstObject];
//scrollView上还有两个子视图,横向指示器和纵向指示器
}
//结束缩放
- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)scale{
NSLog(@"%@",NSStringFromCGSize(scrollView.contentSize));
}
- (void)scrollViewDidZoom:(UIScrollView *)scrollView{
UIImageView *imageView = [scrollView.subviews firstObject];
if (scrollView.zoomBouncing <= 1.0) {
imageView.center = CGPointMake(kWidth / 2, kHeight / 2);
}
}
#pragma mark -----pageControl与scrollView关联的方法,两个都要写----------
#pragma mark -----scrollView的方法----------
//在滚动视图停止滚动时,改变pageControl上面点的位置
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
//获取滚动视图当前偏移量
CGPoint offset = scrollView.contentOffset;
//计算偏移量与屏幕宽度的关系,也就是偏移了多少倍
NSInteger page = offset.x / kWidth;
//赋值
self.pageControl.currentPage = page - 1 < 0 ? 9 : page - 1;
}
#pragma mark -----pageControl的触发事件的方法----------
- (void)click:(UIPageControl *)page{
self.scrollView.contentOffset = CGPointMake(kWidth * (page.currentPage + 1), 0);
}
##DAY6 UIScrollView的更多相关文章
- 【原】Masonry+UIScrollView的使用注意事项
[原]Masonry+UIScrollView的使用注意事项 本文转载请注明出处 —— polobymulberry-博客园 1.问题描述 我想实现的使用在一个UIScrollView依次添加三个UI ...
- UIScrollView的封装
UIScrollView的封装 效果 特点 1.用法简单,尺寸大小,随意设置位置 2.可以有多个数据源的数据,可以定制不通的界面(如同上图,一个有文字,一个没有文字) 3.能够实现点击事件 用法 1. ...
- UI第十七节——UIScrollView
// 实例化一个ScrollView UIScrollView *scrollView = [[UIScrollView alloc] initWithFrame:[[UIScreen main ...
- Python之路,Day6 - Python基础6
本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...
- day6
开发一个简单的python计算器 实现加减乘除及拓号优先级解析 用户输入 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568 ...
- UI控件(UIScrollView)
@implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; //创建一个scrollview UIScrollV ...
- UIScrollView的delaysContentTouches与canCencelContentTouches属性
UIScrollView有一个BOOL类型的tracking属性,用来返回用户是否已经触及内容并打算开始滚动,我们从这个属性开始探究UIScrollView的工作原理: 当手指触摸到UIScrollV ...
- iOS 视图:重绘与UIScrollView(内容根据iOS编程编写)
我们继续之前的 Hypnosister 应用,当用户开始触摸的时候,圆形的颜色会改变. 首先,在 JXHypnosisView 头文件中声明一个属性,用来表示圆形的颜色. #import " ...
- 学习笔记之-------UIScrollView 基本用法 代理使用
//contentSize.contentInset和contentOffset 是 scrollView三个基本的属性. // 滚动 self.ScrollView.contentSize =sel ...
随机推荐
- (6)Xamarin.android google map v2
原文 Xamarin.android google map v2 Google Map v1已经在2013年的3月开始停止支持了,目前若要在你的Android手机上使用到Google Map,就必须要 ...
- c# webBrowser 获取Ajax信息 .
c#中 webbrowser控件对Ajax的执行,没有任何的响应,难于判断Ajax是否已经执行完毕,我GG了一下午,找到一个方法,介绍一下: 假如在页面中有个<div id=result> ...
- mybatis.generator.configurationFile
mybatis.generator.configurationFile 有一个更好的配置方法,可以不用在generateConfig.xml里面写死驱动的地址:如果你的mybatis连接也是在pom. ...
- perl 跨行匹配;
<pre name="code" class="html"><pre name="code" class="ht ...
- Dot模板的使用小结2
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Android 常用开发类库
android.app :提供高层的程序模型.提供基本的运行环境 android.content :包含各种的对设备上的数据进行访问和发布的类 android.database :通过内容 ...
- CSS:margin负数的使用
给所有div加上边框=10px之后,再给所有div设置margin-left与margin-top;以及浮动(float:left) 因此时需要鼠标悬停效果:所以设置给div设置伪类:hover,然因 ...
- 软件介绍:搜索工具 Listary
如今的互联网时代,搜索的重要性我想大家都是认可的.网上的知识浩如烟海,而搜索引擎是通向这些知识的入口.谷歌.百度等搜索引擎给我们带来了极大的便利,也无怪他们成长为如今的互联网巨头. 然而储存在个人硬件 ...
- <转>ASP.NET学习笔记之在ASP.NET MVC中使用DropDownList
看到一篇关于dropdownlist的用法很好的阐述,比较清楚,留着,防止以后自己不记得,还可以瞅瞅. 在ASP.NET MVC中,尽管我们可以直接在页面中编写HTML控件,并绑定控件的属性,但更方便 ...
- iOS 模态视图转场的动画效果
ModalViewController * modalView = [[ModalViewController alloc]init]; modalView.modalTransitionStyle ...