gpg::AndroidSupport

#include <android_support.h>

Funkcje, które umożliwiają obsługę Androida w wersji starszej niż 4.0.

Podsumowanie

Wywołania zwrotne cyklu życia Androida

W przypadku aplikacji kierowanych na urządzenia z Androidem 2.3 lub 3.x (wersja interfejsu API sprzed 14) usługi gier Play nie mogą automatycznie otrzymywać wywołań zwrotnych cyklu życia aktywności. W takich przypadkach Usługi gier Play powiadamiają o zdarzeniach cyklu życia na podstawie Aktywności będącej właścicielem. Działanie zawierające obiekt GameServices powinno wywoływać funkcje AndroidSupport::* z własnych funkcji wywołania zwrotnego cyklu życia. Argumenty tych funkcji są zgodne z argumentami udostępnianymi przez Androida, więc dodatkowe przetwarzanie nie jest konieczne.

W przypadku aplikacji kierowanych na Androida 4.0 lub nowszego (interfejs API w wersji 14 lub nowszej) większość tych wywołań funkcji jest niepotrzebne. W przypadku takich aplikacji musi być wywoływana tylko funkcja OnActivityResult.

Przykładowy kod gry w wersji starszej niż 4.0, która używa aktywności w języku Java

W aktywności w Javie dodaj te elementy. Konieczne może być scalenie tego kodu z istniejącymi funkcjami cyklu życia.

import android.app.Activity;
import android.content.Intent;

