前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >NSScrollView官方文档

NSScrollView官方文档

作者头像
nimomeng
发布2018-09-13 14:20:28
2.8K0
发布2018-09-13 14:20:28
举报
文章被收录于专栏:nimomeng的自我进阶
  • 改变contentInset值会有一个不可预料的副作用,尤其是当你显示滚动条的时候。当用户拖拽内容到顶部或者底部,滚动条会越过任何被定义在contentInset的区域之内的范伟,例如navigation controller和toolbar。
    • 想要修正这个问题,你必须设置scrollIndicatorInsets属性。设置vertical inset值限制了垂直滚动条,避免了越区域显示滚动条的问题。 滚动到特定的Offset:滚动到特定的top-left位置可以通过两种方式完成:
    • setContentOffset:animated:方法,滚动内容到特定的content offset。 也可以通过滚动到一个固定的可见的矩形区域来完成。这个在一个app需要显示一个contorl,恰好这个control在实现之外的时候格外有用。
    • scrollRectToVisible:animated:方法滚动到特殊的矩形区域,以确保区域在可视范围之内。
  • 如何在scrollView内容不够的时候也可以进行拉伸:通过设置弹跳属性。Bouncing只有在bounces属性为YES时(默认值)才可以使用。如果bounces为NO,则alwasyBounceVertical和alwaysBounceHorizontal属性不可用。如果bounces为YES,即便contentSize比scrollView bounds小也可以弹跳。
  • 为了支持zooming,你必须设置scrollView的delegate,且要实现UIScrollViewDelegate协议。大多数情况,这个delegate是scrollView的controller的class。那个delegate class必须实现viewForZoomingInScrollView方法并且返回要zoom的view。
  • 为了控制用户可以zoom的范围,你需要setminimumZoomScale值和maximumZoomScale值,他们初始都被设置为1.0.
  • 如何确保内容在zoom时是锐利的:如果zoom的内容是实时的,并且需要在zoom时是锐利的,那么你的app的类需要用Core Animation来绘制。Class需要改变Core Animation的class,就像UIView的class layer对于CATtiledLayer并且用CA的drawLayer:inContext:方法来绘制。
  • 请注意,这种绘画方法有一个重要的限制,UIKit绘制方法不是线程安全的,并且drawLayer:inRect:会在后台线程回调,因此你必须使用CoreGraphics绘制函数替代UIKit 绘制函数。 想使用Paging Mode,你需要设置pagingMode属性为YES。
  • 配置Paging Scroll View的子view:有两个方法:
    • 如果content很小,你应当一次性draw全部内容,在一个单独的view上就是scroll view的contentSize。这个很容易实现,但是当处理很大的content 区域时效率很低,或者page content需要时间去绘制;
    • 当你的app需要显示很多pages或者绘制page内容会很耗时,你的app应当使用多页面去绘制content,每一个页面属于一个page。PageContrl就是使用这种方法来实现的。可以采用三个view实例,一个显示当前page,一个显示之前的page,一个显示之后的page。这些views在滚动过程中被复用。
  • 如何来判断page需要重新绘制,scrollView需要一个delegate实现scrollViewDidScroll方法。这个实现应当去记录contentOffset,并且当它传中点值(宽度的中点值),view应当进行重新渲染,将马上要消失的view移动到要渲染下一张page或者上一张page的地方去。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016.06.26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档