CarPlay Audio and Navigation Apps
CarPlay Audio and Navigation Apps
WWDC 2018
What’s Special About CarPlay ?
- Touch screens, rotary knob, and touchpad inputs
- Left and right hand drive
- Night interface style
- Screen sizes
- Automaker
data:image/s3,"s3://crabby-images/b60a5/b60a5de36e04c847094fa929293613072298d5de" alt=""
- Messaging
data:image/s3,"s3://crabby-images/12205/12205cdda29248016b444f789adef689a55f801d" alt=""
- VoIP calling
- Audio ( new )
data:image/s3,"s3://crabby-images/b5e47/b5e47cfaaa880bcd8c5064e93a8417fa0dc66426" alt=""
- Navigation ( new )
data:image/s3,"s3://crabby-images/0769a/0769a7ac6368fadadb42c1b384d5fd53926077e5" alt=""
Audio Apps in CarPlay
- Template based
- Works with all CarPlay systems
- Uses existing MediaPlayer APIs
CarPlay Audio App APIs
MPPlayableContent
data:image/s3,"s3://crabby-images/d6f3b/d6f3b14d632ebf06efe4bb7ea603689f200b561a" alt=""
data:image/s3,"s3://crabby-images/5f180/5f180367d1b09b695d0e24dab21fabe96ea2b8ab" alt=""
Improvements in iOS 12 ( new )
- Improved performance in
MPPlayableContent
- Faster startup sequence
- Smoother animations
- Better communication to your app
Best Practices
- Call
reloadData()
only when needed ⚠️ - Use
beginUpdates( )
andendUpdate( )
- Keep an internal representation of the data source to optimize performance
Don’t Miss a Beat ! ⚠️
Account for these common scenarios
- Screen locked with passcode
- Unreliable network connectivity
data:image/s3,"s3://crabby-images/39554/395541835e146397eca08de25d3f81e74827cbea" alt=""
Anticipate the Hits
Utilize beginLoadingChildItems( )
to initiate fetching content
data:image/s3,"s3://crabby-images/49721/49721895c6a813dee66b7cb86cc5d820a19c9423" alt=""
data:image/s3,"s3://crabby-images/a11c7/a11c7ba38d2ff9b43aa619623b33b64347c0cc97" alt=""
Greatest Hits
- Use
MPPlayableContent
to populate the CarPlay screen - Anticipate user scenarios while driving
- Run your audio apps in CarPlay!
Navigation Apps in CarPlay
- Built with CarPlay framework
- Template based
- Supports all CarPlay systems
data:image/s3,"s3://crabby-images/f6e8d/f6e8d46930946255f8d345d1f4424a4c3699d832" alt=""
Map Template
Key responsibilities
- Panning
- Navigation Alerts
data:image/s3,"s3://crabby-images/07ce0/07ce06781a34c0c28d4f14be1b53e3af550709d8" alt=""
- Guidance
data:image/s3,"s3://crabby-images/5832a/5832a133ec8d33295f3c35aa9386f854b2f2c015" alt=""
data:image/s3,"s3://crabby-images/06b40/06b40f428e8bbcfd13d082b8d1595ae2929c1288" alt=""
data:image/s3,"s3://crabby-images/67adc/67adc4b600e01326406dae1db8deb8a92c2a7861" alt=""
data:image/s3,"s3://crabby-images/c32c1/c32c11c09724b41e46c8971f209c2769434ece37" alt=""
data:image/s3,"s3://crabby-images/55682/55682b6f23a7aa1a2caba51f94b03212e7dc9613" alt=""
data:image/s3,"s3://crabby-images/5bd38/5bd38756559a549c24e74ef0d504700e45944076" alt=""
data:image/s3,"s3://crabby-images/6e0e5/6e0e5376cdc3a59e98d0752e9d06560a25a76853" alt=""
data:image/s3,"s3://crabby-images/f1ea6/f1ea69ab73b47e84beb6ddf218748e04de7267cb" alt=""
Guidance
data:image/s3,"s3://crabby-images/63d6d/63d6d5cb024ee5cf4baf07dadcc51ea840eec6fa" alt=""
data:image/s3,"s3://crabby-images/5405b/5405b0976c3775ff906ad4034d9cc31f638cde42" alt=""
Route Preview
Class and methods
data:image/s3,"s3://crabby-images/56730/567307f28c00690ce54e50ce604149b195e6125b" alt=""
data:image/s3,"s3://crabby-images/93b4e/93b4eedccb2d233e931c4cf269c48ce67737a6bf" alt=""
Guidance
- Classes and method
data:image/s3,"s3://crabby-images/ca130/ca13072d94b093ebba3c7c6eecd754ad8da36f40" alt=""
data:image/s3,"s3://crabby-images/eb8f6/eb8f65bf5224f05f8373276ba5267b82461960ae" alt=""
- What happens next ?
- Set upcoming maneuvers and travel estimates
- Set pause reason
- Navigation alerts
- End Navigation
Notifications
data:image/s3,"s3://crabby-images/0f23a/0f23a1a7ee752e951275f65ccc729598c2fa9446" alt=""
data:image/s3,"s3://crabby-images/fef8b/fef8b5f3fe83ae81f7302a8cd900778f910344d9" alt=""
Demo
data:image/s3,"s3://crabby-images/7cd39/7cd391e48d5700d624d318261eaca10672419462" alt=""
data:image/s3,"s3://crabby-images/2a9e3/2a9e310139a9f6f5b3b3ff9b14cfa65b3df48a3b" alt=""
data:image/s3,"s3://crabby-images/93b4e/93b4eedccb2d233e931c4cf269c48ce67737a6bf" alt=""