Sigue estos pasos para traducir una string entre dos idiomas:
Crea un objeto de FirebaseTranslator y configúralo con los idiomas de origen
y de destino:
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)
Si no sabes el idioma del texto de entrada, puedes usar la
API de identificación de idioma en primer lugar. Confirma que no tienes en el dispositivo demasiados modelos de idioma a la vez.
Asegúrate de que el modelo de traducción requerido se haya descargado en el dispositivo.
No llames a translate() hasta que sepas que el modelo está disponible.
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.// ...}
Los modelos de idioma rondan los 30 MB, así que no los descargues innecesariamente, y
solo hazlo usando Wi‑Fi, a menos que el usuario haya especificado lo contrario. También debes borrar los modelos innecesarios.
Consulta Administra explícitamente los modelos de traducción.
Después de confirmar que el modelo se descargó, pasa una string de texto en
el idioma de origen a translate():
El texto traducido, en el idioma de destino que configuraste, se pasa al objeto de escucha que detecta
el resultado correcto.
Administra explícitamente los modelos de traducción
Cuando utilizas la API de traducción como se describe anteriormente, el Kit de AA descarga automáticamente los modelos de traducción específicos del idioma al dispositivo, según sea necesario. También puedes administrar de forma explícita los modelos de traducción que deseas que estén disponibles en el dispositivo con la API de administración de modelos de traducción del Kit de AA. Esto puede ser
útil si deseas descargar modelos con anticipación o borrar modelos innecesarios
del dispositivo.
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,["Última actualización: 2025-08-18 (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 }"]]