Creating Audio Apps for watchOS
Creating Audio Apps for watchOS
WWDC 2018
Native Controls
data:image/s3,"s3://crabby-images/1bdb5/1bdb55384c132fbe3692704273520428d2f69fd6" alt=""
Now playing view
- Digital Crown controls volume
- Place in non-scrolling controller
- Automatically switches source
- Application tint color
data:image/s3,"s3://crabby-images/e2633/e263328d293cb2823ec4eb930ff0ad6af8263089" alt=""
data:image/s3,"s3://crabby-images/8a590/8a590e8dc51d5f0aa98dddd2be78c4fd6e1fc2d2" alt=""
data:image/s3,"s3://crabby-images/cce6a/cce6aa27c4dfda7dab461ecc693b2766f31b4160" alt=""
Volume control
- Controls iPhone or local volume ( Watch )
data:image/s3,"s3://crabby-images/4f99f/4f99f19d557fbc01753cfa22104f50767e02c1f3" alt=""
- Application tint color
data:image/s3,"s3://crabby-images/d9189/d91895f6ccb159666bf0ec5f07838d967d9bb360" alt=""
Getting Content
data:image/s3,"s3://crabby-images/bbcd1/bbcd17b230e9e215fca01bcb0d5cd321042ba34e" alt=""
data:image/s3,"s3://crabby-images/8bc39/8bc39809df5e988a494308aca999f1b04be1f69a" alt=""
data:image/s3,"s3://crabby-images/07c93/07c93054b8bdd3d89f3aee54cb81fc4e5ff6a9df" alt=""
WatchConnectivity
The content might already exist on iPhone.
We can just use watchConnectivity and transfer the file directly over to the Watch
- Transfer file API
- Progress
- Sample Link
data:image/s3,"s3://crabby-images/dda3b/dda3b4dfdfad1e8cbcfab43fc676d57207437337" alt=""
data:image/s3,"s3://crabby-images/ac7fa/ac7fa97efa11e4b2de4125bf91d3949c0b0fb931" alt=""
data:image/s3,"s3://crabby-images/8b8e8/8b8e8a6c44d8237c25cee9f8561915e6f012a07a" alt=""
Which one do we use ?
- URLSession
- User initiated on Apple Watch
- UsewaitsForConnectivity
instead of SCNetworkReachability
- Requests are proxied through iPhone, when in range - WatchConnectivity
- Initiated on iPhone
- No need to request from your server again
Set Expectations
- Instruct your user
- On the magnetic charger
data:image/s3,"s3://crabby-images/7f353/7f3533fa93e2c49a85099d5cb3c792099471401d" alt=""
WatchKit
presentMediaPlayerController(with: option: completion: )
data:image/s3,"s3://crabby-images/e4a64/e4a64a422ae91063c047a9c2291193ab70179048" alt=""
- WKAudioFileQueuePlayer
- WKAudioFilePlayerItem
data:image/s3,"s3://crabby-images/76b1b/76b1b348755c61c42c4f74ca7e2e0f382c72d502" alt=""
AVFoundation
- AVAudioPlayer
- AVAudioEngine
- Playback
- Background run mode (new)
- Foreground, screen on - Formats supported
- AAC-LC, AAC-ELD, HE-AAC, HE-AACv2, MP3 (decoding only), Opus
Background Playback ( new )
- AVFoundation
- Route picking
- MediaPayer.framework
- Restricted to Bluetooth routes just like Music, Podcasts, and Radio
data:image/s3,"s3://crabby-images/91057/91057042d478178b1747790c7173ff926791c151" alt=""
data:image/s3,"s3://crabby-images/a7226/a722629f3a8581d0ed20f19c661adbce9295729f" alt=""
Local Playback
- Set
routeSharingPolicy
tolongForm
on AVAudioSession - Call new
activate(withOptions: completion: )
method on AVAudioSession
- On completion, callplay()
data:image/s3,"s3://crabby-images/cab36/cab363b5a97893693c801bbdc20797cc8abb98cd" alt=""
Route Picker
- Apple wireless chip, W1
- Bluetooth headphones
- If user has an active route, the route picker will select that automatically on your behalf
- Takes active W1 route from iPhone (Unless iPhone has more priority )
- If no active routes, route picker will appear
data:image/s3,"s3://crabby-images/691be/691bef9e7e53723c816fbc1d25c7f607507a8232" alt=""
data:image/s3,"s3://crabby-images/7cfda/7cfda835f3d4c449151b455f707a2fa57062a92e" alt=""
data:image/s3,"s3://crabby-images/e34a7/e34a774718b89a74e999477224a06d2c29bb4008" alt=""
Power
- Only play audio when necessary
- AVAudioEngine
- autoShutdownEnabled on by default
MediaPlayer.framework
- Provide Now Playing information
- Now Playing UI will update
- Handles events
data:image/s3,"s3://crabby-images/d1f3b/d1f3bb3809408fa1131a9500e8cfb34e0ea0fcc6" alt=""
data:image/s3,"s3://crabby-images/5d7c8/5d7c861a41510bbfb08a2280b7cd17f2d4339280" alt=""
Media remote
- Use MediaPlayer.framework
- Handle commands however you wish
- Sample Link
data:image/s3,"s3://crabby-images/8e115/8e1150246c8814b1f3034bd8c4c4416fc6b02533" alt=""
data:image/s3,"s3://crabby-images/f9875/f98751fb1d1dddfd5d59d94b43d4edfcc2935291" alt=""
data:image/s3,"s3://crabby-images/4f01e/4f01ed40c54cab49b889e6b678e51c7e711d9cc2" alt=""
Audio Experience
- Auto launch
- Frontmost App state
- Notifications
- Shortcuts
Auto Launch
- Auto launch Audio Apps
- Now Playing session on iPhone brings Apple Watch app frontmost
- Stays frontmost for duration of the session
data:image/s3,"s3://crabby-images/200ce/200ce7148f2b25d6a01698d8fac2ea606c7b8ffe" alt=""
Now Playing session API
- You will know when you’re launched for a Now Playing session on iPhone
- Take your user directly to the view
- Use
handleRemoteNowPlayingActivity()
on WKExtensionDelegate
data:image/s3,"s3://crabby-images/159b3/159b39af2f87a1632a6f869cfaf0020bab39892f" alt=""
Opt out
- App can opt out
- Do the right thing
- Info.plist key
- Now Playing app will show if you have opted out
Frontmost App State
- WatchConnectivity resumes
- URLSession resumes
- Frontmost notification
- Haptics
- Kept frontmost while playing audio
- User navigates away
- Background playback still occurs - Properly handle background events
- The Life of a watchOS App ( WWDC 2017 )
data:image/s3,"s3://crabby-images/a5962/a5962042821ae9a901e452c17384aacf7e628f9c" alt=""
Notifications
- Content available local notification
- Play option as the primary action
- Configuration step
- What’s New in watchOS ( WWDC 2018 )
data:image/s3,"s3://crabby-images/ed72d/ed72d6a8f1e181316bc69722a5b038eac113e60a" alt=""
data:image/s3,"s3://crabby-images/97e38/97e3841e46ceb41c7127618b16d205bc28823dd1" alt=""
Frontmost notifications
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void)
- Play haptic
Shortcuts
- Donate
INMediaPlaybackIntent
data:image/s3,"s3://crabby-images/040a6/040a68fa1b52d96b791e258993eef8e9e16f3c52" alt=""
- Relevant shortcut API
data:image/s3,"s3://crabby-images/bf1e5/bf1e5d643fe0c5fef36520c0a4c410639427338d" alt=""
- Shortcut phrase
data:image/s3,"s3://crabby-images/0f7c7/0f7c74b62fc8b2f8281baeb8bd3671363109a179" alt=""