Skip to content

Latest commit

 

History

History
234 lines (191 loc) · 12.7 KB

README.md

File metadata and controls

234 lines (191 loc) · 12.7 KB

AC3.2 Stackview and Scrollview: Part II


Readings

  1. UIStackView - Apple
  2. AutoLayout Guide: Stack Views - Apple
  3. Into to Stack Views in iOS 9 - App Coda
  4. UIStackView by Example - Hacking With Swift
  5. Views with Intrinsic Content Size - Apple

References

  1. UIViewContentMode - Apple

Vocabulary

  1. Adaptive Design: having your app resize its UI and content such that it looks good on any sized screen (Apple)
  2. Aspect Ratio: The proportional relationship between its width and its height. It is commonly expressed as two numbers separated by a colon, as in 16:9. (Wiki
  3. Intrinsic Content Size: certain UI elements have a defined size that's determined by their current content. For example. a UIButton has an intrinsic size based on the size of the text of the button (it ends up being the size of the text + margins). (Apple)

0. Objectives

  1. Exploring the UIStackView UI element for quickly aligning rows and/or columns of known content
  2. Further reinforcing the use of UIScrollView to display large amounts of content in a limited space
  3. Practicing layout with a storyboard

1. Intro

Hopefully, the previous lesson exercises have shown you that it isn't an entirely trivial task to work with scroll views. And yet, they're everywhere. A lot of this effort needed is mitigated by using UITableView and UICollectionView to neatly arrange elements, but sometimes it doesn't make sense to implement either of those for very simple setups that require some degree of dynamic sizing and updating.

That's one of the reasons Apple introduced the UIStackView: to streamline the vertical and horizontal layouts of a known number of views. It handles a good portion of autolayout for you, which allows you to create a UI that adapts to screen size and layout changes much more easily than if you were coding a UIScrollView. Note however, UIStackView doesn't handle all of the autolayout which is why it's still critical knowledge (and when we get into programmatic autolayout later in the course, this will be even further emphasized). A deep understanding of autolayout and stack views will allow you to create some pretty impressive and responsive designs without much work.

Let's start simple though: We're going to take a basic look at a stack view to create a horizontally scrolling row of Pokémon icons.


2. PokéStack

Today's lesson is going to focus on implementing a simple, horizontally scrolling stack view. We're going to take a look at how to embed elements into a stack view, along with some of the options we have for configuring how elements will be laid out once they are embedded in the stack view.

  1. Drag in a new UIViewController into Main.storyboard and set it to be the initial view controller
  2. With the view controller selected, go into Editor > Embed In > Tab Bar
  3. Drag in four UIImageView and set their images to the four starter Pokémon. For the unfamiliar, they are: Pikachu, Squirtle, Bulbasaur and Charmander.
  4. By default, images added will have their contentMode set to Aspect Fill. Aspect Fill will attempt to fill the bounds of the view while preserving the aspect ratio of the content. Two other common options are scale fill which will attempt to fill the bounds of the view stretching content if needed, and aspect fit which will size the content to fit within the bounds of the view while preserving aspect ratio. See the table below for further explanation (and feel free to play around with the other content modes to get a sense for each of them):
Image Views Scale Fill Aspect Fill Aspect Fit
Center Aligning ImageViews Scale to Fill Aspect Fill Aspect Fit
Default image views in Interface Builder Scale to Fill: Tries to fill the bounds of the view, stretching content if necessary. Aspect Fill: Tries to fill the bounds of the view based on the larger dimension (width or height). Keeps aspect ratio of the content. Aspect Fit: Fits the content to within the bounds of the view, preserving aspect ratio.
  1. When dealing with images, we're usually most concerned about preserving aspect ratio (so that the image doesn't appear distorted). Change the image content mode to Aspect Fit. Also, set the background color of the image views so that we can better see the bounds of the view.
