במדריך הזה מוסבר איך לתמוך בעדכונים מתוך האפליקציה באפליקציה שלכם באמצעות Unity. יש מדריכים נפרדים למקרים שבהם ההטמעה מתבצעת באמצעות שפת התכנות Kotlin או שפת התכנות Java, ומקרים שבהם ההטמעה מתבצעת באמצעות קוד מקומי (C/C++).
סקירה כללית על Unity SDK
ממשק ה-API של עדכונים בתוך האפליקציה ב-Play הוא חלק ממשפחת Play Core SDK. הפלאגין של Unity כולל את הכיתה AppUpdateManager
לטיפול בתקשורת בין האפליקציה ל-Google Play API. כדי שתוכלו להשתמש בה כדי לנהל עדכונים באפליקציה, עליכם ליצור מופע של הכיתה הזו:
AppUpdateManager appUpdateManager = new AppUpdateManager();
הגדרת סביבת הפיתוח
OpenUPM-CLI
אם OpenUPM CLI מותקן, אפשר להתקין את הרישום של OpenUPM באמצעות הפקודה הבאה:
openupm add com.google.play.appupdate
OpenUPM
פותחים את הגדרות מנהל החבילות על ידי בחירה באפשרות בתפריט של Unity Edit > Project Settings > Package Manager.
מוסיפים את OpenUPM כמאגר ברמת ההיקף לחלון Package Manager:
Name: package.openupm.com URL: https://package.openupm.com Scopes: com.google.external-dependency-manager com.google.play.common com.google.play.core com.google.play.appupdate
פותחים את תפריט מנהל החבילות על ידי בחירה באפשרות התפריט של Unity Window > Package Manager.
בתפריט הנפתח של היקף הניהול, בוחרים באפשרות My Registries.
בוחרים את החבילה Google Play Integrity plugin for Unity מרשימת החבילות ולוחצים על Install.
ייבוא מ-GitHub
מורידים את הגרסה האחרונה של
.unitypackage
מ-GitHub.מייבאים את הקובץ
.unitypackage
על ידי בחירה באפשרות בתפריט של Unity נכסים > ייבוא חבילה > חבילה מותאמת אישית וייבוא כל הפריטים.
בודקים אם יש עדכונים שזמינים
לפני ששולחים בקשה לעדכון, כדאי לבדוק אם יש עדכון זמין לאפליקציה. אפשר להשתמש ב-AppUpdateManager
כדי לבדוק אם יש עדכון בקורוטין:
IEnumerator CheckForUpdate()
{
PlayAsyncOperation<AppUpdateInfo, AppUpdateErrorCode> appUpdateInfoOperation =
appUpdateManager.GetAppUpdateInfo();
// Wait until the asynchronous operation completes.
yield return appUpdateInfoOperation;
if (appUpdateInfoOperation.IsSuccessful)
{
var appUpdateInfoResult = appUpdateInfoOperation.GetResult();
// Check AppUpdateInfo's UpdateAvailability, UpdatePriority,
// IsUpdateTypeAllowed(), ... and decide whether to ask the user
// to start an in-app update.
}
else
{
// Log appUpdateInfoOperation.Error.
}
}
המכונה AppUpdateInfo
שתוחזר מכילה את סטטוס הזמינות של העדכון. אם כבר מתבצע עדכון בתוך האפליקציה, המכונה תדווח גם על סטטוס העדכון.
בדיקת העדכון
בנוסף לבדיקה אם יש עדכון זמין, כדאי גם לבדוק כמה זמן עבר מאז שהמשתמש קיבל הודעה על עדכון בפעם האחרונה דרך חנות Play. כך תוכלו להחליט אם להתחיל עדכון גמיש או עדכון מיידי. לדוגמה, אפשר להמתין כמה ימים לפני ששולחים למשתמש עדכון גמיש, וכמה ימים לאחר מכן לפני שדורשים עדכון מיידי.
אפשר להשתמש ב-ClientVersionStalenessDays
כדי לבדוק את מספר הימים שעברו מאז שהעדכון זמין בחנות Play:
var stalenessDays = appUpdateInfoOperation.ClientVersionStalenessDays;
בדיקת העדיפות של העדכון
Google Play Developer API מאפשר להגדיר את רמת העדיפות של כל עדכון. כך האפליקציה תוכל להחליט עד כמה להמליץ למשתמש על עדכון. לדוגמה, כדאי להשתמש באסטרטגיה הבאה כדי להגדיר את העדיפות של עדכונים:
- שיפורים קלים בממשק המשתמש: עדכון בעדיפות נמוכה. לא צריך לבקש עדכון גמיש או עדכון מיידי.
- שיפורים בביצועים: עדכון בעדיפות בינונית. צריך לבקש עדכון גמיש.
- עדכון אבטחה קריטי: עדכון בעדיפות גבוהה. צריך לבקש עדכון מיידי.
כדי לקבוע את העדיפות, מערכת Google Play משתמשת בערך שלם בין 0 ל-5, כאשר 0 הוא ברירת המחדל ו-5 הוא העדיפות הגבוהה ביותר. כדי להגדיר את רמת העדיפות של עדכון, משתמשים בשדה inAppUpdatePriority
בקטע Edits.tracks.releases
ב-Google Play Developer API. כל הגרסאות החדשות שנוספו במהדורה נחשבות לבעלות אותה תעדוף כמו המהדורה. אפשר להגדיר את רמת העדיפות רק במהלך ההשקה של גרסה חדשה, ולא ניתן לשנות אותה מאוחר יותר.
מגדירים את רמת העדיפות באמצעות Google Play Developer API, כפי שמתואר במסמכי התיעוד של Play Developer API. צריך לציין את העדיפות של העדכון באפליקציה במשאב Edit.tracks
שמוענק בשיטה Edit.tracks: update
. בדוגמה הבאה מוצגת הפצה של אפליקציה עם קוד גרסה 88 ו-inAppUpdatePriority
5:
{ "releases": [{ "versionCodes": ["88"], "inAppUpdatePriority": 5, "status": "completed" }] }
בקוד של האפליקציה, אפשר לבדוק את רמת העדיפות של עדכון נתון באמצעות UpdatePriority
:
var priority = appUpdateInfoOperation.UpdatePriority;
התחלת עדכון
אחרי שתבדקו אם יש עדכון זמין, תוכלו לבקש עדכון באמצעות AppUpdateManager.StartUpdate()
. לפני ששולחים בקשה לעדכון, חשוב לוודא שיש אובייקט AppUpdateInfo
עדכני. צריך גם ליצור אובייקט AppUpdateOptions
כדי להגדיר את תהליך העדכון.
בדוגמה הבאה נוצר אובייקט AppUpdateOptions
לתהליך עדכון מיידי:
// Creates an AppUpdateOptions defining an immediate in-app
// update flow and its parameters.
var appUpdateOptions = AppUpdateOptions.ImmediateAppUpdateOptions();
בדוגמה הבאה נוצר אובייקט AppUpdateOptions
לתהליך עדכון גמיש:
// Creates an AppUpdateOptions defining a flexible in-app
// update flow and its parameters.
var appUpdateOptions = AppUpdateOptions.FlexibleAppUpdateOptions();
האובייקט AppUpdateOptions
מכיל גם את השדה AllowAssetPackDeletion
שמגדיר אם העדכון יכול למחוק חבילות נכסים במקרה של נפח אחסון מוגבל במכשיר. השדה הזה מוגדר כברירת מחדל כ-false
, אבל אפשר להעביר את הארגומנט האופציונלי allowAssetPackDeletion
אל ImmediateAppUpdateOptions()
או אל FlexibleAppUpdateOptions()
כדי להגדיר אותו כ-true
במקום זאת:
// Creates an AppUpdateOptions for an immediate flow that allows
// asset pack deletion.
var appUpdateOptions =
AppUpdateOptions.ImmediateAppUpdateOptions(allowAssetPackDeletion: true);
// Creates an AppUpdateOptions for a flexible flow that allows asset
// pack deletion.
var appUpdateOptions =
AppUpdateOptions.FlexibleAppUpdateOptions(allowAssetPackDeletion: true);
השלבים הבאים משתנים בהתאם לבקשה שלכם: עדכון גמיש או עדכון מיידי.
טיפול בעדכון גמיש
אחרי שיוצרים אובייקט AppUpdateInfo
עדכני ואובייקט AppUpdateOptions
שהוגדר בצורה נכונה, אפשר לבצע קריאה ל-AppUpdateManager.StartUpdate()
כדי לבקש תהליך עדכון באופן אסינכרוני.
IEnumerator StartFlexibleUpdate()
{
// Creates an AppUpdateRequest that can be used to monitor the
// requested in-app update flow.
var startUpdateRequest = appUpdateManager.StartUpdate(
// The result returned by PlayAsyncOperation.GetResult().
appUpdateInfoResult,
// The AppUpdateOptions created defining the requested in-app update
// and its parameters.
appUpdateOptions);
while (!startUpdateRequest.IsDone)
{
// For flexible flow,the user can continue to use the app while
// the update downloads in the background. You can implement a
// progress bar showing the download status during this time.
yield return null;
}
}
כדי שתהליך העדכון יהיה גמיש, צריך להפעיל את התקנת עדכון האפליקציה אחרי שההורדה מסתיימת. כדי לעשות זאת, צריך להפעיל את הפונקציה AppUpdateManager.CompleteUpdate()
, כפי שמתואר בדוגמה הבאה:
IEnumerator CompleteFlexibleUpdate()
{
var result = appUpdateManager.CompleteUpdate();
yield return result;
// If the update completes successfully, then the app restarts and this line
// is never reached. If this line is reached, then handle the failure (e.g. by
// logging result.Error or by displaying a message to the user).
}
טיפול בעדכון מיידי
אחרי שיוצרים אובייקט AppUpdateInfo
עדכני ואובייקט AppUpdateOptions
שהוגדר בצורה נכונה, אפשר לבצע קריאה ל-AppUpdateManager.StartUpdate()
כדי לבקש תהליך עדכון באופן אסינכרוני.
IEnumerator StartImmediateUpdate()
{
// Creates an AppUpdateRequest that can be used to monitor the
// requested in-app update flow.
var startUpdateRequest = appUpdateManager.StartUpdate(
// The result returned by PlayAsyncOperation.GetResult().
appUpdateInfoResult,
// The AppUpdateOptions created defining the requested in-app update
// and its parameters.
appUpdateOptions);
yield return startUpdateRequest;
// If the update completes successfully, then the app restarts and this line
// is never reached. If this line is reached, then handle the failure (for
// example, by logging result.Error or by displaying a message to the user).
}
בתהליך עדכון מיידי, תיפתח ב-Google Play תיבת דו-שיח לאישור המשתמש. כשהמשתמש מאשר את הבקשה, Google Play מורידים ומתקינים את העדכון באופן אוטומטי, ואז מפעילים מחדש את האפליקציה בגרסה המעודכנת אם ההתקנה מסתיימת בהצלחה.
טיפול בשגיאות
בקטע הזה מתוארים פתרונות לשגיאות נפוצות.
- אם הפונקציה
StartUpdate()
גורמת להשלכה שלArgumentNullException
, המשמעות היא ש-AppUpdateInfo
הוא null. לפני שמתחילים את תהליך העדכון, צריך לוודא שהאובייקטAppUpdateInfo
שמוחזר מ-GetAppUpdateInfo()
הוא לא null. - אם
PlayAsyncOperation
מחזיר את קוד השגיאהErrorUpdateUnavailable
, צריך לוודא שיש גרסה מעודכנת של האפליקציה עם אותו מזהה אפליקציה ומפתח חתימה. - אם הפונקציה
PlayAsyncOperation
מחזירה את קוד השגיאהErrorUpdateNotAllowed
, המשמעות היא שהאובייקטAppUpdateOptions
מציין סוג עדכון שאינו מורשה לעדכון הזמין. לפני שמתחילים בתהליך העדכון, צריך לבדוק אם אובייקטAppUpdateInfo
מציין שסוג העדכון שנבחר מותר.
השלבים הבאים
בודקים את העדכונים באפליקציה כדי לוודא שהשילוב פועל כמו שצריך.