Integrating Apps and Content with AR Quick Look
Integrating Apps and Content with AR Quick Look
WWDC 2018
What Is AR Quick Look?
- Preview 3D content in AR
- System-wide
- Uses Quick Look technology
- Available on iOS 12
data:image/s3,"s3://crabby-images/1a896/1a896bb8d9f12881c7272c5ab71704098c355cfd" alt=""
data:image/s3,"s3://crabby-images/deddf/deddf6b9eb490591611beb330f90686d32362445" alt=""
Developer Benefits
- No need to create your own
- Really easy to integrate
- Built-in AR Setup
- No understanding of AR technology required
‘usdz’ FIle
- New File format for distributing 3D models
- Packages a model and its textures into a single file
- Based on Pixar’s open-source USD format
- Supported on iOS and macOS
- used_converter tool in Xcode 1
AR Quick Look Integration
data:image/s3,"s3://crabby-images/152bd/152bd55804e92ed90599cf7f76f6b1e3d81f5bf8" alt=""
Quick Look Preview Flow
data:image/s3,"s3://crabby-images/eb34a/eb34a0635ab251824d2d1ae30fe9b1c1ee591516" alt=""
Previewing ‘usdz’ Objects Using Quick Look
data:image/s3,"s3://crabby-images/e3fa7/e3fa7985abfe896a7d6d64bd5487217fe5aeae00" alt=""
data:image/s3,"s3://crabby-images/c1d90/c1d90100853d65f488cc05ab664b18c9be8140b5" alt=""
data:image/s3,"s3://crabby-images/d855b/d855b4c59d3a04b8a2b4f8f6601ab2b4432edd95" alt=""
data:image/s3,"s3://crabby-images/fd8ff/fd8ffc3d02e49968c10e2622999b5e24868118da" alt=""
Previewing ‘usdz’ content in Safari
HTML markup
data:image/s3,"s3://crabby-images/6bbe7/6bbe78f72dbbe036b5c8f2c050476045bea8c97c" alt=""
Automatic badging
data:image/s3,"s3://crabby-images/a74a0/a74a092d0ddb8755167cd02d94eda37e7b344d52" alt=""
Provide custom thumbnail image
data:image/s3,"s3://crabby-images/c27df/c27dfb466672694a342101a54c7b665e1a5308bd" alt=""
Supports drag and drop
data:image/s3,"s3://crabby-images/6c5ed/6c5ed10d07fb6be9cba403e7ddf465d3d7fdc550" alt=""
Supports long-press
data:image/s3,"s3://crabby-images/5cf74/5cf74253de92da8baee8a5dfb6b6842b4408bcaf" alt=""
HTML Markup for Previewing ‘usdz’ Objects
<img> element
data:image/s3,"s3://crabby-images/59868/5986804b331dda3e1160b5694134068c876522ce" alt=""
<picture> element
data:image/s3,"s3://crabby-images/b8b40/b8b40ad641e82ce1efe82b18f9f043be6790cb43" alt=""
MIME type
data:image/s3,"s3://crabby-images/6741c/6741c4add2c7232229ab27429be314280ceecebd" alt=""
Creating 3D Models for AR Quick Look
Placement
- Place objects facing towards the camera (facing + z)
- Base of object should sit on the ground plane (y=0)
- Pivot point should be at the origin (x,y,z = 0)
data:image/s3,"s3://crabby-images/01765/01765bc8118110a2010f0cf026ad0f78491db198" alt=""
Physical Size
data:image/s3,"s3://crabby-images/44912/4491281e81bec3cc23ca2e23bb9e64ef718a876d" alt=""
Animation
- Provide an “idle” animation to add life to the object
- Animations always loop
- Animations can be a mix of skeletal animation and transform animation
data:image/s3,"s3://crabby-images/37814/37814c4dba14558137f8ebbf75d22085e901019a" alt=""
Animation Tips
- Choose animations that enhance AR immersiveness
- Don’t animate objects away from the origin
- Keep a consistent bounding box throughout an animation
- Prefer animations that make sense at a static location
- Or create animations as self-contained scenes
data:image/s3,"s3://crabby-images/853d7/853d725f602c2399da254f3a73a847232519f45c" alt=""
Contact Shadow
- AR Quick Look provides a contact shadow for you
- Can turn the shadow on / off
- Can apply ambient lighting conditions - Don’t bake a contact shadow into the model
- First animation frame is used for shadow creation
Model Appearance
Albedo (base color)
data:image/s3,"s3://crabby-images/de85c/de85cfde5d39e25869a9b72913b65ca091de08d9" alt=""
Metallic (conductor or insulator)
data:image/s3,"s3://crabby-images/75c2c/75c2c0007279e104c682f611a00914854b341493" alt=""
Roughness (rough or shiny)
data:image/s3,"s3://crabby-images/c05fd/c05fde38cf9a21f685c3399825bbe8f5c8e17ce9" alt=""
Normal (surface details)
data:image/s3,"s3://crabby-images/48437/484379a37d0c6041ee9a468cc25bc03fb4867fbf" alt=""
Ambient occlusion (internal shadows)
data:image/s3,"s3://crabby-images/304c1/304c1bbbfa1ee324651c5f72eba45d4645140378" alt=""
Emissive (emits light)
data:image/s3,"s3://crabby-images/c1383/c13834149140edc62b30a253892e840476715f5e" alt=""
Transparency
- Use a separate material for transparent and non-transparent parts of the model
- Provide an albedo texture with transparency in its alpha channel
- Use transparency for see-through areas, not for cutouts
data:image/s3,"s3://crabby-images/65418/654185222d4b929459546e0666e1599817c57ede" alt=""
Texture Formats
!! Texture should be square powers of 2 (2048, 1024, 512 …) !!
- Albedo (RGB/RGBA)
- Metallic (Grayscale)
- Roughness (Grayscale)
- Normal (RGB)
- Ambient occlusion (Grayscale)
- Emissive (RGB)
Supporting All Devices
- System-wide extension that shares system memory with applications
- Optimize and test your models for high-memory devices
- iPhone 7+, iPhone 8+, iPhone X
- iPad Pro 12.9' - AR Quick Look will dynamically downsample textures for other devices when needed
- Meshes and animations are not modified
Size Limits
- Many factors affect a model’s memory requirements
- Mesh, animations complexity, Texture size & count - As a guide, for a model with a single PBR material
- 100k polygons
- One set of 2048 x 2048 PBR textures
- Ten seconds of animation - Always test your model on a real device
Optimizing Models
- Freeze transforms and merge adjacent vertices
- If possible, use a single material/texture set for the entire model
- Don’t include textures you don’t need
- Spend your texture budget on ares that add most value and realism
- Remember that pixels have a physical size in AR
- Balance texture size and quality against download size
‘usdz’ Converter
- Command line tool to convert 3D models to .usdz format
- Ships with Xcode 10
- Maps PBR textures to meshes and submeshes
- Input format
- OBJ file
- Single-frame Alembic (ABC) file
- USD file (.usda, .usdc)
data:image/s3,"s3://crabby-images/59d6d/59d6d5e5e2f44cf6f531a5ad4108fffbb6830fa3" alt=""
Anatomy of a ‘usdz’ File
- .usdz file is an uncompressed zip archive
- First file in the archive is a .usdc file (model, animation, material)
- Remaining files (if needed) are image files
data:image/s3,"s3://crabby-images/d8ee3/d8ee3ccc4d1607215889806dcf09b8f2fc73c48c" alt=""
Sample
data:image/s3,"s3://crabby-images/b0a9a/b0a9a8f1f8051c8615c151570cec178cbc66bdb9" alt=""