UIScrollView 原理详解

摘要:
UIScrollView原理的详细说明解释了UITableView和UITextView是UIScrollView的子类。UITableViewController管理表视图。UIScrollView是一个类,用于管理它们之间的滚动、在地图上显示、放大和缩小等。当手指触摸时,滚动视图将暂时阻止触摸事件并使用计时器。如果移动事件发生在计时器到达之前,滚动视图将取消跟踪并自行滚动。Scrollview还处理缩放和平移手势。要实现缩放和平移,必须实现两种方法:delegate viewForZoomingInScrollView:和scrollViewDidEndZooming:withView:atScale:。如果该值为NO,即使用户在发送跟踪事件后移动手指,scrollView也不会滚动。

UIScrollView 原理详解

 

 

 語句解釋

UITableViewUITextViewUIScrollView的子类。

UITableViewControllerUIViewController的子类。

UITableViewController是管理表格视图的。

表格视图单元是你的UITableView用来在自身显示数据的UIView子类。

UIScrollView是用来管理在它们之间卷动的类,在地图上显示,放大缩小等。

ContentOffset是你当前可视内容在滚轴视图边界的左上角的那个点,它不是从ContentInsets的左上角开始,而是内容的左上角。

 

 

CGRecct frame=CGRectMake(0,0,200,200);   //创建框架

scrollView = [[UIScrollView  alloc] initWithFrame : frame ]; //把它加为我们视图的一个子视图,后把其它一些内容视图当作子视图添加给它

 

 

添加子视图subviews

ScollView中添加左右移动的UIImageView

frame=CGRectMake(0,0,500,500);   //比可见视图大,当左右移动时隔不久不同部分会移动进来

myImageView = [[UIImageView  alloc] initWithFrame : frame ];

[scrollView  addSubview : myImageView];

 

 

Set the content size

scrollView.contentSize= CGSizeMake(500,500);

 

 

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

它在每次滚轴视图的ContentOffset改变时都会被调用,当用户在四周移动手指时也会一直被调用

 

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

响应事件的一个例子

scroll view 原理

 

http://www.cocoachina.com/bbs/read.php?tid-40965-page-1.html

    在滚动过程当中,其实是在修改原点坐标。当手指触摸后, scroll view会暂时拦截触摸事件,使用一个计时器。假如在计时器到点后没有发生手指移动事件,那么 scroll view 发送 tracking events 到被点击的 subview。假如在计时器到点前发生了移动事件,那么 scroll view 取消 tracking 自己发生滚动。

    子类可以重载

touchesShouldBegin:withEvent:inContentView: 决定自己是否接收 touch 事件
pagingEnabled:当值是 YES 会自动滚动到 subview 的边界,默认是NO
touchesShouldCancelInContentView: 开始发送 tracking messages 消息给 subview 的时候调用这个方法,决定是否发送 tracking messages 消息到subview。假如返回 NO,发送。YES 则不发送。
假如 canCancelContentTouches属性是NO,则不调用这个方法来影响如何处理滚动手势。

    scroll view 还处理缩放和平移手势,要实现缩放和平移,必须实现委托 viewForZoomingInScrollView:scrollViewDidEndZooming:withView:atScale:
两个方法。另外 maximumZoomScaleminimumZoomScale 两个属性要不一样。

几个属性介绍

tracking
touch 后还没有拖动的时候值是YES,否则NO

zoomBouncing
当内容放大到最大或者最小的时候值是 YES,否则 NO

zooming
当正在缩放的时候值是 YES,否则 NO

decelerating
当滚动后,手指放开但是还在继续滚动中。这个时候是 YES,其它时候是 NO

decelerationRate
设置手指放开后的减速率

maximumZoomScale
一个浮点数,表示能放最大的倍数

minimumZoomScale
一个浮点数,表示能缩最小的倍数

pagingEnabled
当值是 YES 会自动滚动到 subview 的边界。默认是NO

scrollEnabled
决定是否可以滚动

