Can someone explain to me what the contentInset property in a UIScrollView
instance is used for? And maybe provide an example?
标签:
uiscrollview
相关问题
- Scroll view scrolling up & down on button click [d
- Xamarin Forms : How to fix Activity Indicator in C
- UIScrollView do not scroll
- Nested Scroll. Auto scroll one after another has r
- UIScrollView w/ Large CATiledLayer + Overlay that
相关文章
- UITableView dragging distance with UIRefreshContro
- Programmatically Control UIScrollView
- Zooming within Nested UIScrollViews
- animation with infinite scrollView
- Detect touch position on UiScrollView
- ModalViewController doesn't display during ani
- Make a deep copy of a UIView and all its subviews
- Resizing behavior of UIPopoverController differs b
Great question.
Consider the following example (
scroller
is a UIScrollView):The insets are the ONLY way to force your scroller to have a "window" on the content where you want it. I'm still messing with this sample code, but the idea is there: use the insets to get a "window" on your
UIScrollView
.It's used to add padding in
UIScrollView
Without
contentInset
, a table view is like this:Then set
contentInset
:The effect is as below:
Seems to be better, right?
And I write a blog to study the
contentInset
, criticism is welcome.It sets the distance of the inset between the content view and the enclosing scroll view.
aScrollView.contentInset = UIEdgeInsetsMake(0, 0, 0, 7.0);
Here's a good iOS Reference Library article on scroll views that has an informative screenshot (fig 1-3) - I'll replicate it via text here:
The scroll view encloses the content view plus whatever padding is provided by the specified content insets.
While jball's answer is an excellent description of content insets, it doesn't answer the question of when to use it. I'll borrow from his diagrams:
That's what you get when you do it, but the usefulness of it only shows when you scroll:
That top row of content will still be visible because it's still inside the frame of the scroll view. One way to think of the top offset is "how much to shift the content down the scroll view when we're scrolled all the way to the top"
To see a place where this is actually used, look at the build-in Photos app on the iphone. The Navigation bar and status bar are transparent, and the contents of the scroll view are visible underneath. That's because the scroll view's frame extends out that far. But if it wasn't for the content inset, you would never be able to have the top of the content clear that transparent navigation bar when you go all the way to the top.
Content insets solve the problem of having content that goes underneath other parts of the User Interface and yet still remains reachable using scroll bars. In other words, the purpose of the Content Inset is to make the interaction area smaller than its actual area.
Consider the case where we have three logical areas of the screen:
and we want the TEXT to never appear transparently underneath the TOP BUTTONS, but we want the Text to appear underneath the BOTTOM TAB BAR and yet still allow scrolling so we could update the text sitting transparently under the BOTTOM TAB BAR.
Then we would set the top origin to be below the TOP BUTTONS, and the height to include the bottom of BOTTOM TAB BAR. To gain access to the Text sitting underneath the BOTTOM TAB BAR content we would set the bottom inset to be the height of the BOTTOM TAB BAR.
Without the inset, the scroller would not let you scroll up the content enough to type into it. With the inset, it is as if the content had extra "BLANK CONTENT" the size of the content inset. Blank text has been "inset" into the real "content" -- that's how I remember the concept.