sábado, 21 de enero de 2012

Human Interface Principles for iOS part VI

iOS UI Element Usage Guidelines

In iOS, the UIKit framework provides a wide range of UI elements that you can use in your application. As you design the user interface of your app, always remember that users expect the standard views and controls to behave as they do in the built-in applications. This is to your advantage, as long as you use these elements appropriately in your application.
Another advantage of using standard UI elements is that they automatically receive updates if iOS introduces a redesigned appearance (completely custom elements do not receive updates). If you create custom UI elements to replicate standard UI elements in all but appearance, you should instead consider using the appearance customization programming interfaces available in iOS 5 and later. When you use these APIs, you can customize the appearance of most UI elements and still receive automatic appearance updates.

Bars

The status bar, navigation bar, tab bar, and toolbar are UI elements that have specifically defined appearances and behaviors in iOS applications. These bars are not required to be present in every application (apps that provide an immersive experience often don’t display any of them), but if they are present, it’s important to use them correctly. The bars provide familiar anchors to users of iOS-based devices, who are accustomed to the information they display and the types of functions they perform.

The Status Bar

The status bar displays important information about the device and the current environment.
image: ../Art/ui_statusbar.jpg
image: ../Art/ui_statusbar_ipad.jpg
The UIStatusBarStyle constant, described in UIApplication Class Reference, controls the status bar style. To specify the status bar style, you set a value in your Info.plist file. (For more information about the contents of this file.

Appearance and Behavior

The status bar always appears at the upper edge of the device screen (in all orientations) and contains information people need, such as the network connection, the time of day, and the battery charge.

On iPhone, the status bar can have different colors; on iPad, the status bar is always black.

Guidelines

Although you don’t use the status bar in the same way that you use other UI elements, it’s important to understand its function in your app.

Think twice before hiding the status bar if your application is not a game or full-screen media-viewing application. Although these apps might permanently hide the status bar, you should understand the ramifications of this design decision. Permanently hiding the status bar means that users must quit your app to find out, for example, whether they need to recharge their device.

Note that most iPad applications do not need to hide the status bar to gain extra space, because the status bar occupies such a small fraction of the screen. On iPad, the subtle appearance of the status bar does not compete with your application for the user’s attention. The small size of the status bar, combined with the slightly rounded corners of the application’s upper bar, make the status bar seem like part of the device background.

Consider hiding the status bar (and all other app UI) while people are actively viewing full-screen media. If you do this, be sure to allow people to retrieve the status bar (and appropriate application UI) with a single tap. Unless you have a very compelling reason to do so, it’s best to avoid defining a custom gesture to redisplay the status bar because users are unlikely to discover such a gesture or remember it.

Don’t create a custom status bar. Users depend on the consistency of the system-provided status bar. Although you might hide the status bar in your app, it’s not appropriate to create custom UI that takes its place.

When appropriate, display the network activity indicator. The network activity indicator can appear in the status bar to show users that lengthy network access is occurring. 

On iPhone, specify the color of the status bar. You can choose gray (the default color), opaque black, or translucent black (that is, black with an alpha value of 0.5).
image: ../Art/ui_statusbartypes.jpg
Be sure to choose a status bar appearance that coordinates with the rest of your iPhone application. For example, avoid using a translucent status bar if the navigation bar is opaque.

On iPhone, set whether the change in status bar color should be animated. Note that the animation causes the old status bar to slide up until it disappears off the screen while the new status bar slides into place.

Navigation Bar

A navigation bar enables navigation through an information hierarchy and, optionally, management of screen contents.
image: ../Art/ui_navbar.jpg
image: ../Art/ui_navbar_ipad.jpg
A navigation bar is contained in a navigation controller, which is an object that manages the display of your hierarchy of custom views. To learn more about defining a navigation bar in your code, see “Navigation Controllers” in View Programming Guide for iOS and UINavigationBar Class Reference.

Appearance and Behavior

A navigation bar appears at the upper edge of an application screen, just below the status bar. A navigation bar usually displays the title of the current screen or view, centered along its length. When navigating through a hierarchy of information, users tap the back button to the left of the title to return to the previous screen. Otherwise, users can tap content-specific controls in the navigation bar to manage the contents of the screen.

All controls in a navigation bar include a bezel around them, which, in iOS, is the bordered style. If you place a plain (borderless) control in a navigation bar, it automatically converts to the bordered style. 

A navigation bar can be translucent or opaque. If the bar is translucent, the top edge of the main content view meets the bottom edge of the status bar, so that users can see the content behind the navigation bar. If the bar is opaque, the top edge of the main content view meets the bottom edge of the navigation bar.

On iPhone, changing the device orientation from portrait to landscape can change the height of the navigation bar automatically. On iPad, the height and translucency of a navigation bar does not change with rotation.

On iPhone, a navigation bar always displays across the full width of the screen. On iPad, a navigation bar can display within a view, such as one pane of a split view, that does not extend across the screen.

Guidelines

You can use a navigation bar to enable navigation among different views, or provide controls that manage the items in a view.
Use the title of the current view as the title of the navigation bar. When the user navigates to a new level, two things should happen:
  • The bar title should change to the new level’s title.
  • A back button should appear to the left of the title, and it should be labeled with the previous level’s title.
Make sure it’s easy to read the text in the navigation bar. The system font provides maximum readability, but you can specify a different font, if appropriate.
Use a toolbar instead of a navigation bar if you need to offer a larger set of controls, or you do not need to enable navigation.
Consider putting a segmented control in a navigation bar at the top level of an application. This is especially useful if doing so helps to flatten your information hierarchy and makes it easier for people to find what they’re looking for. If you use a segmented control in a navigation bar, be sure to choose accurate back-button titles. 

Avoid crowding a navigation bar with additional controls, even if there appears to be enough space. The navigation bar should contain no more than a view’s current title, the back button, and one control that manages the view’s contents. If, instead, you use a segmented control in the navigation bar, the bar should not display a title and it should not contain any controls other than the segmented control.

Use system-provided buttons according to their documented meaning

If appropriate, customize the appearance of a navigation bar. If you want the navigation bar to coordinate with the overall look of your app, you can specify a custom appearance. For example, you can supply a custom background image or tint for the bar and you can specify translucency. In some cases, it can be a good idea to supply a resizable background image; to learn more about creating a resizable image.



Make sure that the look of your customized navigation bar is consistent with the look of the rest of your application. If you use a translucent navigation bar, for example, don’t combine it with an opaque toolbar. Also, it’s best to avoid changing the image, color, or translucency of the navigation bar in different screens in the same orientation.


If appropriate, customize the appearance of navigation-bar controls. In particular, if you supply a custom background appearance for the navigation bar, you should consider supplying a coordinating appearance for the bar controls.

Make sure that a customized back button still looks like a back button. Users know that the standard back button allows them to retrace their steps through a hierarchy of information. If, for example, you create a custom back button that doesn’t have a pointed side, users won’t instantly know what it does.

Don’t create a multisegment back button.
image: ../Art/ui_navbarmultisegment.jpg
Creating a multisegment back button (as in the example above) causes several problems:
  • The extended width of a multisegment back button does not leave room for the title of the current screen.
  • There is no way to program such a multisegment button to indicate the selected state of an individual segment.
  • The more segments there are, the smaller the hit region for each one, which makes it difficult for users to tap a specific one.
  • Choosing which levels to display as users navigate deeper in the hierarchy is problematic.
If you think users might get lost without a multisegment back button that displays a type of breadcrumb path, it probably means that users must go too deeply into the information hierarchy to find what they need. To address this, you should flatten your information hierarchy.
On iPhone, take into account the automatic change in navigation bar height that occurs on device rotation. In particular, make sure that your custom navigation bar icons fit well in the thinner bar that appears in landscape orientation. Don’t specify the height of a navigation bar programmatically; instead, you can take advantage of the UIBarMetrics constants to ensure that your content fits well.

Toolbar

A toolbar contains controls that perform actions related to objects in the screen or view.
image: ../Art/ui_taskstyleexample.jpg
image: ../Art/ui_toolbar_ipad.jpg
A toolbar is typically contained in a navigation controller, which is an object that manages the display of a hierarchy of custom views. 

Appearance and Behavior

On iPhone, a toolbar always appears at the bottom edge of a screen or view, but on iPad it can instead appear at the top edge.

Toolbar items are displayed equally spaced across the width of the toolbar. The precise set of toolbar items can change from view to view, because the items are always specific to the context of the current view.

On iPhone, changing the device orientation from portrait to landscape can change the height of the toolbar automatically. On iPad, the height and translucency of a toolbar does not change with rotation.

Guidelines

Use a toolbar to provide a set of actions users can take in the current context.
Use a toolbar to give people a selection of frequently used commands that make sense in the current context. An alternative is to put a segmented control in a toolbar to give people access to different perspectives on your application’s data or to different application modes.

If appropriate, customize the appearance of a toolbar. If you want the toolbar to coordinate with the overall look of your app, you can specify a custom background image or tint and you can specify translucency. In some cases, it can be a good idea to supply a resizable background image; to learn more about creating a resizable image.




Make sure that your toolbar customization is consistent with the look of the rest of your application. If you use a translucent toolbar, for example, don’t combine it with an opaque navigation bar. Also, it’s usually best to avoid changing the appearance of the toolbar in different screens in the same orientation.


Maintain a hit target area of at least 44 x 44 points for each toolbar item. If you crowd toolbar items too closely together, people have difficulty tapping the one they want. 

Use system-provided toolbar items according to their documented meaning.

If appropriate, customize the appearance of toolbar items. If you customize the appearance of the toolbar, you might want to consider creating a coordinating appearance for the toolbar items. You might also want to adjust the selected appearance of the items so that they look good on your customized toolbar background.

Try to avoid mixing plain style (borderless) and bordered toolbar items in the same toolbar. You can use either style in a toolbar, but mixing them does not usually look good. 

On iPhone, take into account the automatic change in toolbar height that occurs on device rotation. In particular, make sure your custom toolbar icons fit well in the thinner bar that appears in landscape orientation. Don’t specify the height of a toolbar programmatically; instead, you can take advantage of the UIBarMetrics constants to ensure that your content fits well..

Tab Bar

A tab bar gives people the ability to switch between different subtasks, views, or modes.
image: ../Art/tabbar.jpg
image: ../Art/ui_tabbar_ipad.jpg
A tab bar is contained in a tab bar controller, which is an object that manages the display of your set of custom views. To learn more about defining a tab bar in your code.

Appearance and Behavior

A tab bar appears at the bottom edge of the screen and should be accessible from every location in the application. A tab bar displays icons and text in tabs, all of which are equal in width and display a black background by default. When users select a tab, such as Search in YouTube, the tab displays a lighter background (which is known as the selection indicator image) and its icon receives a blue glow.
image: ../Art/ui_selecteditemmodeswitcher.jpg
On iPhone, a tab bar can display no more than five tabs at one time; if the app has more tabs, the tab bar displays four of them and adds the More tab, which reveals the additional tabs in a list. On iPad, a tab bar can display more than five tabs.
A tab can display a badge (a red oval that contains white text, either a number or exclamation point) that communicates app-specific information.
A tab bar does not change its opacity or height, regardless of device orientation.

Guidelines

Use a tab bar to give users access to different perspectives on the same set of data or different subtasks related to the overall function of your app. When you use a tab bar, follow these guidelines:

Don’t use a tab bar to give users controls that act on elements in the current mode or screen. If you need to provide controls for your users, use a toolbar instead.

In general, use a tab bar to organize information at the application level. A tab bar is well-suited for use in the main app view because it’s a good way to flatten your information hierarchy and provide access to several peer information categories or modes at one time.


Don’t remove a tab when its function is unavailable. If a tab represents a part of your app that is unavailable in the current context, it’s better to display a disabled tab than to remove the tab altogether. If you remove a tab in some cases but not in others, you make your app’s UI unstable and unpredictable. The best solution is to ensure that your tabs are always enabled, but to explain why a tab’s content is unavailable. For example, if the user does not have any songs on an iOS-based device, the Music app does not disable the Songs tab; instead, the Songs tab displays a screen that explains how to download songs.

On iPad, you might use a tab bar in a split view pane or a popover if the tabs switch or filter the content within that view. However, it often works better to use a segmented control at the bottom edge of a popover or split view pane, because the appearance of a segmented control coordinates better with the popover or split view appearance.

Consider badging a tab bar icon to communicate unobtrusively. You can display a badge on a tab bar icon to indicate that there is new information associated with that view or mode.
Use system-provided tab bar icons according to their documented meaning

If appropriate, customize the appearance of a tab bar. For example, you can supply a custom tint for the tab bar and its icons, as long as the icons are either system-provided or custom template images (to learn how to create a template image, see “Icons for Navigation Bars, Toolbars, and Tab Bars”). You can also supply a background image for the tab bar . Finally, you can also supply a different tint for the selected appearance of a tab icon (note that this appearance is separate from the selection indicator image). If you do not supply a custom selected-appearance tint, iOS applies the standard blue glow to a selected tab bar icon; if you supply a custom selected-appearance tint, iOS applies only the glow.

If necessary, provide a custom selection indicator image. In particular, if you provide a custom tint for a tab bar, you might want to define a selection indicator image that coordinates with it. You can supply one fixed-size or resizable image to apply to the currently selected tab (you can’t supply multiple selection indicator images for different tabs). In addition, your image should be translucent because iOS draws the selection indicator image behind the tab icon.

On iPad, avoid crowding the tab bar with too many tabs. Putting too many tabs in a tab bar can make it physically difficult for people to tap the one they want. Also, with each additional tab you display, you increase the complexity of your app. In general, try to limit the number of tabs in the main view or in the right pane of a split view to about seven. In a popover or in the left pane of a split view, up to about five tabs fit well.

On iPad, avoid creating a More tab. In an iPad app, a screen devoted solely to a list of additional tabs is a poor use of space.

On iPad, display the same tabs in each orientation to increase the visual stability of your app. In portrait, the recommended seven tabs fit well across the width of the screen. In landscape orientation, you should center the same tabs along the width of the screen. This guidance also applies to the usage of a tab bar within a split view pane or a popover. For example, if you use a tab bar in a popover in portrait, it works well to display the same tabs in the left pane of a split view in landscape.

Content Views

iOS provides a few views that are intended to display custom application content. Each view has certain properties and behaviors that make it especially well-suited to display certain types of information.

Popover (iPad Only)

A popover is a transient view that can be revealed when people tap a control or an onscreen area.
image: ../Art/popover.jpg
Appearance and Behavior

A popover is a self-contained view that hovers above the contents of a screen. It always displays an arrow that indicates the point from which it emerged. A popover can contain a wide variety of objects and views, such as:
  • Table, image, map, text, web, or custom views
  • Navigation bars, toolbars, or tab bars
  • Controls or objects that act upon objects in the current application view
In iPad apps, an action sheet always appears inside a popover.

Guidelines

You can use a popover to:
  • Display additional information or a list of items related to the focused (or selected) object.
  • Display an action sheet that contains a short list of options that are closely related to something on the screen.
  • Display the contents of the left pane when a split view–based app is in portrait. If you do this, be sure to provide an appropriately titled button that displays the popover, preferably in a navigation bar or toolbar at the top of the screen.
Avoid providing a “dismiss popover” button. A popover should close automatically when its presence is no longer necessary. To determine when a popover’s presence is no longer necessary, consider the following scenarios:
  • When a popover’s only function is to provide a set of options or items that have an effect on the main view, it should close as soon as people make a choice. This behavior is very similar to that of a menu in a computer application. Note that this behavior also applies to a popover that contains only an action sheet: As soon as people tap a button in the action sheet, the popover should close.
    Occasionally, it can make sense to provide a popover that contains items that affect the main view, but that does not close when people make a choice. You might want to do this if you implement an inspector in a popover, because people might want to make an additional choice or change the attributes of the current choice.
    A popover that provides menu or inspector functionality should close when people tap anywhere outside its bounds, including the control that reveals the popover. In a popover that provides a menu of choices, this gesture means that the user has decided not to make a choice (so the main view remains unaffected). In a popover that contains an action sheet, this gesture takes the place of tapping a Cancel button.
  • If a popover enables a task, it can be appropriate to display buttons that complete or cancel the task and simultaneously dismiss the popover. In general, popovers that enable an editing task display a Done button and a Cancel button. These buttons help remind people that they’re in an editing environment and allow them to explicitly keep or discard their input. When people tap either button, the popover should close.
    If it makes sense in your application, you can prevent people from closing such a popover when they tap outside its borders. This might be a good idea if it’s important that people finish (or explicitly abandon) a task. Otherwise, you should save their input when they tap outside a popover’s borders, just as you would if they tapped Done.
In general, save users’ work when they tap outside a popover’s borders. Because a popover does not require an explicit dismissal, people might dismiss it mistakenly. You should discard their work only if they tap a Cancel button.
Ensure that the popover arrow points as directly as possible to the element that revealed it. Doing this helps people remember where the popover came from and what task or object it’s associated with.
Make sure people can use a popover without seeing the application content behind it. A popover obscures the content behind it, and people cannot drag a popover to another location.
Ensure that only one popover is visible onscreen at a time. You should not display more than one popover (or custom view designed to look and behave like a popover) at the same time. In particular, you should avoid displaying a cascade or hierarchy of popovers simultaneously, in which one popover emerges from another.
Don’t display a modal view on top of a popover. Except for an alert, nothing should display on top of a popover.
When possible, allow people to close one popover and open a new one with one tap. This behavior is especially desirable when several different bar buttons each open a popover, because it prevents people from having to make extra taps.
Avoid making a popover too big. A popover should not appear to take over the entire screen. Instead, it should be just big enough to display its contents and still point to the place it came from.
Ideally, the width of a popover should be at least 320 points, but no greater than 600 points. The height of a popover is not constrained, so you can use it to display a long list of items. In general, though, you should try to avoid scrolling in a popover that enables a task or that presents an action sheet. Note that the system might adjust both the height and the width of a popover to ensure that it fits well on the screen.
Generally, use standard UI controls and views within a popover. In general, popovers look best, and are easier for users to understand, when they contain standard controls and views.
If appropriate, customize the appearance of a popover. Although it’s easy to customize many of the visual aspects of a popover by using the UIPopoverBackgroundView APIs, it’s important to avoid creating a design that people might not recognize as a popover. If you change the appearance of a popover too much, users can’t rely on their prior experience to help them understand how to use it in your app. (If you decide to supply a resizable background image.

Take care if you combine a customized background color or texture with standard controls and views. Be sure the standard UI elements look good and are easy to read when they’re seen on top of your custom background appearance.

If appropriate, change a popover’s size while it remains visible. You might want to change a popover’s size if you use it to display both a minimal and an expanded view of the same information. If you adjust the size of a popover while it’s visible, you can choose to animate the change. Animating the change is usually a good idea because it avoids making people think that a new popover has replaced the old one.

Split View (iPad Only)

A split view is a full-screen view that consists of two side-by-side panes.
image: ../Art/split_view.jpg
A split view is contained in a split view controller, which is an object that manages the display of the split view’s panes. To learn more about defining a split view in your code.


Appearance and Behavior

A split view consists of two panes. The width of the left pane is fixed at 320 points in all orientations. Users cannot resize either pane of a split view.

Both panes can contain a wide variety of objects and views, such as:
  • Table, image, map, text, web, or custom views.
  • Navigation bars, toolbars, or tab bars.

Guidelines

You can use a split view to display persistent information in the left pane and related details or subordinate information in the right pane. In this design pattern, when people select an item in the left pane, the right pane should display the information related to that item. (You’re responsible for making this happen in code.)
Sometimes, when an app uses a split view in landscape, it displays the contents of the left pane in a popover when the device rotates to portrait. However, you are not required to follow this pattern. If it makes sense in your app, you can design your UI to display side-by-side views in all orientations.
Avoid creating a right pane that is narrower than the left pane. Although the width of the right pane is up to you, it does not look good to use a width of less than 320 points (which is the width of the left pane).
Avoid displaying a navigation bar in both panes at the same time. Doing this would make it very difficult for users to discern the relationship between the two panes.
In general, indicate the current selection in the left pane in a persistent way. This behavior helps people understand the relationship between the item in the left pane and the contents of the right pane. This is important because the content of the right pane can change, but it should always remain related to the item selected in the left pane.

Table View

A table view presents data in a single-column list of multiple rows.
image: ../Art/ui_tableexample.jpg

Appearance and Behavior

A table view displays data in rows that can be divided by section or separated into groups. Users flick or drag to scroll through rows or groups of rows. Users tap a table row to select it and use table view controls to add or remove rows, select multiple rows, see more information about a row item, or reveal another table view. A table row highlights briefly when the user taps a selectable item.

If a row selection results in navigation to a new screen, the selected row highlights briefly as the new screen slides into place. When the user navigates back to the previous screen, the originally selected row again highlights briefly to remind the user of their earlier selection (it does not remain highlighted).

iOS defines two styles of table views, which are distinguished mainly by appearance.

Plain tables display rows that extend from side edge to side edge of the screen. Rows can be separated into labeled sections and an optional index can appear vertically along the right edge of the view. A header can appear before the first item in a section and a footer can appear after the last item. By default, the row background is a creamy white.
image: ../Art/ui_simplelist.jpg
Grouped tables display groups of rows that are inset from the side edges of the screen. A grouped table view always contains at least one group of list items (one list item per row), and each group always contains at least one item. A group can be preceded by header text and followed by footer text. By default, groups are displayed on a distinctive blue-striped background; inside a group, row background is a creamy white. A grouped table view does not include an index.
image: ../Art/ui_grouptablesingles.jpg
iOS includes some table-view elements that can extend the functionality of table views. Unless noted otherwise, these elements are suitable for use with table views only.
Table 7-1  Table-view elements
ElementNameDescription
image: ../Art/checkmark.jpgCheckmarkIndicates that the row is selected
image: ../Art/disclosure.jpgDisclosure indicatorDisplays another table associated with the row
image: ../Art/detail_disclosure.jpgDetail disclosure buttonDisplays additional details about the row in a new view
image: ../Art/row_reorder.jpgRow reorderIndicates that the row can be dragged to another location in the table
image: ../Art/row_add.jpgRow insertAdds a new row to the table
image: ../Art/delete_control.jpgDelete button control In an editing context, reveals and hides the Delete button for a row
image: ../Art/delete_button.jpgDelete buttonDeletes the row
iOS 3 and later defines four table-cell styles that implement the most common layouts for table rows in both plain and grouped tables. Each cell style is best suited to display a different type of information.

Default (UITableViewCellStyleDefault). The default cell style includes an optional image in the left end of the row, followed by a left-aligned title in black.
image: ../Art/ui_defaulttablecell.jpg
In the default cell style, the text label’s appearance implies that it represents an item name or title and its left-alignment makes the list easy to scan. This makes the default style good for displaying a list of items that do not need to be differentiated by supplementary information.
Subtitle (UITableViewCellStyleSubtitle). The subtitle style includes an optional image in the left end of the row, followed by a left-aligned title on one line and a left-aligned subtitle on the line below. The title is in black and the subtitle is in a smaller, gray font.
image: ../Art/ui_subtitletablecell.jpg
In the subtitle cell style, the prominent appearance of the text label implies that it represents an item name or title, whereas the subtle appearance of the detail text label implies that it contains subsidiary information related to the item. The left-alignment of the text labels makes the list easy to scan. This table-cell style works well when list items look similar, because users can use the additional information in the detail text labels to help distinguish items named in the text labels.
Value 1 (UITableViewCellStyleValue1). The value 1 style displays a left-aligned title in black on the same line with a right-aligned subtitle in a smaller, blue font. Images do not fit well in this style.
image: ../Art/ui_value1tablecell.jpg
In the value 1 cell style, the appearance of the text label implies that it represents an item name or title, whereas the appearance of the detail text label implies that it provides important information that is closely associated with the item.
The left-alignment and font of the text label help users scan the list for the item they want, and the right-alignment of the detail text label draws their attention to the related information it provides. This table-cell style works well to display an item’s current value, possibly selected from a sublist.
Value 2 (UITableViewCellStyleValue2). The value 2 style displays a right-aligned title in a small, blue font, followed on the same line by a left-aligned subtitle in a larger, black font. Images do not fit well in this style.
image: ../Art/ui_value2tablecell.jpg
In the value 2 cell style, the right-alignment, constrained width, and font of the text label imply that it functions as a heading or caption for the important information in the more prominent, left-aligned detail text label.
In this layout, the labels are aligned towards each other at the same location in every row. This creates a crisp, vertical margin between the text labels and the detail text labels in the list, which helps users focus on the first words of the detail text label.

Guidelines

You can use a table view to display large or small amounts of information cleanly and efficiently. For example, you can use a table view to:

Provide a list of options from which users can select. You can use the checkmark to show users the currently selected option (or options) in the list.

To display a list of choices users see when they tap an item in a table row, you can use either a plain or a grouped table view. To display a list of choices users see when they tap a button or other UI element that is not in a table row, use the plain style.

Display hierarchical information. The plain table style is well-suited to display a hierarchy of information. Each list item can lead to a different subset of information displayed in another list. Users follow a path through the hierarchy by selecting one item in each successive list. The disclosure indicator tells users that tapping anywhere in the row reveals the subset of information in a new list.

Display conceptually grouped information. Both table view styles allow you to provide context by supplying header and footer text between sections of information. The rounded corners of the grouped style make separate groups of information easy to see, even when users are scrolling quickly.

Display information that is indexed to facilitate lookup. The plain style supports an index view that helps users quickly find what they need. The index consists of a column of entries (usually letters in an alphabet) that floats on the right edge of the screen. Users tap (or drag to) an index entry to reveal the corresponding area in the list. 

If you include an index, avoid using table-view elements that display on the right edge of the table (such as the disclosure indicator), because these elements interfere with the index.
Always provide feedback when users select a list item. Users expect a table row to highlight briefly when they tap a selectable item in it. After tapping, users expect an immediate action to occur: Either a new view appears or the row displays a checkmark to indicate that the item has been selected or enabled. 

In rare cases, a row might remain highlighted when secondary details or controls related to the row item are displayed in the same screen. However, this is not encouraged because it is difficult to display simultaneously a list of choices, a selected item, and related details or controls without creating an uncomfortably crowded layout.

Follow these guidelines when you use table views:

Consider animating the changes users make to list items to provide feedback and strengthen the user’s sense of direct manipulation. In Settings, for example, when users turn off the automatic date and time setting (by selecting Off in General > Date & Time > Set Automatically), the list group expands smoothly to display two new items, Time Zone and Set Date & Time.

If table content is extensive or complex, avoid waiting until all the data is available before displaying anything. Instead, fill the onscreen rows with textual data immediately and display more complex data (such as images) as they become available. This technique gives users useful information right away and increases the perceived responsiveness of your application. 

Consider displaying “stale” data while waiting for new data to arrive. If your app displays data that changes infrequently, you might consider this technique so that users can see something useful right away. This technique is not recommended for applications that handle data that changes frequently. Before you decide to do this, gauge how often the data changes and how much users depend on seeing fresh data quickly.

If the data is slow-loading or complex, provide users with a signal that processing is continuing. If a table contains only complex data, it might be difficult to display anything useful right away. In these rare cases, it's important to avoid displaying empty rows, because this can imply that the application has stalled. Instead, the table should display a spinning activity indicator along with an informative label, such as “Loading...”, centered in the screen. This provides feedback to users, letting them know that processing is continuing.

Avoid variable row heights in a plain table. Variable row heights are acceptable in grouped tables, but they can make a plain table look cluttered and uneven.

Don’t use white in areas of an image that you want to look transparent. The background of a table row is not pure white, so white areas in an image will appear white; they will not blend in with the background and appear transparent. If you want some areas in an image to look transparent, be sure to make them transparent.

If appropriate, use a custom title for the Delete button. If it helps users to better understand the way your app works, you can create a title to replace the system-provided Delete title.

Generally, use grouped tables for the value 1 and value 2 cell styles. Although you can use any cell style with either type of table, the value 1 and value 2 cell styles look best in grouped tables. For example, Settings uses the value 1 cell style:
image: ../Art/value1_example.jpg
iPhone Contacts uses the value 2 cell style:
image: ../Art/value2_example.jpg
As much as possible, ensure that your text labels are succinct to avoid truncation. Truncated words and phrases can be difficult for users to scan and understand. Text truncation is automatic in all table-cell styles, but it can present more or less of a problem, depending on which cell style you use and on where truncation occurs.
  • In the default cell style, short text labels are best. If truncation is unavoidable, try to ensure that the most important information is contained in the first few words.
  • In the subtitle cell style, too, short text labels are best. If truncation is unavoidable, focus on putting the most important information in the first few words. If the detail text label is truncated, users are not likely to mind too much because they view it as information that enhances or supplements the item named by the text label.
  • In the value 1 cell style, text truncation can be difficult to avoid (because both labels are on the same line), but it’s worth the effort. Otherwise, you lose the active space between the labels that helps users understand the relationship between the two pieces of information.
  • In the value 2 cell style, truncated text labels blunt the sharpness of the vertical strip of white space between them and the detail text. When the white-space width is inconsistent from row to row, it’s harder for users to scan the information in the detail text.
You might be able to avoid text truncation by increasing the height of a table row to accommodate text wrapping, but this can be problematic for these reasons:
  • You have to programmatically check the text length and decide if wrapping might occur. You must make this determination for both portrait and landscape orientation, because the table width affects text wrapping.
  • Text might wrap in one orientation, but not the other, which is something you should avoid.
  • Variable row heights can negatively impact the overall table view performance in your application, regardless of table-view style.
If you want to lay out your table rows in a nonstandard way, it’s better to create a custom table-cell style than to significantly alter a standard one. 

Text View

A text view accepts and displays multiple lines of text.
image: ../Art/ui_textview.jpg

Appearance and Behavior

A text view is a rounded rectangle of any height. A text view supports scrolling when the content is too large to fit inside its bounds.
If the text view supports user editing, a keyboard appears when the user taps inside the text view. The keyboard’s input method and layout are determined by the user’s language settings. When users tap the button labeled “.?123,” the keyboard changes to display numbers, punctuation marks, and a few common symbols.

Guidelines

You have control over the font, color, and alignment of the text in a text view, but only as they apply to the entirety of the text. In other words, you can’t change any of these properties for only part of the text. The default font is the system font and the default color is black, because these tend to be the most readable. The default for the alignment property is left (you can change it to center or right). 

If you must enable variable fonts, colors, or alignments within a view that displays text, you can use a web view instead of a text view, and style the text using HTML.

You can also specify different keyboard styles, depending on the type of content you expect users to enter.

Web View

A web view is a region that can display rich HTML content (shown here between the navigation bar and toolbar in Mail on iPhone).
image: ../Art/webview.jpg

Appearance and Behavior

In addition to displaying web content, a web view performs some automatic processing on web content, such as converting a phone number to a phone link.

Guidelines

If you have a webpage or web app, you might decide to use a web view to implement a simple iOS application that provides a wrapper for your webpage or web app. If you plan to use a web view to access web content that you control.

Avoid using a web view to create an application that looks and behaves like a mini web browser. People expect to use Safari on iOS to browse web content, so replicating this broad functionality within your app is not recommended.

Container View Controller

A container view controller manages and presents its set of child views (or view controllers) in a custom way. Examples of system-defined container view controllers are tab bar view controller, navigation view controller, and split view controller.

Appearance and Behavior

As you might expect, a custom container view controller does not have any predefined appearance or behavior. When you subclass UIViewController to create a custom container view controller object, you decide how many child view controllers it contains and how they should be presented.

Guidelines

You can use a container view controller to present content through which users navigate in a custom way. 

Ask yourself whether a custom container view controller is really necessary. Users are comfortable with the appearance and behavior of standard container view controllers, such as split view and tab bar view. You need to be sure that the potential advantages of your custom container view outweigh the fact that users won’t recognize it or instantly know how it works.

Make sure that your custom container view controller works in both orientations. You need to design a container view controller that gives users a consistent experience in both portrait and landscape.

In general, avoid flashy view transitions. When you use storyboards to design a custom view controller, it’s easy to define custom animations for the transitions between content views. But in most cases, flamboyant view transitions distract people from their purpose and often decrease the aesthetic appeal of your app.

Alerts, Action Sheets, and Modal Views

Alerts, action sheets, and modal views are temporary views that appear when something requires the user’s attention or when additional choices or functionality need to be offered. People cannot interact with an application while one of these views is on the screen.


Alert

An alert gives people important information that affects their use of the application (or the device).
image: ../Art/alert_title_with_msg.jpg

Appearance and Behavior

An alert pops up in the middle of the application screen and floats above its views. The unattached appearance of an alert emphasizes the fact that its arrival is due to some change in the application or the device, not necessarily as the result of the user’s most recent action. Users must dismiss the alert before they can continue using the currently running application.

An alert always contains at least one button, which users tap to dismiss the alert. By default, an alert displays a title and might also display a message that provides additional information. An alert can contain one or two text fields, one of which can be a secure text-input field. The background appearance of an alert is system-defined and cannot be changed.


Guidelines

The infrequency with which alerts appear helps users take them seriously. Be sure to minimize the number of alerts your app displays and ensure that each one offers critical information and useful choices.
Avoid creating unnecessary alerts.
In general, alerts are unnecessary if they:
  • Merely increase the visibility of some information, especially information that is related to the standard functioning of your application.
    Instead, you should design an eye-catching way to display the information that harmonizes with your app’s style.
  • Update users on tasks that are progressing normally.
    Instead, consider using a progress view or an activity indicator to provide progress-related feedback to users .
  • Ask for confirmation of user-initiated actions.
    To get confirmation for an action the user initiated, even a potentially risky action such as deleting a contact, you should use an action sheet.
  • Inform users of errors or problems about which they can do nothing.
    Although it might be necessary to use an alert to tell users about a critical problem they can’t fix, it’s better to integrate such information into the UI, if possible. For example, instead of telling users every time a server connection fails, display the time of the last successful connection.
You can specify the text of the required title and optional message, the number of buttons, and the button contents in an alert. You can’t customize the width or the background appearance of the alert view itself, or the alignment of the text (it’s center-aligned).
As you read the alert-text design guidelines, it’s useful to know the following definitions:
  • Title-style capitalization means that every word is capitalized, except articles, coordinating conjunctions, and prepositions of four or fewer letters when they aren’t the first word.
  • Sentence-style capitalization means that the first word is capitalized, and the rest of the words are lowercase unless they are proper nouns or proper adjectives.
Write alert text that succinctly describes the situation and explains what people can do about it. Ideally, the text you write gives people enough context to understand why the alert has appeared and to decide which button to tap.
Keep the title short enough to display on a single line, if possible. A long alert title is difficult for people to read quickly, and it might get truncated or force the alert message to scroll.
image: ../Art/alert_title_only.jpg

Avoid single-word titles that don’t provide any useful information, such as “Error” or “Warning.”

When possible, use a sentence fragment. A short, informative statement is often easier to understand than a complete sentence.

Don’t hesitate to be negative. People understand that most alerts tell them about problems or warn them about dangerous situations. It’s better to be negative and direct than it is to be positive but oblique.

Avoid using “you,” “your,” “me,” and “my” as much as possible. Sometimes, text that identifies people directly can be ambiguous and can even be interpreted as an insult.

Use capitalization and punctuation appropriately.

Use title-style capitalization and no ending punctuation when the title is a sentence fragment or it consists of a single sentence that is not a question.

If the title consists of a single sentence that is a question, use sentence-style capitalization and an ending question mark. In general, consider using a question for an alert title if it allows you to avoid adding a message.

If the title consists of two or more sentences, use sentence-style capitalization and appropriate ending punctuation for each sentence. A two-sentence alert title should seldom be necessary, although you might consider it if it allows you to avoid adding a message.

If you provide an optional alert message, create a short, complete sentence. Use sentence-style capitalization and appropriate ending punctuation.

image: ../Art/alert_title_with_msg.jpg 

Avoid creating an alert message that is too long. If possible, keep the message short enough to display on one or two lines. If the message is too long it will scroll, which is not a good user experience.

image: ../Art/alert_msg_too_long.jpg 

Avoid lengthening your alert text with descriptions of which button to tap, such as “Tap View to see the information.” Ideally, the combination of unambiguous alert text and logical button labels gives people enough information to understand the situation and their choices. However, if you must provide detailed guidance, follow these guidelines:
  • Be sure to use the word “tap” (not “touch” or “click” or “choose”) to describe the selection action.
  • Don’t enclose a button title in quotation marks, but do preserve its capitalization.
Be sure to test the appearance of your alert in both orientations. Because the height of an alert is constrained in landscape, it might look different from the way it looks in portrait. It’s recommended that you optimize the length of the alert text so that it looks good (and avoids scrolling) in both orientations.
Generally, use a two-button alert. A two-button alert is often the most useful, because it is easiest for people to choose between two alternatives. It is rarely a good idea to display an alert with a single button because such an alert is merely informative; it does not give people any control over the situation. An alert that contains three or more buttons is significantly more complex than a two-button alert and should be avoided if possible. In fact, if you find that you need to offer people more than two choices, you should consider using an action sheet instead .

Use alert button colors appropriately. Alert buttons are colored either dark or light. In an alert with two buttons, the button on the left is always dark-colored and the button on the right is always light-colored. In a one-button alert, the button is always light-colored.
  • In a two-button alert that proposes a potentially risky action, the button that cancels the action should be on the right (and light-colored).
  • In a two-button alert that proposes a benign action that people are likely to want, the button that cancels the action should be on the left (and dark-colored).

Give alert buttons short, logical titles. The best titles consist of one or two words that make sense in the context of the alert text. Follow these guidelines as you create titles for alert buttons:
  • As with all button titles, use title-style capitalization and no ending punctuation.
  • Use verbs and verb phrases, such as “Cancel,” “Allow,” “Reply,” or “Ignore” that relate directly to the alert text.
  • Use “OK” for a simple acceptance option if there is no better alternative. Avoid using “Yes” or “No.”
  • Avoid “you,” “your,” “me,” and “my” as much as possible. Button titles that use these words are often both ambiguous and patronizing.

Action Sheet

An action sheet (shown below on iPhone) displays a set of choices related to a task the user initiates.
image: ../Art/action_sheet_iphone.jpg


Appearance and Behavior

An action sheet has two different appearances. On iPhone, an action sheet always emerges from the bottom of the screen and hovers over the application’s views (an action sheet for Safari on iPhone is shown above). The side edges of an action sheet are anchored to the sides of the screen, which reinforces its connection to the app and to the user’s most recent action.
On iPad, an action sheet is always displayed within a popover; it never has full-screen width . An action sheet can cause a popover to appear, or it can appear within a popover that is already open. In both cases, there is a strong visual connection between the action sheet and the user’s action. For example, the action sheet shown here is displayed when the user taps the Mail Reply button on iPad.
image: ../Art/action_sheet_ipad.jpg
An action sheet always contains at least two buttons that allow users to choose how to complete their task. When users tap a button, the action sheet disappears. An action sheet does not include a title or explanatory text, because it appears in immediate response to a user action.

Guidelines

Use an action sheet to:
  • Provide alternate ways a task can be completed. An action sheet allows you to provide a range of choices that make sense in the context of the current task, without giving these choices a permanent place in the user interface.
  • Get confirmation before completing a potentially dangerous task. An action sheet prompts users to think about the potentially dangerous effects of the step they’re about to take and gives them some alternatives. This type of communication is particularly important on iOS-based devices because sometimes users tap controls without meaning to.
On iPhone, coordinate the action sheet background appearance with the navigation bars and toolbars. Use the translucent black background if your application uses black navigation bars and toolbars. Use the default blue background if your navigation bars and toolbars are the default blue color.
All action sheets in your iPhone application should have the same background color.
On iPhone, include a Cancel button so that users can easily and safely abandon the task. Place the Cancel button at the bottom of the action sheet to encourage users to read through all the alternatives before making a choice. By default, the appearance of the Cancel button coordinates with the background of the action sheet.
On iPad, choose whether to display an action sheet with animation or without animation.
  • Display an action sheet without animation to provide alternatives related to a task that the user initiates from outside a popover. Without animation, an action sheet and its popover appear simultaneously. When you display an action sheet this way, the popover’s arrow points to the control or area the user tapped to initiate the task.
    Do not include a Cancel button when the action sheet is displayed without animation, because people can tap outside the popover to dismiss the action sheet without selecting one of the other alternatives.
  • Display an action sheet with animation to provide alternatives related to a task that the user initiates from within an open popover. With animation, an action sheet slides up over an open popover’s content.
    An animated action sheet should include a Cancel button, because people need to be able to dismiss the action sheet without closing the popover.
On both devices, use the red button color if you need to provide a button that performs a potentially destructive action. Display a red button at the top of the action sheet, because the closer to the top of the action sheet a button is, the more eye-catching it is. And, on iPhone, the farther a destructive button is from the bottom of an action sheet, the less likely users are to tap it when they’re aiming for the Home button.
image: ../Art/red_button_action_sheet.jpg
Avoid making users scroll through an action sheet. If you include too many buttons in an action sheet, users must scroll to see all actions. This is a disconcerting experience for users, because they must spend extra time considering each choice. Also, it can be very difficult for users to scroll without inadvertently tapping a button.

Modal View

A modal view (that is, a view presented modally) provides self-contained functionality in the context of the current task or workflow.
image: ../Art/page_modal.jpg

Appearance and Behavior

A modal view occupies the entire application screen, which strengthens the user’s perception of entering a separate, transient mode in which they can accomplish something. On iPad, a modal view might also occupy the entire area of a parent view, such as a popover.
A modal view can display text if appropriate, and contains the controls necessary to perform the task. A modal view generally displays a button that completes the task and dismisses the view, and a Cancel button users can tap to abandon the task.

Guidelines

Use a modal view when you need to offer the ability to accomplish a self-contained task related to your application’s primary function. A modal view is especially appropriate for a multistep subtask that requires UI elements that don’t belong in the main application user interface all the time.
On iPad, choose a modal view style that suits the current task and the visual style of your app. You can use any of these styles, defined here:
  • Full screen. Covers the entire screen. This style is good for presenting a potentially complex task that people can complete within the context of the modal view. For example, the Music application uses this style for its Genius playlist creation task.
  • Page sheet. Has a fixed width of 768 points; the sheet height is the current height of the screen. In portrait, the modal view covers the entire screen; in landscape, the screen that is visible on both sides of the modal view is dimmed to prevent user interaction. For example, Mail uses this style for its message composition task.
  • Form sheet. Has fixed dimensions of 540 x 620 points and is centered in the screen. The area of the screen that is visible outside the modal view is dimmed to prevent user interaction. When the keyboard is visible in landscape, a form sheet view moves up to just below the status bar. This style is good for gathering structured information from the user.
  • Current context. Uses the same size as its parent view. This style is good for displaying a modal view within a split view pane, popover, or other non–full–screen view.
On iPad, don’t display a modal view on top of a popover. With the possible exception of an alert, nothing should display on top of a popover. In rare cases when you might need to display a modal view as a result of an action the user takes in a popover, close the popover before you open the modal view.
On iPhone, coordinate the overall look of a modal view with the appearance of your app. For example, a modal view often includes a navigation bar that contains a title and buttons that cancel or complete the modal view’s task. When this is the case, the navigation bar should have the same background appearance as the navigation bar in the application.
On both devices, display a title that identifies the task, if appropriate. You might also display text in other areas of the view that more fully describes the task or provides some guidance. For example, the Messages app on iPhone presents a modal view when users want to compose a text message. This modal view displays a navigation bar with the same background as the application navigation bar and with the title New Message.
image: ../Art/ui_modalviewexample.jpg
On both devices, choose an appropriate transition style for revealing the modal view. Use a style that coordinates with your application and enhances the user’s awareness of the temporary context shift that the modal view represents. To do this, you can specify one of the following transition styles:
  • Vertical. The modal view slides up from the bottom edge of the screen and slides back down when dismissed. (This is the default transition style.)
  • Flip. The current view flips horizontally from right to left to reveal the modal view. Visually, the modal view looks as if it is the back of the current view. When the modal view is dismissed, it flips horizontally from left to right, revealing the previous view.
  • Partial curl. The partial-curl transition style is similar to the page-curl behavior of Maps on iPhone. Visually, one corner of the current view curls up to reveal the modal view underneath. When the user leaves the modal view, the current view uncurls to its original position. You might want to use this style when the modal view you reveal is not large and does not require much user interaction, such as a view that holds configuration options.
    Note that a modal view revealed by a partial-curl transition cannot itself reveal another modal view.
If you decide to vary the transition styles of the modal views in your application, avoid doing so merely for the sake of variety. Users are quick to notice such differences and will assume that they mean something. For this reason, it’s best to establish a logical, consistent pattern that users can easily detect and remember, and avoid changing transition styles without a good reason.

Controls

Controls are UI elements that users view to get information, or interact with to perform an action. iOS provides a large number of controls that you can use in your application.

Activity Indicator

An activity indicator shows that a task or process is progressing (shown here with a label).
image: ../Art/activity_indicator_with_label.jpg


Appearance and Behavior

An activity indicator spins while a task is progressing and disappears when the task completes. Users do not interact with an activity indicator. By default, an activity indicator is white.

Guidelines

Use an activity indicator in a toolbar or a main view to show that processing is occurring, without suggesting when it will finish.
Don’t display a stationary activity indicator, because users associate this with a stalled process.
Use an activity indicator when it’s more important to reassure users that their task or process has not stalled than it is to suggest when processing will finish.
If appropriate, customize the size and color of an activity indicator to coordinate with the background of the view in which it appears.

Date and Time Picker

A date and time picker displays components of date and time, such as hours, minutes, days, and years.
image: ../Art/date_time_picker.jpg


Appearance and Behavior

A date and time picker can have up to four independent wheels, each of which displays values in a single category, such as month or hour. Users flick or drag to spin each wheel until it displays the desired value beneath the clear selection bar that stretches across the middle of the picker. The final value comprises the values displayed in each wheel.
The overall size of a date and time picker is fixed at the same size as the iPhone keyboard.
A date and time picker has four modes, each of which displays a different number of wheels that contain a set of different values.
  • Date and time. The date and time mode displays wheels for the calendar date, hour, and minute values, with the optional addition of a wheel for the AM/PM designation. This is the default mode.
  • Time. The time mode displays wheels for the hour and minute values, with the optional addition of a wheel for the AM/PM designation.
  • Date. The date mode displays wheels for the month, day, and year values.
  • Countdown timer. The countdown timer mode displays wheels for the hour and minute. You can specify the total duration of a countdown, up to a maximum of 23 hours and 59 minutes.

Guidelines

Use a date and time picker to let users pick (instead of type) a date or time value that consists of multiple parts, such as the day, month, and year. A date and time picker is easy to use because the values in each part have a relatively small range and users already know what the values are.
If it makes sense in your app, change the interval in the minutes wheel. By default, a minutes wheel displays 60 values (0 to 59). If you need to display a coarser granularity of choices, you can set a minutes wheel to display a larger minute interval, as long as the interval divides evenly into 60. For example, you might want to display the quarter-hour intervals 0, 15, 30, and 45.
On iPad, present a date and time picker only within a popover. A date and time picker is not suitable for the main screen.

Detail Disclosure Button

A detail disclosure button reveals additional details or functionality related to an item (shown here inside a map annotation view).
image: ../Art/detail_disclosure_maps.jpg


Appearance and Behavior

Users tap a detail disclosure button to reveal additional information or functionality related to a specific item. The additional details or functionality are revealed in a separate view.
When a detail disclosure button appears in a table row, tapping elsewhere in the row does not activate the detail disclosure button; instead, it selects the row item or results in application-defined behavior.

Guidelines

Typically, you use a detail disclosure button in a table view to give users a way to see more details or functionality related to a list item. However, you can also use this element in other types of views to provide a way to reveal more information or functionality related to an item in that view.

Info Button

An Info button reveals configuration details about an application, often on the back of the current view.
image: ../Art/info_button.jpg


Appearance and Behavior

iOS includes two styles of Info button: a dark-colored “i” on a light background and a light-colored “i” on a dark background. An Info button automatically glows briefly when the user taps it. When tapped, an Info button results in an immediate action, such as flipping a view in an application to reveal the back.

Guidelines

Use an Info button to reveal configuration details or options about an application. You can use the style of Info button that coordinates best with the UI of your app.
On iPhone, use an Info button to flip the screen and reveal more information. Typically, the back of a screen displays configuration options that don’t need to be in the main UI.
On iPad, avoid using an Info button to flip the entire screen. Instead, you might use an Info button to show people that they can access an expanded view that contains related information or additional details.

Label

A label displays static text.
image: ../Art/label.jpg

Appearance and Behavior

A label displays any amount of static text. Users do not interact with labels except, potentially, to copy the text.

Guidelines

You can use a label to name or describe parts of your UI or to provide short messages to the user. A label is best suited to display a relatively small amount of text.
Take care to make your labels legible. Don’t sacrifice clarity for fancy fonts or showy colors.

Network Activity Indicator

A network activity indicator appears in the status bar and shows that network activity is occurring (shown here to the left of the time).
image: ../Art/network_activity_indicator.jpg
In your code, you use the UIApplication method networkActivityIndicatorVisible to control the indicator’s visibility.

Appearance and Behavior

The network activity indicator spins in the status bar while network activity proceeds. It disappears when network activity stops. Users do not interact with the network activity indicator.

Guidelines

Display the network activity indicator to provide feedback when your application accesses the network for more than a couple of seconds. If the operation finishes sooner than that, you don’t have to show the network activity indicator, because the indicator would be likely to disappear before users notice its presence.

Page Indicator

A page indicator indicates how many views are open and which one is currently visible.
image: ../Art/page_indicator.jpg


Appearance and Behavior

A page indicator displays a dot for each currently open peer view in an application. From left to right, the dots represent the order in which the views were opened (the leftmost dot represents the first view). The currently visible view is indicated by a glow on the dot that represents it. Users tap to the left or the right of the glowing dot to see the previous or next open view.
The dots of a page indicator do not shrink or squeeze together as more appear. A screen in portrait orientation can accommodate approximately 20 dots; if you try to display more dots than will fit in the screen, they will be clipped.

Guidelines

Use a page indicator when each view in your application is a peer of every other view. Do not use a page indicator if your application displays information in a hierarchy of views, because a page indicator does not help users retrace their steps through a specific path.
Vertically center a page indicator between the bottom edge of an open view and the bottom edge of the screen, where it is always visible without getting in users’ way. Be sure to avoid trying to display too many dots for the current screen orientation.
On iPad, investigate ways to display your content on a single screen. On the large iPad screen multiple parallel screens don’t work as well, so the need for the page indicator control is decreased.

Picker

A picker displays a set of values from which a user picks one.
image: ../Art/picker_view.jpg


Appearance and Behavior

A picker is a generic version of the date and time picker. As with a date and time picker, users spin the wheel (or wheels) of a picker until the value they want appears. The overall size of a picker, including its background, is fixed at the same size as the keyboard on iPhone. 

Guidelines

Use a picker to make it easy for people to choose from a set of values. It’s often best to use a picker when people are familiar with the entire set of values. This is because many, if not most, of the values are hidden when the wheel is stationary. If you need to provide a large set of choices that aren’t well known to your users, a picker might not be the appropriate control.
Consider using a table view, instead of a picker, if you need to display a very large number of values. This is because the greater height of a table view makes scrolling faster.
Use the translucent selection bar to display contextual information, such as a unit of measurement. Do not display such labels above the picker or on the wheel itself.
On iPad, present a picker only within a popover. A picker is not suitable for the main screen.

Progress View

A progress view shows the progress of a task or process that has a known duration (shown here with a label).
image: ../Art/progress_in_bar.jpg


Appearance and Behavior

iOS provides two styles of progress view. The appearance of each style is very similar, except for height.
  • The default style is white and has a weight that makes it suitable for use in an application’s main content area.
  • The bar style is thinner than the default style, which makes it well-suited for use in a toolbar. The bar style is also white by default.
As the task or process proceeds, the track of the progress view is filled from left to right. At any given time, the proportion of filled to unfilled area in the progress view gives people an indication of how soon the task or process will finish. Users do not interact with a progress view.

Guidelines

Use a progress view to provide feedback to people on a task that has a well-defined duration, especially when it’s important to show them approximately how long the task will take. When you display a progress view, you tell the user that their task is being performed and you give them enough information to decide if they want to wait until the task is complete or cancel it.
If appropriate, customize the appearance of a progress view to coordinate with the style of your app. You can specify a custom tint or image for both the track and the fill of a progress view.

Rounded Rectangle Button

A rounded rectangle button performs an application-specific action.
image: ../Art/rounded_rectangle.jpg


Appearance and Behavior

A rounded rectangle button has a corner radius that is the same as the corner radius of a grouped table view. By default, the button’s background is white.

Guidelines

Use a rounded rectangle button to initiate an action. When you supply a title for a rounded rectangle button, follow this approach:
  • Use title-style capitalization (that is, capitalize every word except articles, coordinating conjunctions, and prepositions of four or fewer letters)
  • Avoid creating a title that is too long. Overly long text gets truncated, which can make it difficult for users to understand it.
You can specify the title or image to display in a rounded rectangle button . You can also specify that the button should highlight when it’s tapped and how the title should look when the button highlights.

Scope Bar

A scope bar allows users to define the scope of a search. A scope bar is available only in conjunction with a search bar, and is often displayed below it.
image: ../Art/scope_bar_with_search.jpg
Appearance and Behavior
 
When a search bar is present, a scope bar can appear near it. The scope bar displays below the search bar, regardless of orientation, unless you use a search display controller in your code . When you use a search display controller, the scope bar is displayed within the search bar to the right of the search field when the device is in landscape orientation (in portrait orientation, it’s below the search bar).
The scope bar contains buttons users can tap to select a scope for the search, and it adopts the same appearance you specify for the search bar.

Guidelines

It can be useful to display a scope bar when there are clearly defined or typical categories in which users might want to search. For example, users often want to narrow their search to one field in an email message.
You can customize a scope bar by supplying a background image. In addition, you can define different appearances for the enabled and disabled states of the scope bar buttons and the dividers between them.

Search Bar

A search bar accepts text from users, which can be used as input for a search (shown here with placeholder text and the Bookmarks button).
image: ../Art/search_bar.jpg


Appearance and Behavior

A search bar looks like a text field with rounded ends. By default, a search bar displays the search icon on the left side. When the user taps a search bar, a keyboard appears; when the user is finished typing search terms, the input is handled in an application-specific way.
In addition, a search bar can display a few optional elements:
  • Placeholder text. This text might state the function of the control (for example, “Search”) or remind users in what context they are searching (for example, “YouTube” or “Google”).
  • The Bookmarks button. This button can provide a shortcut to information users want to easily find again. For example, the Bookmarks button in the Maps search mode gives access to bookmarked locations, recent searches, and contacts.
    The Bookmarks button is visible only when there is no user-supplied or nonplaceholder text in the search bar, because the Clear button is visible when there is text in the search bar that users might want to erase.
  • The Clear button. Most search bars include a Clear button that allows users to erase the contents of the search bar with one tap. (The Clear button is a gray circle with a white “x” in it.)
    When the search bar contains any nonplaceholder text, the Clear button is visible so users can erase the text. If there is no user-supplied or nonplaceholder text in the search bar, the Clear button is hidden because there is no need to erase the contents of the search bar.
  • The results list icon. This icon indicates the presence of search results. When users tap the results list icon, your app can display the results of their most recent search.
  • A descriptive title, called a prompt, that appears above the search bar. For example, a prompt can be a short phrase that provides introductory or application-specific context for the search bar.

Guidelines

Use a search bar to enable search in your application. Do not use a text field to enable search because it doesn’t have the standard search-bar appearance that users expect.
You can customize a search bar by specifying a custom background appearance and providing custom accessory images. For the background, you can supply a tint or an image, or you can choose one of the following standard background colors:
  • Blue (this is the default gradient that coordinates with the default appearance of toolbars and navigation bars)
  • Black
  • Black transparent
If you decide to supply a background image, it can be a good idea to supply a resizable image.

Segmented Control

A segmented control is a linear set of segments, each of which functions as a button that can display a different view.
image: ../Art/segmented_control.jpg

Appearance and Behavior

The length of a segmented control is determined by the number of its segments; the height of a segmented control is fixed. The width of each segment is proportional, based on the total number of segments. When users tap a segment, the segment displays a selected appearance.

Guidelines

Use a segmented control to offer closely related, but mutually exclusive choices. 

Make sure that each segment is easy to tap. To maintain a comfortable hit region of 44 x 44 points for each segment, you need to limit the number of segments. On iPhone, a segmented control should have five or fewer segments. 

As much as possible, maintain consistency in the size of each segment’s contents. Because all segments in a segmented control have equal width, it does not look good if the content fills some segments, but not others.

Avoid mixing text and images in a single segmented control. A segmented control can contain text or images. An individual segment can contain either text or an image, but not both. In general, it’s best to avoid putting text in some segments and images in other segments of a single segmented control.

If appropriate, customize the appearance of a segmented control. For example, you can supply a custom background tint or image. If you supply a background image, you can also specify a different background image to use for a segment’s selected appearance and a custom appearance for the dividers between segments. 

If you customize the background appearance of a segmented control, you should make sure that the automatic centering of the control’s text or image content still looks good. If necessary, you can use the bar metrics APIs to adjust the positioning of the content inside the segmented control .

Slider

A slider allows users to make adjustments to a value or process throughout a range of allowed values (shown here with custom images on the left and the right).
image: ../Art/slider.jpg

Appearance and Behavior

A slider consists of a track and a thumb (a circular control that the user can slide) and optional images that convey the meaning of the right and left values. When people drag the thumb along the slider, the value or process is updated continuously and is displayed in the track.

Guidelines

Use a slider to give users fine-grained control over values they can choose or the operation of the current process.
If appropriate, customize the appearance of a slider. For example, you can do any of the following:
  • Display a slider either horizontally or vertically.
  • Set the width of a slider to fit in with the UI of your app.
  • Define the appearance of the thumb, so that users can see at a glance whether the slider is active.
  • Supply images to appear at both ends of the slider to help users understand what the slider does.
    Typically, these custom images correspond to the minimum and maximum values of the value range that the slider controls. A slider that controls font size, for example, could display a very small character at the minimum end and a very large character at the maximum end.
  • Define a different appearance for the track, depending on which side of the thumb it is on and which state the control is in.

Stepper

A stepper increases or decreases a value by a constant amount.
image: ../Art/stepper.jpg

Appearance and Behavior

A stepper is a two-segment control in which one segment displays a plus symbol and the other segment displays a minus symbol. Users tap a segment to increase or decrease a value. A stepper does not display the value that the user changes.

Guidelines

In general, use a stepper when users might need to make small adjustments to a value. For example, it makes sense to use a stepper to set the number of copies in the Printer Options action sheet, because users rarely change this value by very much. On the other hand, it would not make sense to use a stepper to help users choose a page range, because those values can vary a lot.
Make it obvious which value the stepper affects. A stepper does not display any values, so you need to make sure that users know which value they’re changing when they use a stepper.

Switch

A switch presents two mutually exclusive choices or states (used in table views only).
image: ../Art/switch_on.jpg
image: ../Art/switch_off.jpg

Appearance and Behavior

A switch displays the value that is currently in effect; users slide the control to select (and reveal) the other value. Users can also tap the control to switch between choices.

Guidelines

Use a switch in a table row to give users two simple, diametrically opposed choices that determine the state of something, such as yes/no or on/off. Use a predictable pair of values so that users don’t have to slide the control to discover what the other value is.
You can use a switch control to change the state of other UI elements in the view. Depending on the choice users make, new list items might appear or disappear, or list items might become active or inactive.
If appropriate, customize the appearance of a switch. You can supply a tint for the on-state appearance that coordinates with the look of your app.

Text Field

A text field accepts a single line of user input (shown here with a purpose description and placeholder text).
image: ../Art/text_field.jpg

Appearance and Behavior

A text field is a fixed-height field with rounded corners. When users tap a text field a keyboard appears; when users tap Return in the keyboard, the text field handles the input in an application-specific way.

Guidelines

Use a text field to get a small amount of information from the user. Before you decide to use a text field, consider whether there are other controls that might make inputting the information easier, such as a picker or a list.
Customize a text field if it helps users understand how they should use it. For example, you can display custom images in the left or right sides of the text field, or add a system-provided button, such as the Bookmarks button. In general, you should use the left end of a text field to indicate its purpose and the right end to indicate the presence of additional features, such as bookmarks.
Display the Clear button in the right end of a text field when appropriate. When this element is present, tapping it clears the contents of the text field, regardless of any other image you might display over it.
Display a hint in the text field if it helps users understand its purpose, such as “Name” or “Address.” A text field can display such placeholder text when there is no other text in the field.
Specify different keyboard types to accommodate different types of content you expect users to enter. For example, you might want to make it easy for users to enter a URL, a PIN, or a phone number. Note, however, that you have no control over the keyboard’s input method and layout, which are determined by the user’s language settings. iOS provides several different keyboard types, each designed to facilitate a different type of input. 

System-Provided Buttons and Icons

To promote a consistent user experience (and to make your job easier) iOS provides numerous standard buttons for use in navigation bars and toolbars, and icons for use in tab bars.
You should familiarize yourself with the guidelines that govern the use of the system-provided buttons and icons regardless of the type of application you’re developing, so that you can:
  • Use the system-provided items correctly
  • Avoid designing a custom icon that looks too similar to a system-provided icon

If you can’t find a system-provided toolbar or navigation bar button or tab bar icon that has the appropriate meaning for a specific function in your app, you should design a custom button or icon. 

Standard Buttons for Use in Toolbars and Navigation Bars

iOS makes available many of the standard buttons users see in toolbars and navigation bars. These buttons, shown in Table 7-2, are available in two styles, each of which is appropriate for the specific usages described here:
  • Bordered style—For example, the Add button in the navigation bar of the Contacts app on iPhone uses bordered style. This style is suitable for both navigation bars and toolbars.
  • Plain style—For example, the Compose button in the Mail toolbar uses plain style. This style is suitable for toolbars only. In fact, if you specify the plain style for a button in the navigation bar, it is converted to the bordered style.
As with all system-provided buttons, you should avoid using the buttons described in Table 7-2 to represent actions other than those for which they are designed. In particular, avoid choosing a button based on its appearance, without regard for its documented meaning. For a discussion of the reasons why it’s important to use these icons correctly.




Table 7-2  Standard buttons available for toolbars and navigation bars (plain style)
ButtonNameMeaning
image: ../Art/UIButtonBarAction.jpgActionOpen an action sheet that allows users to take an application-specific action
image: ../Art/UIButtonBarCamera.jpgCameraOpen an action sheet that displays a photo picker in camera mode
image: ../Art/UIButtonBarCompose.jpgComposeOpen a new message view in edit mode
image: ../Art/UIButtonBarBookmarks.jpgBookmarksShow application-specific bookmarks
image: ../Art/UIButtonBarSearch.jpgSearchDisplay a search field
image: ../Art/UIButtonBarNew.jpgAddCreate a new item
image: ../Art/UIButtonBarTrash.jpgTrashDelete current item
image: ../Art/UIButtonBarOrganize.jpgOrganizeMove or route an item to a destination within the application, such as a folder
image: ../Art/UIButtonBarReply.jpgReplySend or route an item to another location
image: ../Art/UIButtonBarStop.jpgStopStop current process or task
image: ../Art/UIButtonBarRefresh.jpgRefreshRefresh contents (use only when necessary; otherwise, refresh automatically)
image: ../Art/UIButtonBarPlay.jpgPlayBegin media playback or slides
image: ../Art/UIButtonBarFastForward.jpgFastForwardFast forward through media playback or slides
image: ../Art/UIButtonBarPause.jpgPausePause media playback or slides (note that this implies context preservation)
image: ../Art/UIButtonBarRewind.jpgRewindMove backwards through media playback or slides
In addition to the buttons shown in Table 7-2, you can also use the system-provided Edit, Cancel, Save, Done, Redo, and Undo buttons shown in Table 7-3 to support editing or other types of content manipulation in your application.


Table 7-3  Bordered action buttons for use in navigation bars and toolbars
ButtonNameMeaning
image: ../Art/UIBarSystemItemEdit.jpgEditEnter an editing or content-manipulation mode
image: ../Art/UIBarSystemItemCancel.jpgCancelExit the editing or content-manipulation mode without saving changes
image: ../Art/UIBarSystemItemSave.jpgSaveSave changes and, if appropriate, exit the editing or content-manipulation mode
image: ../Art/UIBarSystemItemDone.jpgDoneExit the current mode and save changes, if any
image: ../Art/UIBarButtonSystemItemUndo.jpgUndoUndo the most recent action
image: ../Art/UIBarButtonSystemItemRedo.jpgRedoRedo the most recent undone action

The buttons listed in Table 7-3 are suitable for both navigation bars and toolbars, and are available in the bordered style only. If you specify the plain style for one of these buttons, it is converted to the bordered style.
In addition, you can use the system-provided page curl button in a toolbar . The page curl button is not available for use in a navigation bar.
image: ../Art/UIButtonBarPageCurl.jpg
The page curl button allows you to give users a way to curl up the bottom corner of a screen to see information underneath. For example, Maps allows people to lift the lower-right corner of a map view to access buttons that manipulate the map.
Don’t use the page curl button to flip the screen. If you need to flip the screen, use the Info button instead. Also, make sure that some of the curled-up page is still visible onscreen to emphasize the temporary nature of the action of flipping the screen. If the upper page disappears, the page curl becomes too much like a full-screen transition, and users lose their context.

Standard Icons for Use in Tab Bars

iOS provides the standard icons described in Table 7-4 for use in tab bars.
Table 7-4  Standard icons for use in the tabs of a tab bar
IconNameMeaning
image: ../Art/UITabBarBookmarks.jpgBookmarksShow application-specific bookmarks
image: ../Art/UITabBarContacts.jpgContactsShow contacts
image: ../Art/UITabBarDownloads.jpgDownloadsShow downloads
image: ../Art/UITabBarFavorites.jpgFavoritesShow user-determined favorites
image: ../Art/UITabBarFeatured.jpgFeaturedShow content featured by the application
image: ../Art/UITabBarHistory.jpgHistoryShow history of user actions
image: ../Art/UITabBarMore.jpgMoreShow additional tab bar items
image: ../Art/UITabBarMostRecent.jpgMostRecentShow the most recent item
image: ../Art/UITabBarMostViewed.jpgMostViewedShow items most popular with all users
image: ../Art/UITabBarRecents.jpgRecentsShow the items accessed by the user within an application-defined period
image: ../Art/UITabBarSearch.jpgSearchEnter a search mode
image: ../Art/UITabBarTopRated.jpgTopRatedShow the highest-rated items, as determined by the user

As with all standard buttons and icons, it’s essential to use the tab bar icons in accordance with their documented meanings. In particular, take care to base your usage of an icon on its semantic meaning, not its appearance. This will help your application’s user interface make sense even if the icon associated with a specific meaning changes its appearance.

Standard Buttons for Use in Table Rows and Other UI Elements

iOS provides the buttons described in Table 7-5 for use in table rows and other elements.
Table 7-5  Standard buttons for use in table rows and other UI elements
ButtonNameMeaning
image: ../Art/UIButtonTypeContactAdd.jpgContactAddDisplay a people picker to add a contact to an item.
image: ../Art/UIButtonTypeDetailDisclosure.jpgDetailDisclosureDisplay a new view that contains details about the current item.
image: ../Art/UIButtonTypeInfoDark.jpgInfoFlip to the back of the view to display configuration options or more information.
Note that the Info button is also available as a light-colored “i” in a dark circle.
These buttons should be used according to their defined meaning, as with all standard buttons and icons. In other words, avoid choosing a button based on its appearance, without regard for its documented meaning. For a discussion of the reasons why it’s important to use these buttons correctly.

Although the detail disclosure button is usually used in table rows, it can be used elsewhere.
Source: http://developer.apple.com/library/ios

No hay comentarios:

Publicar un comentario

Clima