Ajoutez les dépendances des bibliothèques Android ML Kit au fichier Gradle de votre module (au niveau de l'application) (généralement app/build.gradle):
Créez un objet FirebaseTranslator, en le configurant avec les langues source et cible:
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 vous ne connaissez pas la langue du texte saisi, vous pouvez d'abord utiliser l'API d'identification de la langue. (mais veillez à ne pas conserver trop de modèles de langage sur l'appareil en même temps).
Assurez-vous que le modèle de traduction requis a été téléchargé sur l'appareil.
N'appelez pas translate() tant que vous n'êtes pas sûr que le modèle 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.// ...}
Les modèles de langage font environ 30 Mo. Ne les téléchargez donc pas inutilement et ne les téléchargez que via le Wi-Fi, sauf si l'utilisateur a spécifié le contraire. Vous devez également supprimer les modèles inutiles.
Consultez Gérer explicitement les modèles de traduction.
Une fois que vous avez vérifié que le modèle a été téléchargé, transmettez une chaîne de texte dans la langue source à translate():
Le texte traduit, dans la langue cible que vous avez configurée, est transmis à l'écouteur de succès.
Gérer explicitement les modèles de traduction
Lorsque vous utilisez l'API de traduction comme décrit ci-dessus, ML Kit télécharge automatiquement des modèles de traduction spécifiques à la langue sur l'appareil, si nécessaire. Vous pouvez également gérer explicitement les modèles de traduction que vous souhaitez mettre à disposition sur l'appareil à l'aide de l'API de gestion des modèles de traduction de ML Kit. Cela peut être utile si vous souhaitez télécharger des modèles à l'avance ou supprimer des modèles inutiles de l'appareil.
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.}
Sauf indication contraire, le contenu de cette page est régi par une licence Creative Commons Attribution 4.0, et les échantillons de code sont régis par une licence Apache 2.0. Pour en savoir plus, consultez les Règles du site Google Developers. Java est une marque déposée d'Oracle et/ou de ses sociétés affiliées.
Dernière mise à jour le 2025/08/16 (UTC).
[null,null,["Dernière mise à jour le 2025/08/16 (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 }"]]