iOS already features a system-wide translation function that permits customers to simply translate textual content into numerous languages. With the discharge of iOS 17.4 (and iOS 18), now you can leverage the brand new Translation API to combine this highly effective translation functionality into your apps.
Apple gives two choices for builders to make the most of the Translation API. The quickest and easiest technique is to make use of the .translationPresentation
modifier, which shows a translation overlay in your app. For a extra versatile answer, you’ll be able to straight name the Translation API to construct a customized translation function.
On this tutorial, we are going to discover each approaches and information you thru their implementation utilizing a SwiftUI demo app. Please be aware that you’ll want Xcode 16 to observe alongside.
Utilizing the translationPresentation Modifier
Let’s begin with the simple strategy: the .translationPresentation
modifier. In Safari, customers can spotlight any textual content to entry the interpretation choice, which then shows a translation overlay with the translated textual content.
data:image/s3,"s3://crabby-images/a059b/a059b4404e9d4bfa13814bdce338bc9a50d7394c" alt=""
If you wish to deliver this translation overlay to your app, all you want is to import the Translation package deal and use the .translationPresentation modifier. Check out the next pattern code:
import SwiftUI
import Translation
struct ContentView: View {
@State personal var showTranslation = false
@State personal var sampleText = article
var physique: some View {
VStack {
Textual content(sampleText)
.font(.system(.physique, design: .rounded))
Button("Translate") {
showTranslation.toggle()
}
.controlSize(.extraLarge)
.buttonStyle(.borderedProminent)
}
.padding()
.translationPresentation(isPresented: $showTranslation, textual content: article)
}
}
The app shows some pattern textual content in English with a Translate button positioned beneath it.
data:image/s3,"s3://crabby-images/3f8fe/3f8fe2a6a3d2daa8ffd8d9d5379a74f55993bcc6" alt=""
Now, whenever you faucet the “Translate” button, a translation overlay seems, displaying the translated textual content in your required language. Apart from iOS, the Translation API additionally works on each iPadOS and macOS. At the moment, this translation function can’t be examined in Xcode Preview; you need to deploy the app onto an actual machine for testing.
data:image/s3,"s3://crabby-images/ca6c7/ca6c79fd24e0c99636634d0e5d0394017ca1abd8" alt=""
The .translationPresentation modifier lets you specify an non-compulsory motion to be carried out when customers faucet the “Change with Translation” button. For example, if you wish to exchange the unique textual content with the translated textual content when the button is tapped, you’ll be able to outline this motion like this:
.translationPresentation(isPresented: $showTranslation, textual content: article) { translatedText in
sampleText = translatedText
}
When you specify the motion within the modifier, you will note the “Change with Translation” choice within the translation overlay.
data:image/s3,"s3://crabby-images/eeb09/eeb090579afc6d76914d91902ae8331392d16ba3" alt=""
Working with the Translation API
For higher management over translations, you should utilize the Translation API straight as a substitute of counting on the interpretation overlay. For example, in case your app shows an inventory of article excerpts and also you wish to supply translation help, the interpretation overlay may not be perfect as a result of customers must choose every excerpt individually for translation.
data:image/s3,"s3://crabby-images/f01de/f01de16febe84084fa15be451e7458392d83e5ae" alt=""
A extra environment friendly answer is to carry out a batch translation of all of the article excerpts when customers faucet the “Translate” button. Let’s create a easy demo to see tips on how to work with the Translation API and deal with batch translations.
Beneath is the pattern code for creating the UI above:
struct BatchTranslationDemo: View {
@State personal var articles = sampleArticles
var physique: some View {
NavigationStack {
Record(articles) { article in
VStack {
Textual content(article.textual content)
if article.translatedText != "" {
Textual content(article.translatedText)
.body(maxWidth: .infinity, alignment: .main)
.padding()
.background(Coloration(.systemGray4))
}
}
}
.listStyle(.plain)
.toolbar {
Button {
} label: {
Label("Translate", systemImage: "translate")
.labelStyle(.iconOnly)
}
}
}
}
}
To carry out a batch translation, you first have to outline a translation configuration that specifies each supply and goal languages. Within the code, you’ll be able to declare a state variable to carry the configuration like beneath:
@State personal var configuration: TranslationSession.Configuration?
After which, within the closure of the toolbar’s Button, we are able to instantiate the configuration:
Button {
if configuration == nil {
configuration = TranslationSession.Configuration(supply: .init(identifier: "en-US"), goal: .init(identifier: "zh-Hant-TW"))
return
}
configuration?.invalidate()
} label: {
Label("Translate", systemImage: "translate")
.labelStyle(.iconOnly)
}
We specify English because the supply language and Conventional Chinese language because the goal language. If you don’t specify the languages, the Translation API will routinely create a default configuration, with iOS figuring out the supply and goal languages for you.
To carry out translation, you connect the .translationTask
modifier to the checklist view:
Record(articles) { article in
.
.
.
}
.translationTask(configuration) { session in
let requests = articles.map { TranslationSession.Request(sourceText: $0.textual content, clientIdentifier: $0.id.uuidString) }
if let responses = strive? await session.translations(from: requests) {
responses.forEach { response in
updateTranslation(response: response)
}
}
}
This modifier initiates a translation job utilizing the desired configuration. Every time the configuration adjustments and isn’t nil
, the interpretation job is executed. Throughout the closure, we put together a set of translation requests and use the session’s translations(from:)
technique to carry out a batch translation.
If the interpretation job succeeds, it returns an array of translation responses containing the translated textual content. We then move this translated textual content to the updateTranslation
technique to show it on display screen.
func updateTranslation(response: TranslationSession.Response) {
guard let index = articles.firstIndex(the place: { $0.id.uuidString == response.clientIdentifier }) else {
return
}
articles[index].translatedText = response.targetText
}
Let’s deploy the app to an actual machine for testing. I examined the app on my iPad Air. While you faucet the “Translate” button, the app ought to show extra article excerpts in Conventional Chinese language.
data:image/s3,"s3://crabby-images/b7522/b75223a66b6c73c8374dbb2f20ad041a73e76c9a" alt=""
Abstract
With the brand new Translation API launched in iOS 17.4 (and iOS 18), builders can now simply combine highly effective translation options into their apps. This tutorial covers two major strategies for using the API: the straightforward strategy utilizing the .translationPresentation
modifier for displaying a translation overlay, and a extra versatile strategy utilizing the Translation API straight for customized translation options.
We reveal each approaches on this tutorial. As illustrated within the demo, you’ll be able to simply add translation capabilities with only a few strains of code. Given the simplicity and energy of this API, there’s no motive to not embody translation performance in your apps.