Image and Graphics Best Practice
Image and Graphics Best Practice
WWDC 2018
Image Render Pipeline
data:image/s3,"s3://crabby-images/2a66c/2a66c464e3eafad8f8c1feb007276fff9cae7cec" alt=""
Image Buffers
data:image/s3,"s3://crabby-images/59b26/59b26904d7020ee03d53f3d5434bf5b598ac6c2d" alt=""
If you use the same image, the renderer will reuse the frame buffer.
data:image/s3,"s3://crabby-images/6d3b8/6d3b83fe747ea3c2793eccc2f2ea4e3babc223fb" alt=""
Pipeline in Action
data:image/s3,"s3://crabby-images/f9007/f90071d3db777b541cd146e0ffd5475c358ac80b" alt=""
data:image/s3,"s3://crabby-images/acb02/acb020ce19548526527593d623a5596a8489e986" alt=""
Downsampling (Solution) 👍
data:image/s3,"s3://crabby-images/74f98/74f980aa0d75ddc531bae19ea35c1099ae8cf93f" alt=""
data:image/s3,"s3://crabby-images/5a502/5a502f670f684b58edb6aee9078dfccf80cd34f5" alt=""
data:image/s3,"s3://crabby-images/3578e/3578e6bc7be71268e17a6c70838a91e8fb9314a2" alt=""
Decoding in Scrollable Views
Use the prefetching, background decoding / downsampling
data:image/s3,"s3://crabby-images/38d6d/38d6d44b7eeaa9487e784e4f126cb4a3a1193710" alt=""
Avoid thread explosion
data:image/s3,"s3://crabby-images/86684/866847d85e68f85f17e5ebfba2a67319ff4181fc" alt=""
Vector Artwork Pipeline
data:image/s3,"s3://crabby-images/72bc4/72bc4ca390bc1929e4fbfb9312e95f62fca1cf5c" alt=""
Vector Artwork Optimizations
- Xcode raterizes artwork for relevant scale factors while compiling.
- Prerasterized artwork used when image is drawn at natural size.
- If artwork has fixed sizes, use multiple image assets instead of relying on vector rasterization.
Custom Drawing vs UIImageView
- Do not override UIView.draw() when you make a customized view.
This is an very inefficient way. - Use UIImageView.draw() because ‘Decoded Image’ is better than ‘Backing store’
data:image/s3,"s3://crabby-images/22e69/22e6996e4f62178b0288e1c00cd31b1bacf6812a" alt=""
data:image/s3,"s3://crabby-images/1f45f/1f45fb29fd26b1240a455dec6a2f81f7090938bd" alt=""
Backing Store Memory Costs
- Proportional to pixel size of view
- Element size grows to accommodate color range used by drawing
- Setting CALayer.contentsFormat opts out
- Update layerWillDraw(_:) implementations
Reducing Backing Store Use
data:image/s3,"s3://crabby-images/1fe7e/1fe7ebdaaf2b4fea8a962a68bedf8be634125cfa" alt=""
Drawing Off-Screen
- Use UIGrahpicsImageRenderer to create and draw to an imag buffer
- Supports, Wide Color, unlike UIGraphicBeginContext( )
- Combine with UIImageView for efficient offscreen rendering
- Set prefersExtendedRange on UIGraphicsImageRendererFormat for direct control (new)
- UIImage.imageRendererFormat may offer an intermediate representation (new)
Advanced Image Effects
Core Image
- For realtime effects
- UIImageView renders CIImage efficiently. UIImage.init(ciImage: )
Interfacing with other frameworks
- CVPixelBuffer ( Data → Metal, Vision, Accelerate )
- Use the best initializer — don’t unwind work that’s already been done
- Guard against moving work GPU ↔ CPU
- Ensure buffers are correct format for Accelerate