• UIScrollView的属性总结


    contentSize是scrollview可以滚动的区域,比如frame = (0 ,0 ,320 ,480) contentSize = (320 ,960),代表你的scrollview可以上下滚动,滚动区域为frame大小的两倍。

     

    contentOffset是scrollview当前显示区域顶点相对于frame顶点的偏移量,比如上个例子你拉到最下面,contentoffset就是(0 ,480),也就是y偏移了480

     

    contentInset是scrollview的contentview的顶点相对于scrollview的位置,例如你的contentInset = (0 ,100),那么你的contentview就是从scrollview的(0 ,100)开始显示

     

     

    另外UITableView是UIScrollView的子类,它们在上述属性又有所不同,tabelview的contentsize是由它的下列方法共同实现的

    - (NSInteger)numberOfSections;

    - (NSInteger)numberOfRowsInSection:(NSInteger)section;

    - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;

    - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section;

    - (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section;

    它会自动计算所有的高度和来做为它的contentsize的height.

     

    例如你在delegate方法

    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

        return 100;

    }

    那么你的tabelview的contentsize就是(320, 4400)

    posted @ 2011-10-13 17:36 zcbbin 阅读(194) 评论(2) 编辑

    UIScrollView 原理

    UIScrollView 原理   

    scroll view 原理
    //作者:禚来强 iphone开发q*****:79190809 邮箱:zhuolaiqiang@gmail.com转帖请保留
    demo 可以到我的博客http://blog.csdn.net/diyagoanyhacker/article/list/10
    在滚动过程当中,其实是在修改原点坐标

    当手指触摸后, 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:
    两个方法,另外 maximumZoomScale和minimumZoomScale两个属性要不一样 

    几个属性
    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开始滚动
    假如值是NO,scrollView发送tracking events后,就算用户移动手指,scrollView也不会滚动

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

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

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

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

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

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

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

    scrollIndicatorInsets
    设置滚动条的位置

     

     

     

     

     

     

     

    属性

    作用

    CGPoint contentOffSet

    监控目前滚动的位置

    CGSize contentSize

    滚动范围的大小

    UIEdgeInsets contentInset

    视图在scrollView中的位置

    id<UIScrollerViewDelegate>
    delegate

    设置协议

    BOOL directionalLockEnabled

    指定控件是否只能在一个方向上滚动

    BOOL bounces

    控制控件遇到边框是否反弹

    BOOL alwaysBounceVertical

    控制垂直方向遇到边框是否反弹

    BOOL alwaysBounceHorizontal

    控制水平方向遇到边框是否反弹

    BOOL pagingEnabled

    控制控件是否整页翻动

    BOOL scrollEnabled

    控制控件是否能滚动

    BOOL showsHorizontalScrollIndicator

    控制是否显示水平方向的滚动条

    BOOL
    showsVerticalScrollIndicator

    控制是否显示垂直方向的滚动条

    UIEdgeInsets scrollIndicatorInsets

    指定滚动条在scrollerView中的位置

    UIScrollViewIndicatorStyle
    indicatorStyle

    设定滚动条的样式

    float decelerationRate

    改变scrollerView的减速点位置

    BOOL tracking

    监控当前目标是否正在被跟踪

    BOOL dragging

    监控当前目标是否正在被拖拽

    BOOL decelerating

    监控当前目标是否正在减速

    BOOL delaysContentTouches

    控制视图是否延时调用开始滚动的方法

    BOOL canCancelContentTouches

    控制控件是否接触取消touch的事件

    float minimumZoomScale

    缩小的最小比例

    float maximumZoomScale

    放大的最大比例

    float zoomScale

    设置变化比例

    BOOL bouncesZoom

    控制缩放的时候是否会反弹

    BOOL zooming

    判断控件的大小是否正在改变

    BOOL zoomBouncing

    判断是否正在进行缩放反弹

    BOOL scrollsToTop

    控制控件滚动到顶部

    1.开始滑动

    - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

    {

        NSLog(@"scrollViewWillBeginDragging");

    }

    2.将要结束滑动

    - (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inoutCGPoint *)targetContentOffsetNS_AVAILABLE_IOS(5_0)

    {

        NSLog(@"scrollViewWillEndDragging");

    }

    注意该方法常用在当用户滚动完屏幕时加载图片,HTTP请求加载,这样会提高效率

    3.已经结束滑动

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

    {

        NSLog(@"scrollViewDidEndDragging");

    }

    4.将要减速

    - (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView

    {

        NSLog(@"scrollViewWillBeginDecelerating");

    }

    5.已经减速

    - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView   // called when scroll view grinds to a halt

    {

        NSLog(@"scrollViewDidEndDecelerating");

    }

    6.已经停止滚动

    - (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView

    {

        NSLog(@"scrollViewDidEndScrollingAnimation");

    }

  • 相关阅读:
    一个有趣的.net程序死锁问题
    腾讯2013年实习生笔试题目(附答案)
    C#函数式程序设计初探基础理论篇
    IE的BUG?
    OpenPetra 以及CentOS Mono 3.0 部署包
    自己封装的内存缓存类DotNet.Caches.Bytecached
    Windows Azure Services安装及故障排查
    接口
    利用SQL Server的扩展属性自动生成数据字典
    CentOS配置ssh无密码登录的注意点
  • 原文地址:https://www.cnblogs.com/liangjialun219/p/3896617.html
Copyright © 2020-2023  润新知