Создайте объект FirebaseTranslator , настроив его с использованием исходного и целевого языков:
Java
// Create an English-German translator:FirebaseTranslatorOptionsoptions=newFirebaseTranslatorOptions.Builder().setSourceLanguage(FirebaseTranslateLanguage.EN).setTargetLanguage(FirebaseTranslateLanguage.DE).build();finalFirebaseTranslatorenglishGermanTranslator=FirebaseNaturalLanguage.getInstance().getTranslator(options);
Kotlin
// Create an English-German translator:valoptions=FirebaseTranslatorOptions.Builder().setSourceLanguage(FirebaseTranslateLanguage.EN).setTargetLanguage(FirebaseTranslateLanguage.DE).build()valenglishGermanTranslator=FirebaseNaturalLanguage.getInstance().getTranslator(options)
Если вы не знаете язык входного текста, вы можете сначала воспользоваться API идентификации языка . (Но убедитесь, что вы не храните на устройстве слишком много языковых моделей одновременно.)
Убедитесь, что требуемая модель перевода загружена на устройство. Не вызывайте translate() пока не убедитесь, что модель доступна.
Java
FirebaseModelDownloadConditionsconditions=newFirebaseModelDownloadConditions.Builder().requireWifi().build();englishGermanTranslator.downloadModelIfNeeded(conditions).addOnSuccessListener(newOnSuccessListener<Void>(){@OverridepublicvoidonSuccess(Voidv){// Model downloaded successfully. Okay to start translating.// (Set a flag, unhide the translation UI, etc.)}}).addOnFailureListener(newOnFailureListener(){@OverridepublicvoidonFailure(@NonNullExceptione){// Model couldn’t be downloaded or other internal error.// ...}});
Kotlin
englishGermanTranslator.downloadModelIfNeeded().addOnSuccessListener{// Model downloaded successfully. Okay to start translating.// (Set a flag, unhide the translation UI, etc.)}.addOnFailureListener{exception->
// Model couldn’t be downloaded or other internal error.// ...}
Языковые модели весят около 30 МБ, поэтому не загружайте их без необходимости и загружайте их только через WiFi, если пользователь не указал иное. Вам также следует удалить ненужные модели. См. Явное управление моделями перевода .
После подтверждения загрузки модели передайте строку текста на исходном языке в translate() :
Переведенный текст на указанном вами целевом языке передается прослушивателю успешного выполнения.
Явное управление моделями перевода
При использовании API перевода, как описано выше, ML Kit автоматически загружает языковые модели перевода на устройство по мере необходимости. Вы также можете явно управлять моделями перевода, которые вы хотите иметь на устройстве, используя API управления моделями перевода ML Kit. Это может быть полезно, если вы хотите загрузить модели заранее или удалить ненужные модели с устройства.
Java
FirebaseModelManagermodelManager=FirebaseModelManager.getInstance();// Get translation models stored on the device.modelManager.getDownloadedModels(FirebaseTranslateRemoteModel.class).addOnSuccessListener(newOnSuccessListener<Set<FirebaseTranslateRemoteModel>>(){@OverridepublicvoidonSuccess(Set<FirebaseTranslateRemoteModel>models){// ...}}).addOnFailureListener(newOnFailureListener(){@OverridepublicvoidonFailure(@NonNullExceptione){// Error.}});// Delete the German model if it's on the device.FirebaseTranslateRemoteModeldeModel=newFirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.DE).build();modelManager.deleteDownloadedModel(deModel).addOnSuccessListener(newOnSuccessListener<Void>(){@OverridepublicvoidonSuccess(Voidv){// Model deleted.}}).addOnFailureListener(newOnFailureListener(){@OverridepublicvoidonFailure(@NonNullExceptione){// Error.}});// Download the French model.FirebaseTranslateRemoteModelfrModel=newFirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.FR).build();FirebaseModelDownloadConditionsconditions=newFirebaseModelDownloadConditions.Builder().requireWifi().build();modelManager.download(frModel,conditions).addOnSuccessListener(newOnSuccessListener<Void>(){@OverridepublicvoidonSuccess(Voidv){// Model downloaded.}}).addOnFailureListener(newOnFailureListener(){@OverridepublicvoidonFailure(@NonNullExceptione){// Error.}});
Kotlin
valmodelManager=FirebaseModelManager.getInstance()// Get translation models stored on the device.modelManager.getDownloadedModels(FirebaseTranslateRemoteModel::class.java).addOnSuccessListener{models->
// ...}.addOnFailureListener{// Error.}// Delete the German model if it's on the device.valdeModel=FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.DE).build()modelManager.deleteDownloadedModel(deModel).addOnSuccessListener{// Model deleted.}.addOnFailureListener{// Error.}// Download the French model.valfrModel=FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.FR).build()valconditions=FirebaseModelDownloadConditions.Builder().requireWifi().build()modelManager.download(frModel,conditions).addOnSuccessListener{// Model downloaded.}.addOnFailureListener{// Error.}
[null,null,["Последнее обновление: 2025-08-15 UTC."],[],[],null,["You can use ML Kit to translate text between languages. ML Kit\ncurrently supports translation between\n[59 languages](/docs/ml-kit/translation-language-support).\n\n\u003cbr /\u003e\n\nBefore you begin\n\n1. If you haven't already, [add Firebase to your Android project](/docs/android/setup).\n2. Add the dependencies for the ML Kit Android libraries to your module (app-level) Gradle file (usually `app/build.gradle`): \n\n ```carbon\n apply plugin: 'com.android.application'\n apply plugin: 'com.google.gms.google-services'\n\n dependencies {\n // ...\n\n implementation 'com.google.firebase:firebase-ml-natural-language:22.0.0'\n implementation 'com.google.firebase:firebase-ml-natural-language-translate-model:20.0.8'\n }\n ```\n\nTranslate a string of text\n\nTo translate a string between two languages:\n\n1. Create a `FirebaseTranslator` object, configuring it with the source and\n target languages:\n\n Java \n\n // Create an English-German translator:\n FirebaseTranslatorOptions options =\n new FirebaseTranslatorOptions.Builder()\n .setSourceLanguage(FirebaseTranslateLanguage.EN)\n .setTargetLanguage(FirebaseTranslateLanguage.DE)\n .build();\n final FirebaseTranslator englishGermanTranslator =\n FirebaseNaturalLanguage.getInstance().getTranslator(options);\n\n Kotlin \n\n // Create an English-German translator:\n val options = FirebaseTranslatorOptions.Builder()\n .setSourceLanguage(FirebaseTranslateLanguage.EN)\n .setTargetLanguage(FirebaseTranslateLanguage.DE)\n .build()\n val englishGermanTranslator = FirebaseNaturalLanguage.getInstance().getTranslator(options)\n\n If you don't know the language of the input text, you can use the [language\n identification API](/docs/ml-kit/identify-languages) first. (But be sure you\n don't keep too many language models on the device at once.)\n2. Make sure the required translation model has been downloaded to the device.\n Don't call `translate()` until you know the model is available.\n\n Java \n\n FirebaseModelDownloadConditions conditions = new FirebaseModelDownloadConditions.Builder()\n .requireWifi()\n .build();\n englishGermanTranslator.downloadModelIfNeeded(conditions)\n .addOnSuccessListener(\n new OnSuccessListener\u003cVoid\u003e() {\n @Override\n public void onSuccess(Void v) {\n // Model downloaded successfully. Okay to start translating.\n // (Set a flag, unhide the translation UI, etc.)\n }\n })\n .addOnFailureListener(\n new OnFailureListener() {\n @Override\n public void onFailure(@NonNull Exception e) {\n // Model couldn't be downloaded or other internal error.\n // ...\n }\n });\n\n Kotlin \n\n englishGermanTranslator.downloadModelIfNeeded()\n .addOnSuccessListener {\n // Model downloaded successfully. Okay to start translating.\n // (Set a flag, unhide the translation UI, etc.)\n }\n .addOnFailureListener { exception -\u003e\n // Model couldn't be downloaded or other internal error.\n // ...\n }\n\n Language models are around 30MB, so don't download them unnecessarily, and\n only download them using WiFi, unless the user has specified otherwise. You\n should also delete unneeded models.\n See [Explicitly manage translation models](#manage_models).\n3. After you confirm the model has been downloaded, pass a string of text in\n the source language to `translate()`:\n\n Java \n\n englishGermanTranslator.translate(text)\n .addOnSuccessListener(\n new OnSuccessListener\u003cString\u003e() {\n @Override\n public void onSuccess(@NonNull String translatedText) {\n // Translation successful.\n }\n })\n .addOnFailureListener(\n new OnFailureListener() {\n @Override\n public void onFailure(@NonNull Exception e) {\n // Error.\n // ...\n }\n });\n\n Kotlin \n\n englishGermanTranslator.translate(text)\n .addOnSuccessListener { translatedText -\u003e\n // Translation successful.\n }\n .addOnFailureListener { exception -\u003e\n // Error.\n // ...\n }\n\n The translated text, in the target language you configured, is passed to the\n success listener.\n\nExplicitly manage translation models\n\n\nWhen you use the translation API as described above, ML Kit automatically\ndownloads language-specific translation models to the device as required. You\ncan also explicitly manage the translation models you want available on the\ndevice by using ML Kit's translation model management API. This can be\nuseful if you want to download models ahead of time, or delete unneeded models\nfrom the device.\n\n\u003cbr /\u003e\n\nJava \n\n FirebaseModelManager modelManager = FirebaseModelManager.getInstance();\n\n // Get translation models stored on the device.\n modelManager.getDownloadedModels(FirebaseTranslateRemoteModel.class)\n .addOnSuccessListener(new OnSuccessListener\u003cSet\u003cFirebaseTranslateRemoteModel\u003e\u003e() {\n @Override\n public void onSuccess(Set\u003cFirebaseTranslateRemoteModel\u003e models) {\n // ...\n }\n })\n .addOnFailureListener(new OnFailureListener() {\n @Override\n public void onFailure(@NonNull Exception e) {\n // Error.\n }\n });\n\n // Delete the German model if it's on the device.\n FirebaseTranslateRemoteModel deModel =\n new FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.DE).build();\n modelManager.deleteDownloadedModel(deModel)\n .addOnSuccessListener(new OnSuccessListener\u003cVoid\u003e() {\n @Override\n public void onSuccess(Void v) {\n // Model deleted.\n }\n })\n .addOnFailureListener(new OnFailureListener() {\n @Override\n public void onFailure(@NonNull Exception e) {\n // Error.\n }\n });\n\n // Download the French model.\n FirebaseTranslateRemoteModel frModel =\n new FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.FR).build();\n FirebaseModelDownloadConditions conditions = new FirebaseModelDownloadConditions.Builder()\n .requireWifi()\n .build();\n modelManager.download(frModel, conditions)\n .addOnSuccessListener(new OnSuccessListener\u003cVoid\u003e() {\n @Override\n public void onSuccess(Void v) {\n // Model downloaded.\n }\n })\n .addOnFailureListener(new OnFailureListener() {\n @Override\n public void onFailure(@NonNull Exception e) {\n // Error.\n }\n });\n\nKotlin \n\n val modelManager = FirebaseModelManager.getInstance()\n\n // Get translation models stored on the device.\n modelManager.getDownloadedModels(FirebaseTranslateRemoteModel::class.java)\n .addOnSuccessListener { models -\u003e\n // ...\n }\n .addOnFailureListener {\n // Error.\n }\n\n // Delete the German model if it's on the device.\n val deModel = FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.DE).build()\n modelManager.deleteDownloadedModel(deModel)\n .addOnSuccessListener {\n // Model deleted.\n }\n .addOnFailureListener {\n // Error.\n }\n\n // Download the French model.\n val frModel = FirebaseTranslateRemoteModel.Builder(FirebaseTranslateLanguage.FR).build()\n val conditions = FirebaseModelDownloadConditions.Builder()\n .requireWifi()\n .build()\n modelManager.download(frModel, conditions)\n .addOnSuccessListener {\n // Model downloaded.\n }\n .addOnFailureListener {\n // Error.\n }"]]