ML Kit יכול ליצור תשובות קצרות להודעות באמצעות מודל במכשיר.
כדי ליצור תשובות חכמות, מעבירים ל-ML Kit יומן של הודעות אחרונות בשיחה. אם ML Kit קובע שהשיחה היא באנגלית, ושהשיחה לא כוללת נושאים רגישים, הוא יוצר עד שלוש תשובות שאפשר להציע למשתמש.
בחבילה | לא מקובצים | |
---|---|---|
שם הספרייה | com.google.mlkit:smart-reply | com.google.android.gms:play-services-mlkit-smart-reply |
הטמעה | המודל מקושר באופן סטטי לאפליקציה בזמן הבנייה. | המודל מורד באופן דינמי דרך Google Play Services. |
השפעה על גודל האפליקציה | הגדלת הגודל בכ-5.7MB. | הגודל גדל בכ-200KB. |
זמן האתחול | המודל זמין באופן מיידי. | יכול להיות שתצטרכו לחכות עד שהמודל יורד לפני השימוש הראשון. |
רוצה לנסות?
- כדאי להתנסות באפליקציית הדוגמה כדי לראות דוגמה לשימוש ב-API הזה.
לפני שמתחילים
בקובץ
build.gradle
ברמת הפרויקט, מוודאים שמאגר Maven של Google כלול בקטעיםbuildscript
ו-allprojects
.מוסיפים את התלויות של ספריות ML Kit ל-Android לקובץ Gradle ברמת האפליקציה של המודול, שבדרך כלל נקרא
app/build.gradle
. בוחרים אחת מהתלויות הבאות בהתאם לצרכים:- כדי לארוז את המודל עם האפליקציה:
dependencies { // ... // Use this dependency to bundle the model with your app implementation 'com.google.mlkit:smart-reply:17.0.4' }
- כדי להשתמש במודל ב-Google Play Services:
dependencies { // ... // Use this dependency to use the dynamically downloaded model in Google Play Services implementation 'com.google.android.gms:play-services-mlkit-smart-reply:16.0.0-beta1' }
אם בוחרים להשתמש במודל ב-Google Play Services, אפשר להגדיר את האפליקציה כך שהמודל יורד אוטומטית למכשיר אחרי שהאפליקציה מותקנת מחנות Play. מוסיפים את ההצהרה הבאה לקובץ
AndroidManifest.xml
של האפליקציה:<application ...> ... <meta-data android:name="com.google.mlkit.vision.DEPENDENCIES" android:value="smart_reply" > <!-- To use multiple models: android:value="smart_reply,model2,model3" --> </application>
אפשר גם לבדוק באופן מפורש את זמינות המודל ולבקש הורדה באמצעות ModuleInstallClient API של Google Play Services.
אם לא מפעילים הורדות של מודלים בזמן ההתקנה או לא מבקשים הורדה מפורשת, המודל יורד בפעם הראשונה שמריצים את מחולל התשובות החכמות. אם שולחים בקשות לפני שההורדה מסתיימת, לא מתקבלות תוצאות.
1. יצירת אובייקט של היסטוריית שיחות
כדי ליצור תשובות חכמות, מעבירים ל-ML Kit רשימה
List
שלTextMessage
אובייקטים, מסודרים לפי סדר כרונולוגי, כשהחותמת הכי מוקדמת מופיעה ראשונה.בכל פעם שהמשתמש שולח הודעה, צריך להוסיף את ההודעה ואת חותמת הזמן שלה להיסטוריית השיחות:
Kotlin
conversation.add(TextMessage.createForLocalUser( "heading out now", System.currentTimeMillis()))
Java
conversation.add(TextMessage.createForLocalUser( "heading out now", System.currentTimeMillis()));
בכל פעם שהמשתמש מקבל הודעה, מוסיפים את ההודעה, חותמת הזמן שלה ומזהה המשתמש של השולח להיסטוריית השיחות. מזהה המשתמש יכול להיות כל מחרוזת שמזהה באופן ייחודי את השולח בשיחה. מזהה המשתמש לא צריך להתאים לנתוני משתמשים כלשהם, והוא לא צריך להיות עקבי בין שיחות או הפעלות של מחולל התשובות החכמות.
Kotlin
conversation.add(TextMessage.createForRemoteUser( "Are you coming back soon?", System.currentTimeMillis(), userId))
Java
conversation.add(TextMessage.createForRemoteUser( "Are you coming back soon?", System.currentTimeMillis(), userId));
אובייקט של היסטוריית שיחות נראה כמו בדוגמה הבאה:
חותמת זמן userID isLocalUser הודעה Thu Feb 21 13:13:39 PST 2019 true אתה בדרך? Thu Feb 21 13:15:03 PST 2019 FRIEND0 false אאחר, מצטער/ת! ML Kit מציע תשובות להודעה האחרונה בהיסטוריית השיחה. ההודעה האחרונה צריכה להיות ממשתמש לא מקומי. בדוגמה שלמעלה, ההודעה האחרונה בשיחה היא מהמשתמש FRIEND0 שאינו מקומי. כשמשתמשים ב-ML Kit כדי להעביר את היומן הזה, מוצעות תשובות להודעה של FRIENDO: "אני מאחר, מצטער!"
2. קבלת תשובות להודעות
כדי ליצור תשובות מהירות להודעה, צריך לקבל מופע של
SmartReplyGenerator
ולהעביר את היסטוריית השיחות לשיטהsuggestReplies()
שלו:Kotlin
val smartReplyGenerator = SmartReply.getClient() smartReply.suggestReplies(conversation) .addOnSuccessListener { result -> if (result.getStatus() == SmartReplySuggestionResult.STATUS_NOT_SUPPORTED_LANGUAGE) { // The conversation's language isn't supported, so // the result doesn't contain any suggestions. } else if (result.getStatus() == SmartReplySuggestionResult.STATUS_SUCCESS) { // Task completed successfully // ... } } .addOnFailureListener { // Task failed with an exception // ... }
Java
SmartReplyGenerator smartReply = SmartReply.getClient(); smartReply.suggestReplies(conversation) .addOnSuccessListener(new OnSuccessListener
() { @Override public void onSuccess(SmartReplySuggestionResult result) { if (result.getStatus() == SmartReplySuggestionResult.STATUS_NOT_SUPPORTED_LANGUAGE) { // The conversation's language isn't supported, so // the result doesn't contain any suggestions. } else if (result.getStatus() == SmartReplySuggestionResult.STATUS_SUCCESS) { // Task completed successfully // ... } } }) .addOnFailureListener(new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { // Task failed with an exception // ... } }); אם הפעולה מצליחה, אובייקט
SmartReplySuggestionResult
מועבר ל-success handler. האובייקט הזה מכיל רשימה של עד שלוש תשובות מוצעות, שאפשר להציג למשתמש:Kotlin
for (suggestion in result.suggestions) { val replyText = suggestion.text }
Java
for (SmartReplySuggestion suggestion : result.getSuggestions()) { String replyText = suggestion.getText(); }
שימו לב: יכול להיות ש-ML Kit לא יחזיר תוצאות אם המודל לא בטוח ברלוונטיות של התשובות המוצעות, אם השיחה בקלט לא מתנהלת באנגלית או אם המודל מזהה נושא רגיש.