NEW: Start my new Ultimate Portfolio App course with a free Hacking with Swift+ trial! >>

How to insert images into text

Paul Hudson    @twostraws   

Updated for Xcode 12.0

SwiftUI lets you combine text views using +, but you can also place images directly into text using a simple Text initializer. This allows you to place images directly inside text, including having the text wrap as needed.

For example, this writes “Hello World” with a star image in the middle:

Text("Hello ") + Text(Image(systemName: "star")) + Text(" World!")

The images inside your text will automatically adjust to match whatever font or foreground color you’ve chosen, but make sure you apply your modifiers to the whole joined text rather than simply the last item.

For example, this will make the whole combined text large and blue:

(Text("Hello ") + Text(Image(systemName: "star")) + Text(" World!"))
    .foregroundColor(.blue)
    .font(.largeTitle)

Whereas this – without the extra parentheses – will make only the “World” text large and blue:

Text("Hello ") + Text(Image(systemName: "star")) + Text(" World!")
    .foregroundColor(.blue)
    .font(.largeTitle)

Subscribe to Hacking with Swift+

Sponsor Hacking with Swift and reach the world's largest Swift community!

Similar solutions…

BUY OUR BOOKS
Buy Pro Swift Buy Swift Design Patterns Buy Testing Swift Buy Hacking with iOS Buy Swift Coding Challenges Buy Swift on Sundays Volume One Buy Server-Side Swift (Vapor Edition) Buy Advanced iOS Volume One Buy Advanced iOS Volume Two Buy Advanced iOS Volume Three Buy Hacking with watchOS Buy Hacking with tvOS Buy Hacking with macOS Buy Dive Into SpriteKit Buy Swift in Sixty Seconds Buy Objective-C for Swift Developers Buy Server-Side Swift (Kitura Edition) Buy Beyond Code

Was this page useful? Let us know!

Average rating: 3.7/5

Link copied to your pasteboard.