Aspect Fit, Bkdg Color Util Panel, Content Mode
Aspect Fitted with background color Utilities Panel, Selecting Content Mode
  1. Now that we have the four imageviews set up we can add them to a stack view. There are a couples of ways to add a stack view in storyboard:
    • You can drag in either a Horizontal Stack View or Vertical Stack View from the Object Library in the right pane
    • You can select the views you'd like to place in a stack view, and then go to Editor > Embed In > Stack View
    • Or, you can select the views and click on the Stack button, conveniently located next to the Align, Pin and Resolve AutoLayout Issues buttons on the bottom right corner of Interface Builder.
    • Convenient Embedding Stack Button
  2. There are three main configuration options needed to consider for a stack view (see UIStackView documentation under "Managing the Stack View's Apperance")
    • Axis - the orientation of the stack, vertical or horizontal
    • Alignment - the layout of the arranged views perpendicular to the stack’s axis
    • Distribution - the layout of the arranged views along the stack’s axis

Developer's Note: Once again, it's encouraged that you try out variations of each of these properties to get a sense for what each is accomplishing. Visual changes made by each of these properties is best understood having used them for a while.

You may have already noticed how each of these options affects the contents of the stack view.

Vertical Align Center Horizontal Dist. Fill
Though one thing you might not immediately realize is that the four icons have a maximum height and width of 128pt. But each one has a width or height slightly smaller than 128pt. For example, the image of Squirtle is slightly narrower than the other icons. You can observe this by switching the alignment of the stack view to be center instead of fill.
Alternatively, you could switch axis to horizontal and set distribution to fill
Slightly narrow icons Slightly narrower Squirtle
Using the slight differences in the width and height of the images, these icons are a good way to visually identify how the options of a stack view affects its content. Now, let's make our images look uniform in size by using:
  • Axis = Horizontal
  • Alignment = Fill
  • Distribution = Fill Equally
Fill Equally
  1. Lastly, pin the stackview to the top-left of the screen with the following constraints:
    • 8pt left and top relative to margins
  2. Run the project... Ah.. bummer. I guess we'll need a scroll view
    • Needs scrolling!
  3. Selecting the stack view, go to Editor > Embed In > Scroll View
  4. For the scroll view, you'll need the following constraints:
    • Pin to top, left and right edges of its super view
  5. For the stack view:
    • remove the two constraints we just set on the stack view (left and top pins)
    • Add 8pt top, left, right, bottom, relative to margins
    • And add Center Vertically In Container
  6. Run the project.

What's nice about using the image views (along with the stack view) is that they define their own intrinsic content size. So we have far fewer constraints needed to satisfy autolayout.

Horiz Scroll PokéStack Small Set of Constraints Needed

3. Exercises

Note: There are no tests for these exercises Note: Please use the existing project for these exercises; add new UIViewController to the storyboard and link them to the existing UITabBarController

  1. Continue on and create 2 more horizontally scrolling stack views using the other two pokemon asset categories in Assets.xcassets ("Common Pokemon" and "Uncommon Pokemon")
    • Add a label just above each stack view with that group's category ("Starter Pokemon", "Common Pokemon", Uncommon Pokemon")
    • Select the 3 stack views and 3 labels and embed them in a vertical stack view
    • Now, with that vertical stack view selected, embed everything in a vertical-only scroll view.

Here's what your finished product should look like:

Exercise 1: Running in Sim Execise 1: Expanded View
Exercise 1: Running in Sim Execise 1: Expanded View

  1. Create two vertical stack views each embedded in their own vertically-scrolling, scroll view.
    • Each scroll view should be 1/2 the width of the screen, and have its edges pinned to the edges of the view and each other (trailing edge of scroll view 1 is pinned to leading edge of scroll view 2)
    • Add at least 6 UIImageView or UIView to each stack view to ensure you are able to demonstrate some scrolling
    • Make sure that the images are all the same dimensions, aligned properly, and set to aspect fit. They should all be equally distant from each other as well.

When complete, you should have something similar to:

Exercise 2 - Sim Exercise 2 - Expanded
Exercise 2 - In Sim Exercise 2 - View Hierarchy

Advanced

If you have time and are interested, take a look at the AutoLayout Guide: Stack Views link. Experiment with different layouts and see what you can create. Just be sure that your storyboard doesn't list any warnings or errors.

Whatever you end up creating, share with the rest of the cohort and explain the trickier parts of your design.