אירועים במשחקים ל-Android

במדריך הזה נסביר איך אוספים נתונים על אופן המשחק של השחקנים לצורך ניתוח נתוני המשחק באמצעות ממשקי ה-API של האירועים שסופקו על ידי שירותי המשחקים של Google Play. ממשקי ה-API נמצאים ב-com.google.android.gms.games.event וב-com.google.android.gms.games.

לפני שמתחילים

אם עדיין לא עשית זאת, כדאי לעיין במאמר מושגים על משחקי אירועים.

לפני שמתחילים לכתוב קוד באמצעות ממשקי ה-API של האירועים:

אחזור הלקוח של האירועים

כדי להתחיל להשתמש בממשקי ה-API של האירועים, המשחק צריך לקבל קודם אובייקט EventsClient. אפשר לעשות זאת על ידי קריאה לשיטה Games.getEventsClient() והעברת הפעילות וה-GoogleSignInAccount של הנגן הנוכחי. במאמר כניסה למשחקים ל-Android מוסבר איך לאחזר את פרטי חשבון השחקן.

שליחת אירועים

אתם יכולים להוסיף למשחק קוד שיודיע ל-Google Play Games Services בכל פעם שמתרחש אירוע שחשוב למשחק.

כדי לשלוח עדכון של אירוע, צריך להפעיל את EventsClient.increment() עם הערך eventId ועם מספר שלם incrementAmount שווה ל-0 או גדול ממנו.

  • השדה eventId נוצר על ידי Google Play Games Services כשמגדירים את האירוע בפעם הראשונה ב-Google Play Console, ומשמש לזיהוי ייחודי של האירוע הזה במשחק.
  • אפשר להשתמש בקלט incrementAmount כדי לציין את ההתקדמות הכמותית של השחקן להשגת יעד מסוים במשחק. לדוגמה, אם האירוע שאתם רוצים לעקוב אחריו במשחק הוא 'ניצחון על 500 מפלצות עם עיניים עגולות', הערך של incrementAmount יכול להיות מספר המפלצות שהשחקן הרג בקרב אחד.

דוגמה לשליחת אירוע עם סכום הגדלה של 1:

public void submitEvent(String eventId) {
  Games.getEventsClient(this, GoogleSignIn.getLastSignedInAccount(this))
      .increment(eventId, 1);
}

אחזור אירועים

אפשר לאחזר את כל נתוני האירועים של המשחק ששמורים בשרתי Google באמצעות קריאה ל-EventsClient.load(). בקריאה ל-method, מעבירים ערך בוליאני כדי לציין אם מערכת Google Play Games Services צריכה לנקות את הנתונים שנשמרו במטמון באופן מקומי במכשיר של המשתמש.

כדי לאחזר נתונים של אירועים ספציפיים שהגדרתם ב-Google Play Console, צריך להפעיל את הפונקציה EventsClient.loadByIds() ולהעביר אותה במערך של מזהי אירועים בפרמטרים של הקלט.

קטע הקוד הבא מראה איך שולחים שאילתה ל-Google Play Games Services כדי לקבל את רשימת כל האירועים במשחק:

public void loadEvents() {
  Games.getEventsClient(this, GoogleSignIn.getLastSignedInAccount(this))
      .load(true)
      .addOnCompleteListener(new OnCompleteListener<AnnotatedData<EventBuffer>>() {
        @Override
        public void onComplete(@NonNull Task<AnnotatedData<EventBuffer>> task) {
          if (task.isSuccessful()) {
            // Process all the events.
            for (Event event : task.getResult().get()) {
              Log.d(TAG, "loaded event " + event.getName());
            }
          } else {
            // Handle Error
            Exception exception = task.getException();
            int statusCode = CommonStatusCodes.DEVELOPER_ERROR;
            if (exception instanceof ApiException) {
              ApiException apiException = (ApiException) exception;
              statusCode = apiException.getStatusCode();
            }
            showError(statusCode);
          }
        }
      });
}