iOS 如何计算滚动条的拇指位置和范围?
最近我比较了 Android 和 iOS 之间滚动条中拇指的行为。我发现以下内容:
- 有两种类型可以计算 Android 中拇指的偏移量和范围(由 android:smoothScrollbar 属性或 setSmoothScrollbarEnabled 方法)。
- 如果
smoothScrollbar
为false
,则滚动时拇指看起来不连续。 - 如果
smoothScrollbar
为true
,则拇指看起来很平滑,但如果项目的高度不同,则滚动时其范围会有所不同。 - 不过,iOS 中的拇指要好得多。看起来相当光滑,程度也没有变化。
在Android中,计算偏移量和范围的方法可以在 AbsListView 中找到
。但是,我不知道这些值在 iOS 中是如何计算的。有人可以帮忙吗?
Recently I compared the behavior of the thumb in a scrollbar between Android and iOS. I found the following:
- There are two types to compute the thumb's offset and extent in Android (controlled by android:smoothScrollbar attribute or setSmoothScrollbarEnabled method).
- If
smoothScrollbar
isfalse
, the thumb looks discontinuous when scrolling. - If
smoothScrollbar
istrue
, the thumb looks smooth, but it's extent varies when scrolling if the items' height are different. - However, the thumb in iOS is much better. It looks quite smooth, and the extent does not change.
In Android, the method to compute the offset and extent could be found in AbsListView
. However, I do not know how those values are compited in iOS. Can anyone help?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
对于内容偏移,请使用
self.scrollView.contentOffset
。对于框架值(包括宽度),请使用 self.scrollView.frame.size.(<>); [宽度,高度],
self.scrollview.bounds;
或self.scrollview.frame.origin.(<>); [x,y]
。如果您想收到滚动事件的通知,请成为滚动视图的委托。
编辑
以下是委托方法:
响应滚动和拖动
管理缩放
响应滚动动画
For content offset, use
self.scrollView.contentOffset
.For frame values (including width), use
self.scrollView.frame.size.(<>); [width, height]
,self.scrollview.bounds;
orself.scrollview.frame.origin.(<>); [x,y]
.If you want to be notified of scroll events, become the scrollview's delegate.
EDIT
Here are the delegate methods:
Responding to Scrolling and Dragging
Managing Zooming
Responding to Scrolling Animations