delaysContentTouches
是个布尔值,当值是 YES 的时候,用户触碰开始,scroll view要延迟一会,看看是否用户有意图滚动。假如滚动了,那么捕捉 touch-down 事件,否则就不捕捉。假如值是NO,当用户触碰, scroll view 会立即触发 touchesShouldBegin:withEvent:inContentView:,默认是 YES

canCancelContentTouches
当值是YES 的时候,用户触碰后,然后在一定时间内没有移动,scrollView 发送 tracking events,然后用户移动手指足够长度触发滚动事件,这个时候,scrollView 发送了 touchesCancelled:withEvent: subview,然后 scroView 开始滚动。假如值是 NOscrollView 发送 tracking events 后,就算用户移动手指,scrollView 也不会滚动。

contentSize
里面内容的大小,也就是可以滚动的大小,默认是0,没有滚动效果。

showsHorizontalScrollIndicator
滚动时是否显示水平滚动条

showsVerticalScrollIndicator
滚动时是否显示垂直滚动条

bounces
默认是 yes,就是滚动超过边界会反弹有反弹回来的效果。假如是 NO,那么滚动到达边界会立刻停止。

bouncesZoom
bounces 类似,区别在于:这个效果反映在缩放上面,假如缩放超过最大缩放,那么会反弹效果;假如是 NO,则到达最大或者最小的时候立即停止。

directionalLockEnabled
默认是 NO,可以在垂直和水平方向同时运动。当值是 YES 时,假如一开始是垂直或者是水平运动,那么接下来会锁定另外一个方向的滚动。假如一开始是对角方向滚动,则不会禁止某个方向

indicatorStyle
滚动条的样式,基本只是设置颜色。总共3个颜色:默认、黑、白

scrollIndicatorInsets
设置滚动条的位置

 

 

免责声明:文章转载自《UIScrollView 原理详解》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇MySQL复合主键下ON DUPLICATE KEY UPDATE语句失效问题1. python跨目录调用模块下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

【vue】在移动端使用better-scroll 实现滚动效果

  安装依赖:(c)npm install better-scroll --save 引入:  import BScroll from 'better-scroll' 格式:  var obj = new BScroll(object,{[option1,],.,.}); 注意: 1、要确保object元素的高度比其父元素高 2、使用时,一定要确保obje...

DIV Scroll属性

DIV Scroll属性详解,为DIV层打造不同的滚动条。 一、scrollbar属性、样式详解1.overflow内容溢出时的设置(设定被设定对象是否显示滚动条) overflow-x水平方向内容溢出时的设置 overflow-y垂直方向内容溢出时的设置 以上三个属性设置的值为visible(默认值)、scroll(出现滚动条)、hidden(隐藏)、a...

【无限滚动加载数据】—infinite-scroll插件的使用

网上对于infinite-scroll插件使用的例子不多。但由于它的出现,鼓吹了瀑布流形式的页面展示方式,所以不得不了解了解这种新的分页方式。 官网上有对infinite-scroll的详细描述,但一般人即使看未必看得懂,看得懂未必就调试成功。所以借今晚有点时间,把跑通的例子供大家借鉴。 一.无限滚动概念 首先,它是基于Jquery的,另外还要明白无限...

ES分页

本篇文章将会讲解ES两种分页查询方法以及优缺点 注意:以下文章中的命令和java代码均基于ES5.3.0版本 一、from/size分页 官网文档地址:https://www.elastic.co/guide/en/elasticsearch/reference/5.3/search-request-from-size.html 查询的时候带上from和s...

黑马IOS学习笔记

1、模拟器返回Home键的快捷方式是 shift+命令键+H 2、UIButtonTypeRoundedRect 这个在IOS7里面是不再支持了的。因为IOS7扁平化设计,这个是在IOS6下面的。 3、viewWithTag 若有多个子控件view的tag值相同,则是按照添加的顺序来找的。而且用这个取view还有一个强转问题,因为viewWithTag返回...

scroll事件总结

一般监听窗口的滚动事件都是给window,document,body绑定滚动事件。但是需要注意以下几点: (1)给body绑定scroll事件时,this指向window (2)不管给谁绑定,要获取scrollTop值都是通过document.body来获取。即document.body.scrollTop.window和document是没有scroll...