public class YourActivity extends Activity {
  protected void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    nativeOnActivityCreated(this, savedInstanceState);
  }

  protected void onDestroy(){
    super.onDestroy();
    nativeOnActivityDestroyed(this);
  }

  protected void onPause(){
    super.onPause();
    nativeOnActivityPaused(this);
  }

  protected void onResume(){
    super.onResume();
    nativeOnActivityResumed(this);
  }

  protected void onStart(){
    super.onStart();
    nativeOnActivityStarted(this);
  }

  protected void onStop(){
    super.onStop();
    nativeOnActivityStopped(this);
  }

  protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    nativeOnActivitySaveInstanceState(this, outState);
  }

  protected void onActivityResult(int requestCode,
                                  int resultCode,
                                  Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    nativeOnActivityResult(this, requestCode, resultCode, data);
  }

  // Implemented in C++.
  private static native void nativeOnActivityCreated(
      Activity activity, Bundle savedInstanceState);
  private static native void nativeOnActivityDestroyed(Activity activity);
  private static native void nativeOnActivityPaused(Activity activity);
  private static native void nativeOnActivityResumed(Activity activity);
  private static native void nativeOnActivitySaveInstanceState(
      Activity activity,
      Bundle outState);
  private static native void nativeOnActivityStarted(Activity activity);
  private static native void nativeOnActivityStopped(Activity activity);
  private static native void nativeOnActivityResult(
      Activity activity,
      int requestCode,
      int resultCode,
      Intent data);
}
Następnie w bibliotece natywnej dodaj podane niżej funkcje przekierowania.
void Java_com_example_yourapp_YourActivity_nativeOnActivityCreated(
    JNIEnv* env,
    jobject thiz,
    jobject activity,
    jobject saved_instance_state) {
  gpg::AndroidSupport::OnActivityCreated(env,
                                         activity,
                                         saved_instance_state);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityDestroyed(
    JNIEnv* env, jobject thiz, jobject activity) {
  gpg::AndroidSupport::OnActivityDestroyed(env, activity);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityPaused(
    JNIEnv* env, jobject thiz, jobject activity) {
  gpg::AndroidSupport::OnActivityPaused(env, activity);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityResumed(
    JNIEnv* env, jobject thiz, jobject activity) {
  gpg::AndroidSupport::OnActivityResumed(env, activity);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivitySaveInstanceState(
    JNIEnv* env, jobject thiz, jobject activity, jobject out_state) {
  gpg::AndroidSupport::OnActivitySaveInstanceState(env, activity, out_state);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityStarted(
    JNIEnv* env, jobject thiz, jobject activity) {
  gpg::AndroidSupport::OnActivityStarted(env, activity);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityStopped(
    JNIEnv* env, jobject thiz, jobject activity) {
  gpg::AndroidSupport::OnActivityStopped(env, activity);
}

void Java_com_example_yourapp_YourActivity_nativeOnActivityResult(
    JNIEnv* env,
    jobject thiz,
    jobject activity,
    jint request_code,
    jint result_code,
    jobject data) {
  gpg::AndroidSupport::OnActivityResult(
      env, activity, request_code, result_code, data);
}

Przykładowy kod gry na Androida 4.0 lub nowszej korzystającej z aktywności w Javie

W aktywności w Javie dodaj te elementy. Konieczne może być scalenie tego kodu z istniejącymi funkcjami cyklu życia.

public class YourActivity extends Activity {
  protected void onActivityResult(int requestCode,
                                  int resultCode,
                                  Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    nativeOnActivityResult(this, requestCode, resultCode, data);
  }

  // Implemented in C++.
  private static native void nativeOnActivityResult(
      Activity activity,
      int requestCode,
      int resultCode,
      Intent data);
}
Następnie w bibliotece natywnej dodaj podane niżej funkcje przekierowania.
void Java_com_example_yourapp_YourActivity_nativeOnActivityResult(
    JNIEnv* env,
    jobject thiz,
    jobject activity,
    jint request_code,
    jint result_code,
    jobject data) {
  gpg::AndroidSupport::OnActivityResult(
      env, activity, request_code, result_code, data);
}

Publiczne funkcje statyczne

OnActivityCreated(JNIEnv *env, jobject activity, jobject saved_instance_state)
void
Powinno być wywoływane w celu przekazania danych z działania onActivityCreated aktywności w Javie.
OnActivityDestroyed(JNIEnv *env, jobject activity)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityDestroyed aktywności Java.
OnActivityPaused(JNIEnv *env, jobject activity)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivitypause w aktywności Java.
OnActivityResult(JNIEnv *env, jobject activity, jint request_code, jint result_code, jobject result)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityResult Twojej aktywności w Javie.
OnActivityResumed(JNIEnv *env, jobject activity)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityActivityd Twojej aktywności w Javie.
OnActivitySaveInstanceState(JNIEnv *env, jobject activity, jobject out_state)
void
Powinno być wywoływane w celu przekazywania danych z ustawienia OnActivitySaveInstanceState w aktywności Javy.
OnActivityStarted(JNIEnv *env, jobject activity)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityStarted aktywności Java.
OnActivityStopped(JNIEnv *env, jobject activity)
void
Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityStopped aktywności Java.

Publiczne funkcje statyczne

OnActivityCreated

void gpg::AndroidSupport::OnActivityCreated(
  JNIEnv *env,
  jobject activity,
  jobject saved_instance_state
)

Powinno być wywoływane w celu przekazania danych z działania onActivityCreated aktywności w Javie.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivityDestroyed

void gpg::AndroidSupport::OnActivityDestroyed(
  JNIEnv *env,
  jobject activity
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityDestroyed aktywności Java.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivityPaused

void gpg::AndroidSupport::OnActivityPaused(
  JNIEnv *env,
  jobject activity
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivitypause w aktywności Java.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivityResult

void gpg::AndroidSupport::OnActivityResult(
  JNIEnv *env,
  jobject activity,
  jint request_code,
  jint result_code,
  jobject result
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityResult Twojej aktywności w Javie.

OnActivityResumed

void gpg::AndroidSupport::OnActivityResumed(
  JNIEnv *env,
  jobject activity
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityActivityd Twojej aktywności w Javie.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivitySaveInstanceState

void gpg::AndroidSupport::OnActivitySaveInstanceState(
  JNIEnv *env,
  jobject activity,
  jobject out_state
)

Powinno być wywoływane w celu przekazywania danych z ustawienia OnActivitySaveInstanceState w aktywności Javy.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivityStarted

void gpg::AndroidSupport::OnActivityStarted(
  JNIEnv *env,
  jobject activity
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityStarted aktywności Java.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.

OnActivityStopped

void gpg::AndroidSupport::OnActivityStopped(
  JNIEnv *env,
  jobject activity
)

Powinno być wywoływane w celu przekazania danych z ustawienia OnActivityStopped aktywności Java.

Niezbędne tylko na potrzeby obsługi Androida 2.3.x.