Amplify has re-imagined the way frontend developers build fullstack applications. Develop and deploy without the hassle.

Page updated Apr 29, 2024

Translate language

Amplify iOS v1 is now in Maintenance Mode until May 31st, 2024. This means that we will continue to include updates to ensure compatibility with backend services and security. No new features will be introduced in v1.

Please use the latest version (v2) of Amplify Library for Swift to get started.

If you are currently using v1, follow these instructions to upgrade to v2.

Amplify libraries should be used for all new cloud connected applications. If you are currently using the AWS Mobile SDK for iOS, you can access the documentation here.

If you haven't already done so, run amplify init inside your project and then amplify add auth (we recommend selecting the default configuration).

Run amplify add predictions, then use the following answers:

? Please select from one of the categories below
Identify
❯ Convert
Interpret
Infer
Learn More
? What would you like to convert? (Use arrow keys)
❯ Translate text into a different language
Generate speech audio from text
Transcribe text from audio
? Provide a friendly name for your resource
<Enter a friendly name here>
? What is the source language? (Use arrow keys)
<Select your default source language>
? What is the target language? (Use arrow keys)
<Select your default target language>
? Who should have access?
Auth users only
❯ Auth and Guest users

Run amplify push to create the resources in the cloud

Working with the API

Here is an example of translating text. In order to override any choices you made in regards to target or source languages while adding this resource using the Amplify CLI, you can pass in them in directly as parameters as shown below.

func translateText(text:String) {
Amplify.Predictions.convert(textToTranslate: text,
language: .english,
targetLanguage: .italian) { event in
switch event {
case let .success(result):
print(result.text)
case let .failure(error):
print(error)
}
}
}
func translateText(text:String) -> AnyCancellable {
Amplify.Predictions.convert(
textToTranslate: text,
language: .english,
targetLanguage: .italian
)
.resultPublisher
.sink {
if case let .failure(error) = $0 {
print(error)
}
}
receiveValue: { result in
print(result.text)
}
}

As a result of running this code, you will see the translated text printed to the console.