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 (interfejs API w wersji starszej niż 14) usługi gier Play nie mają możliwości automatycznego otrzymywania wywołań zwrotnych cyklu życia aktywności. W takich przypadkach usługi gier Play korzystają z Aktywności właściciela, aby powiadamiać ją o zdarzeniach cyklu życia. Każda aktywność, która jest właścicielem obiektu GameServices, powinna wywoływać funkcje AndroidSupport::* z poziomu własnych funkcji wywołania zwrotnego cyklu życia. Argumenty tych funkcji są zgodne z argumentami udostępnianymi przez Androida, więc żadne dodatkowe przetwarzanie nie jest konieczne.

W aplikacjach kierowanych na Androida 4.0 lub nowszego (interfejs API w wersji 14 lub nowszej) większość tych wywołań funkcji jest niepotrzebna. W przypadku takich aplikacji należy wywołać tylko funkcję OnActivityResult.

Przykładowy kod gry z aktywnością w języku Java w wersji starszej niż 4.0

Do aktywności w Javie dodaj następującą treść. Może być konieczne 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 wymienione 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

Do aktywności w Javie dodaj następującą treść. Może być konieczne 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 wymienione 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
Powinna być wywoływana, aby przekazywać dane z aktywności w Javie w rodzaju onActivityCreated.
OnActivityDestroyed(JNIEnv *env, jobject activity)
void
Powinna być wywoływana, aby przekazywać dane z zdarzenia OnActivityDestroyed w aktywności w Javie.
OnActivityPaused(JNIEnv *env, jobject activity)
void
Powinna być wywoływana, aby przekazywać dane z klasy OnActivityPause w aktywności Javy.
OnActivityResult(JNIEnv *env, jobject activity, jint request_code, jint result_code, jobject result)
void
Powinno być wywoływane, aby przekazywać dane z parametru OnActivityResult Twojej aktywności w Javie.
OnActivityResumed(JNIEnv *env, jobject activity)
void
Powinna być wywoływana, aby przekazywać dane z aktywności w Javie OnActivityWznów.
OnActivitySaveInstanceState(JNIEnv *env, jobject activity, jobject out_state)
void
Powinna być wywoływana, aby przekazywać dane z wartości OnActivitySaveInstanceState w aktywności w Javie.
OnActivityStarted(JNIEnv *env, jobject activity)
void
Powinna być wywoływana, aby przekazywać dane z zdarzenia OnActivityStarted w aktywności w Javie.
OnActivityStopped(JNIEnv *env, jobject activity)
void
Powinna być wywoływana, aby przekazywać dane z klasy OnActivityStopped w aktywności w Javie.

Publiczne funkcje statyczne

OnActivityCreated

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

Powinna być wywoływana, aby przekazywać dane z aktywności w Javie w rodzaju onActivityCreated.

Wymagane tylko w przypadku Androida 2.3.x.

OnActivityDestroyed

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

Powinna być wywoływana, aby przekazywać dane z zdarzenia OnActivityDestroyed w aktywności w Javie.

Wymagane tylko w przypadku Androida 2.3.x.

OnActivityPaused

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

Powinna być wywoływana, aby przekazywać dane z klasy OnActivityPause w aktywności Javy.

Wymagane tylko w przypadku 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, aby przekazywać dane z parametru OnActivityResult Twojej aktywności w Javie.

OnActivityResumed

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

Powinna być wywoływana, aby przekazywać dane z aktywności w Javie OnActivityWznów.

Wymagane tylko w przypadku Androida 2.3.x.

OnActivitySaveInstanceState

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

Powinna być wywoływana, aby przekazywać dane z wartości OnActivitySaveInstanceState w aktywności w Javie.

Wymagane tylko w przypadku Androida 2.3.x.

OnActivityStarted

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

Powinna być wywoływana, aby przekazywać dane z zdarzenia OnActivityStarted w aktywności w Javie.

Wymagane tylko w przypadku Androida 2.3.x.

OnActivityStopped

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

Powinna być wywoływana, aby przekazywać dane z klasy OnActivityStopped w aktywności w Javie.

Wymagane tylko w przypadku Androida 2.3.x.