Inside SwiftShot: Creating an AR Game
Inside SwiftShot: Creating an AR Game
WWDC 2018
SwiftShot Internals
- Establishing a shared coordinate space
- Networking and state sharing
- Physics
- Asset import and management
- Flag simulation
- Dynamic audio
ARKit — Establishing a shared Coordinate Space
- Image detection
- Object detection
- World Map sharing
- iBeacons for fixed installations
data:image/s3,"s3://crabby-images/2a8a4/2a8a44101954af82c257c8471f67955c57dbfaa1" alt=""
data:image/s3,"s3://crabby-images/4df02/4df02e1258577487eec47597aff24cc8b79bf9ba" alt=""
Sharing a World Map
1. Saving
- First device scans area, captures features
- Asks
ARSession
for world map - Serializes to dist
data:image/s3,"s3://crabby-images/b4f72/b4f72e13467268e13a105bee17b76a93f926f03f" alt=""
2. Ad-hoc gaming
Share over network
- Peer-to-peer network connnection
- Encrypt data in flight
- UI guidance to aid delocalization
3. Fixed installations
- Prerecord world maps for specific installation areas
- Distribute to managed devices
- Use iBeacons to automatically select correct world map for each location
4. Loading
data:image/s3,"s3://crabby-images/c4b41/c4b41ca8ba1097f4e6a05d662829b37cc1ab0fdb" alt=""
5. Privacy
ARWorldMap
uses features of the world around you
- No latitude/ longitude information
- May include personally identifiable information
Treat serialized ARWorldMap
as user-private data
- Encrypt at rest and in motion
- Obtain user consent for extended usage
6. ARAnchor
ARAnchor
represents a location and orientation in the physical world
- ARKit adds anchors for planes, objects, and images
- Also, created and added via API
data:image/s3,"s3://crabby-images/78f92/78f920a6e06cbf4081b2f2bca275932fcfff0d24" alt=""
data:image/s3,"s3://crabby-images/68d43/68d43efe5d408276e0d4295b25763793297461b4" alt=""
Networking with Multipeer Connectivity
- Peer-to-peer connectivity, no central server
- Encryption and authentication are built in
- Advertisement and discovery
- Device starting the game creates a session, starts advertising
- Other devices see session listed in menu
- User selects game to join
- Device sends request
- Advertising device accepts or denies - Once session set up, devices are peers in the network
- API to send
- Data packets
- Resources as URLs
- Streams - UDP for transport
data:image/s3,"s3://crabby-images/effad/effad603be29eb4ef2c9903d9e54535b5b6081b4" alt=""
data:image/s3,"s3://crabby-images/ee8eb/ee8ebbea917e6951cb3cf473bb76d726f917918e" alt=""
Physics
- SceneKit physics
- All peers run physics simulation
- Server sends updates to client to ensure synchronization
- Only game state relevant information is shared
- Object scaled approximately 10x for better performance
Physics Data Optimization
data:image/s3,"s3://crabby-images/1c4a5/1c4a5e7400e765823a8ecb7acc907f81dc2c3184" alt=""
data:image/s3,"s3://crabby-images/1cff6/1cff6635b188f2b45d691fed4757145df77689d2" alt=""
data:image/s3,"s3://crabby-images/1416d/1416dd9c41192c58562c6f9aef2a4816b3aac03c" alt=""
Encoding — BitStream
- Bit-packed encoding of values
- Minimum size, fast serialization and deserialization
- Purpose-built for network communications of binary data
- Not suitable for persistence
- Not robust in face of changing data scheme
data:image/s3,"s3://crabby-images/e9231/e9231edeb3000b9d95f7a956e8e642ae6333946c" alt=""
data:image/s3,"s3://crabby-images/7c7fb/7c7fb2ab90d65924947190455fafc6c23e6e2ed5" alt=""
data:image/s3,"s3://crabby-images/f4ed0/f4ed01b1a3da74f62a57a88c887e0722c7fc3e07" alt=""
data:image/s3,"s3://crabby-images/11af9/11af9c879141d05aafdfc0b16cdf619e367123e9" alt=""
data:image/s3,"s3://crabby-images/1c0db/1c0db681f2a9cd3343e2ffdb9dbc149016d838b7" alt=""
Combining Encodings
- Physics data encoded in BitStreams
- Other commands encoded with Swift Codable, binary property lists
data:image/s3,"s3://crabby-images/0f0c4/0f0c4443bee123ee88220fbbad67e00d1ee916f5" alt=""
Assets for Game Levels
Use level of detail to optimize for different distance
- Nearby objects get chamfered edges on blocks
- Distant objects get less detailed textures, fewer polygons
Physics bodies are the same
- Use predefined types (box, sphere, etc) wherever possible for performance
SceneKit
will build convex hull if not otherwise specified
data:image/s3,"s3://crabby-images/373e4/373e4f3c626d75299914ecdadf1effded7a6bac7" alt=""
Flag Simulation
- SceneKit static asset
- Swift class
- Build metal
- Apply results back to SceneKit model - Metal compute shader
- Computes forces in a mesh
- Produces vertices and shadows
data:image/s3,"s3://crabby-images/53c5a/53c5a419ede2adcf9f672efbc447fae6d7042e00" alt=""
Audio in SwiftShot
- Positions sounds in the world
- Limit app size
- Leverage MIDI instrument support from
AVFoundation
data:image/s3,"s3://crabby-images/06525/06525f33caed41086ba3fee38532d3738ea071a9" alt=""