Apple allows us to customize the SFSymbols with different rendering modes. Here is a little cheatsheet explaining how to use rendering modes and how to customize them.
Automatic
This mode is used when we don't explicitly specify any rendering mode:
Image(systemName: "shareplay")
.foregroundStyle(.white)
Every SFSymbol has preferred rendering mode, and when we use automatic mode each symbol will decide how to render itself.
data:image/s3,"s3://crabby-images/264b8/264b829e1dad9f7992a9d7b66b3df37a8ba496a0" alt=""
We can also explicitly set automatic rendering mode by passing nil
to the `symbolRenderingMode(_)` function:
Image(systemName: "shareplay")
.symbolRenderingMode(nil)
.foregroundStyle(.white)
Monochrome
This mode renders SFSymbol as a flat layer filled with the foreground style:
Image(systemName: "speaker.wave.2.circle.fill")
.symbolRenderingMode(.monochrome)
.foregroundStyle(.white)
data:image/s3,"s3://crabby-images/bc1b5/bc1b547b72dfbdef51f44c262e28d20b0f4bfadc" alt=""
Hierarchical
This mode renders SFSymbol as multiple layers, where each layer has a different opacity applied to the foreground style:
Image(systemName: "person.3.sequence.fill")
.symbolRenderingMode(.hierarchical)
.foregroundStyle(.white)
data:image/s3,"s3://crabby-images/ea111/ea111a151b67ec495a34bef8195ad86256057db0" alt=""
Palette
This mode renders SFSymbol as multiple layers, with different foreground styles applied to the layers:
Image(systemName: "person.3.sequence.fill")
.symbolRenderingMode(.palette)
.foregroundStyle(.white, .teal, .green)
data:image/s3,"s3://crabby-images/2e1bf/2e1bfcfe9cd6fd0ac53b1617a7a2c5b616e2380b" alt=""
Multicolor
In this mode supported SFSymbols are rendered as colored layers where colors are defined by the symbols themselves:
Image(systemName: "cloud.sun.rain.fill")
.symbolRenderingMode(.multicolor)
data:image/s3,"s3://crabby-images/11d9c/11d9c156bff6a9e690520b95f101a9e6b0421ceb" alt=""
This is it. If you want to know more details about SFSymbols rendering modes I recommend watching What's new in SF Symbols 4 video from WWDC 2022.
Comments
Anything interesting to share? Write a comment.