With just a raise of the wrist, users can receive and respond to notifications, see essential information in a complication, and much more. Developing for Apple Watch means providing your users with important, helpful, and impactful information in the most immediate, convenient way.
The projects you create for Apple Watch consist of two related bundles: a Watch app bundle and a WatchKit extension bundle. The Watch app bundle contains the storyboards and resource files associated with all of your app’s user interfaces. The WatchKit extension bundle lives inside the Watch app bundle and contains the code for managing those interfaces and for responding to user interactions. (The two bundles are known collectively as the Watch app.) You distribute the Watch app inside your iOS app bundle, but iOS copies your app to the user’s Apple Watch, where it runs locally.
The Watch app is the core of your watchOS project, and provides your app’s main interface, but it is not the only thing that users see. Watch apps can also provide custom notification and complication interfaces. These interfaces present your app content in distinct and separate ways, but are packaged as part of the Watch app itself. Specifically, the code for managing notification and complication interfaces is in your WatchKit extension and the storyboard scenes are part of the main storyboard in your Watch app bundle. Although optional, notifications and complications are an important way to communicate with users and are often the interfaces used most by users.
The Watch app is what the user launches from the Apple Watch Home screen. The Watch app presents your app’s full user interface, which can include multiple screens of custom content and support sophisticated user interactions. Use the Watch app to present all of the content you support on Apple Watch.
Complications are small visual elements on the watch face that communicate important information to the user. The term complication comes from watch making, where the addition of features added complexity to the watch construction. Complications are visible whenever the user looks at the watch face, and users can customize which complications are displayed. The number of slots available for complications on a given watch face varies, but most support at least two or three complications.
Complications let you show important information in a frequently viewed location, making your app more visible to the user.
When your complication is on the watch face, your app stays in memory, which reduces the amount of time it takes to launch your app.
When your complication is on the watch face, your app receives more time to execute background tasks, as described in Background Tasks.
Apple recommends that all Watch apps include a complication, even if that complication only acts as a button to launch the app. For information about complications and how to implement them, see Complication Essentials.
Apple Watch presents local and remote notifications using a distinct set of interfaces. When a notification first arrives, Apple Watch displays a minimal interface called a short look, which provides a glanceable version of the notification content. If the user’s wrist remains raised, the minimal interface changes to a more detailed interface called a long look.
You can customize the long look interface of your Watch app to incorporate custom graphics, dynamic content, and additional information. Providing a custom interface lets you incorporate branding and other elements that are familiar to users of your app. You can even provide different interfaces for different types of notifications, focusing each interface on the most important aspects of the notification.
In watchOS, you use the User Notifications framework to schedule and handle notifications directly from your WatchKit extension. This framework supports the creation of time-based and location-based local notifications. You also use it to configure your app’s actionable notifications and to handle local and remote notifications delivered to Apple Watch.
For information on how watchOS handles notifications, and information about how to add notification interfaces to your Watch app, see Notification Essentials. For more information about how to schedule and handle local and remote notifications, see Local and Remote Notification Programming Guide.
The personal nature of Apple Watch requires a different approach when it comes to designing Watch app, notification, and complication interfaces. Your interfaces need to display information quickly and facilitate fast navigation and interactions. Creating that kind of interface means you should not simply port your existing iOS app behavior over to Apple Watch. Instead, make the experience of using your Watch app complementary to the experience of your iOS app.
As part of creating a great user experience, understand that the Watch app, notifications, and complications each have their own unique role. Complications provide access to information directly from the watch face, but space for that information is limited and you must carefully choose what information to show. Notifications keep users informed about recent events, giving you a way to communicate with users even when your app is not running. Watch apps provide a richer experience by letting you present more content and interact with the user, but those interactions must be quick and intuitive to keep users engaged.