it-swarm.com.ru

GooglePlayServicesUtil.getErrorDialog имеет значение null

Я использую ACRA ( arca.ch ) для создания автоматических отчетов об ошибках.

Я только что выпустил новую версию своего приложения, используя Google Maps Android API v2. Пользователи EEEPad и Transformer Pad получают сообщение об ошибке при попытке показать диалоговое окно, возвращаемое GooglePlayServicesUtil.getErrorDialog. Кто-нибудь знает, почему это может произойти?

Вот соответствующий код и Logcat, как сообщает acra:

Во время вызова этой линии:

int resultCode = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
if(resultCode != ConnectionResult.SUCCESS)
{
        //The dialog that comes back is null (probably due to the logcat message)
        Dialog dialog = GooglePlayServicesUtil.getErrorDialog(resultCode, this, 69);
        //So when I call the next line, the app crashes with a NullPointerException
        dialog.show();
}
...

Logcat:

12-18 04:21:04.531 W/GooglePlayServicesUtil( 3977): Google Play Store signature invalid.
12-18 04:21:04.551 E/GooglePlayServicesUtil( 3977): Google Play services is invalid. Cannot recover.

Заранее благодарим за любую помощь, которую вы можете предоставить.

Обновление

Google еще не решил эту проблему, и я обновлю этот вопрос, как только услышу что-нибудь (см. Ответ CommonsWare для ссылки на отчет об ошибке Google). В то же время, если вы столкнулись с этой проблемой и не хотите, чтобы ваше приложение зависало, вот что я делаю на данный момент:

public void checkGooglePlayServicesAvailability()
{
    int resultCode = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
    if(resultCode != ConnectionResult.SUCCESS)
    {
        Dialog dialog = GooglePlayServicesUtil.getErrorDialog(resultCode, this, 69);
        if(dialog != null)
        {
            dialog.show();                
        }
        else
        {
            showOkDialogWithText(this, "Something went wrong. Please make sure that you have the Play Store installed and that you are connected to the internet. Contact developer with details if this persists.");
        }
    }

    Log.d("GooglePlayServicesUtil Check", "Result is: " + resultCode);
}

public static void showOkDialogWithText(Context context, String messageText)
{
    Builder builder = new AlertDialog.Builder(context);
    builder.setMessage(messageText);
    builder.setCancelable(true);
    builder.setPositiveButton("OK", null);
    AlertDialog dialog = builder.create();
    dialog.show();
}
36
DiscDev

Google предлагает (также в docs ) вызвать getErrorDialog(), если код результата SERVICE_MISSING, SERVICE_VERSION_UPDATE_REQUIRED или SERVICE_DISABLED. Поэтому может случиться так, что последний возможный код состояния (SERVICE_INVALID) является причиной проблем.

Я использую следующий код, и пока он работает нормально (тестирование в эмуляторе, платформа 2.3.3):

int resultCode = GooglePlayServicesUtil.isGooglePlayServicesAvailable(activity.getApplicationContext());
if (resultCode == ConnectionResult.SUCCESS) {
    activity.selectMap();
} else if (resultCode == ConnectionResult.SERVICE_MISSING ||
           resultCode == ConnectionResult.SERVICE_VERSION_UPDATE_REQUIRED ||
           resultCode == ConnectionResult.SERVICE_DISABLED) {
    Dialog dialog = GooglePlayServicesUtil.getErrorDialog(resultCode, activity, 1);
    dialog.show();
}
37
Nevermore

Похоже, вы должны проверить с isUserRecoverableError, прежде чем пытаться отобразить диалоговое окно.

  int status = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
  if (status != ConnectionResult.SUCCESS) {
    if (GooglePlayServicesUtil.isUserRecoverableError(status)) {
      GooglePlayServicesUtil.getErrorDialog(status, this, 
      REQUEST_CODE_RECOVER_PLAY_SERVICES).show();
    } else {
      Toast.makeText(this, "This device is not supported.", 
          Toast.LENGTH_LONG).show();
      finish();
    }
  }
22
Rahim

Основываясь на коде Рахима, я добавляю возможность запретить пользователю закрывать диалоговое окно сервисов Google Play (нажав кнопку «Назад») и продолжать использовать приложение без установленных сервисов Google Play:

private void checkGooglePlayServicesAvailable() {
    int status = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
    if (status != ConnectionResult.SUCCESS) {
        if (GooglePlayServicesUtil.isUserRecoverableError(status)) {
            Dialog dialog = GooglePlayServicesUtil.getErrorDialog(status, this, 0);
            dialog.setOnCancelListener(new DialogInterface.OnCancelListener() {
                @Override
                public void onCancel(DialogInterface dialogInterface) {
                    MainActivity.this.finish();
                }
            });
            dialog.show();
        } else {
            Toast.makeText(this, "This device is not supported.", Toast.LENGTH_LONG).show();
            finish();
        }
    }
}
8
Daniele B

Обновление ответа с помощью @Nevermore , поскольку методы GooglePlayServicesUtil устарели в пользу GoogleApiAvailability

GoogleApiAvailability googleApiAvailability = GoogleApiAvailability.getInstance();
int resultCode = googleApiAvailability.isGooglePlayServicesAvailable(activity.getApplicationContext());
if (resultCode == ConnectionResult.SUCCESS) {
    activity.selectMap();
} else if (resultCode == ConnectionResult.SERVICE_MISSING ||
           resultCode == ConnectionResult.SERVICE_VERSION_UPDATE_REQUIRED ||
           resultCode == ConnectionResult.SERVICE_DISABLED) {
    Dialog dialog = googleApiAvailability.getErrorDialog(activity, resultCode, 1);
    dialog.show();
}

Обратите внимание, что порядок первых двух параметров в getErrorDialog() был изменен в реализации GoogleApiAvailability.

0
DaveAlden