Кажущаяся задержка между обратным вызовом разрешений и предоставленными разрешениями - PullRequest
0 голосов
/ 17 декабря 2018

Итак, это приложение Lollipop (5.0) с загрузочным приемником.Загрузочный приемник запускает действие (SplashActivity.class).Цель SplashActivity - получить все необходимые разрешения до запуска MainActivity.class.

public class SplashActivity extends Activity {

private static boolean bPermission = false;
private static final int MY_PERMISSIONS_REQUEST = 100;
private static final String[] allRequestedPermissions = new String[] {
        Manifest.permission.READ_CONTACTS,
        Manifest.permission.SEND_SMS,
        Manifest.permission.CALL_PHONE
};

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    if(getIntent().hasExtra("PERMISSION_FOR_SERVICE")) {
        bPermission = true;
    }
    if (!checkAllRequestedPermissions()) {
        ActivityCompat.requestPermissions(this, allRequestedPermissions, MY_PERMISSIONS_REQUEST);
    }
    else {
        startMainActivity();
    }
}

private boolean checkAllRequestedPermissions() {
    for (String permission : allRequestedPermissions) {
        if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) {
            return false;
        }
    }
    return true;
}

private boolean isServiceRunning(Class<?> serviceClass) {
    ActivityManager manager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
    for (ActivityManager.RunningServiceInfo service : manager.getRunningServices(Integer.MAX_VALUE)) {
        if (serviceClass.getName().equals(service.service.getClassName())) {
            return true;
        }
    }
    return false;
}

@Override
public void onRequestPermissionsResult(int requestCode,
                                       String permissions[], int[] grantResults) {
    switch (requestCode) {
        case MY_PERMISSIONS_REQUEST: {
            if (checkAllRequestedPermissions()) {
                    startMainActivity();
            }
            else {
                finish();
            }
            return;
        }

        // other 'case' lines to check for other
        // permissions this app might request
    }
}

private void startMainActivity() {
    Intent intent = new Intent(this, MainActivity.class);
    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | IntentCompat.FLAG_ACTIVITY_CLEAR_TASK);
    if(bPermission) {
        intent.putExtra("PERMISSION_FOR_SERVICE","_");
    }
    startActivity(intent);
}

}

Что в итоге происходит после всех проверок и запросов разрешений (если вы прокрутите довнизу) он запускает MainActivity.

Проблема в том, что я предпочел бы, чтобы он не запускал MainActivity в случае, когда bPermission == true.Если bPermission == true, предпочтет следующее поведение:

private void startMainActivity() {
    if(bPermission) {
        startService(new Intent(this, SchedulerService.class));
        finish();
    }
    else {
        Intent intent = new Intent(this, MainActivity.class);
        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | IntentCompat.FLAG_ACTIVITY_CLEAR_TASK);

        intent.putExtra("PERMISSION_FOR_SERVICE", "_");
        startActivity(intent);
    }

}

Но это приводит к сбою приложения.Есть идеи, что может быть не так?Заранее большое спасибо

РАЗРЕШЕНО: У моего сервиса была зависимость, о которой он не знал.Инициализация зависимости до запуска службы исправлена ​​ошибка!Спасибо @ Mike м. !!

1 Ответ

0 голосов
/ 17 декабря 2018

РАЗРЕШЕНО: У моей службы была зависимость, о которой не было известно.Инициализация зависимости до запуска службы исправлена ​​ошибка!Спасибо @Mike M. !!

...