How to use custom fonts with SwiftUI
Table of Contents
Fonts are no different than other assets like images. You can add and use a custom one in an iOS app.
The process is not hard, but it requires a few extra steps to make it work. Let's learn how to do it.
To use custom fonts with SwiftUI, you need to do the following steps.
Find a custom font to use in your app
To add a custom font, we need a font file. I will use Silkscreen font in this article.
Fonts are generally very expensive, and a license is also complicated. There are usually different licenses for desktop, printing, and mobile. Make sure you read them carefully and pick the right one that suits your need.
My go-to resource is Google Fonts. You can find many beautiful free licensed font families there.
Here are the two Silkscreen font styles I downloaded.
data:image/s3,"s3://crabby-images/f134e/f134e9654ebba35fde5357f849808daca277f6f9" alt="Silkscreen font."
You can easily support sarunw.com by checking out this sponsor.
data:image/s3,"s3://crabby-images/22163/22163fb948c69bda3a35dfb1ab736a7cd0f91b3b" alt="Translate your app In 1 click:"
Translate your app In 1 click: Simplifies app localization and helps you reach more users.
Adding a custom font to your app
There are two steps to adding a custom font to your iOS app.
Add the font file to your Xcode project
You can add custom fonts into an Xcode the same way you did with other assets. Nothing complicated in this first step.
- You can add them via menu by selecting File menu > Add Files to "Your Project Name..." from the menu bar, select all the fonts you need to add, then click the Add button.
data:image/s3,"s3://crabby-images/e3b52/e3b5227d1e0b716881fa46125ebc0e4088328542" alt="Add fonts from menu."
Or drag the file from Finder and drop it into your Xcode project.
data:image/s3,"s3://crabby-images/130de/130def56fa309eac92f00e13d8fbe102800692c2" alt="Add fonts by dragging."
- Ensure both Copy items if needed and Add to targets are checked.
data:image/s3,"s3://crabby-images/a0eee/a0eee29876f99a92f133e367157311870e2f766e" alt="Ensure both "Copy items if needed" and "Add to targets" are checked."
Register your font file with iOS
After you add a custom font to the project, you need to introduce them to iOS.
To do this:
- Navigate to Info.plist.
- After opening your Info.plist, add the key "Fonts provided by application".
data:image/s3,"s3://crabby-images/e6220/e622090714d5616a39ad3beefdb6bbc7e44f1cfd" alt="Add the key "Fonts provided by application""
- Add the name of all the fonts as items of the array. Be sure to include the file extension as part of the name.
data:image/s3,"s3://crabby-images/5d590/5d590f83a82a476e3c5b39bb801cc75c3932eab9" alt="Put all font files with extension as the content of the "Fonts provided by application" key."
You can easily support sarunw.com by checking out this sponsor.
data:image/s3,"s3://crabby-images/22163/22163fb948c69bda3a35dfb1ab736a7cd0f91b3b" alt="Translate your app In 1 click:"
Translate your app In 1 click: Simplifies app localization and helps you reach more users.
Use a custom font in SwiftUI
That's all you need to do to add a custom font to your SwiftUI app.
To use a custom font in SwiftUI, we initialize Font
with custom(_:size:)
static method.
Then we use it in a place where Font
is expected. In this example, I use a custom font on a Text
view.
VStack {
Text("Hello, world!")
.font(.custom("Silkscreen-Regular", size: 46))
Text("Hello, world!")
.font(.custom("Silkscreen-Bold", size: 46))
}
data:image/s3,"s3://crabby-images/e48dd/e48dd443c7a9065482b34a2d4456b220fa8f85af" alt="Use custom font in SwiftUI text view."
Read more article about SwiftUI, Font, or see all available topic
Enjoy the read?
If you enjoy this article, you can subscribe to the weekly newsletter.
Every Friday, you'll get a quick recap of all articles and tips posted on this site. No strings attached. Unsubscribe anytime.
Feel free to follow me on Twitter and ask your questions related to this post. Thanks for reading and see you next time.
If you enjoy my writing, please check out my Patreon https://www.patreon.com/sarunw and become my supporter. Sharing the article is also greatly appreciated.
Become a patron Buy me a coffee Tweet ShareWhat is the difference between List and ForEach in SwiftUI
Even though ForEach and List have similar syntax, they serve different purposes. Let's learn about their differences.
How to dismiss fullScreenCover in SwiftUI
SwiftUI has many ways to dismiss a modal view based on how you structure your view and the minimum iOS version you support.