Подтвердить что ты не робот

Отключенная блокировка блокировки клавиатуры повторно активирует себя после нажатия на уведомление

В моем приложении я отключу блокировку блокировки клавиатуры (например, Remove Lockscreen), используя приведенный ниже код, и он работает нормально, пока я не нажму на любое уведомление в панели уведомлений. Если я нажимаю на уведомление, экран блокировки автоматически включается. Любая помощь приветствуется.

private void remove_lockscreen() {
    final CheckBoxPreference lock = (CheckBoxPreference) findPreference("remove_lockscreen");
    KeyguardManager km = (KeyguardManager)getSystemService(KEYGUARD_SERVICE);
    KeyguardLock kl = km.newKeyguardLock("keyguard_lock");
    if (lock.isChecked()) {
        prefEdit("remove_lockscreen", 1);
        Toast.makeText(getBaseContext(), "Lockscreen will not be shown", Toast.LENGTH_SHORT).show();
        kl.disableKeyguard();
    }
    else if (!lock.isChecked()) {
        prefEdit("remove_lockscreen", 0);
        Toast.makeText(getBaseContext(), "Lockscreen will be shown", Toast.LENGTH_SHORT).show();
        kl.reenableKeyguard();
        android.os.Process.killProcess(android.os.Process.myPid());
    }
}
4b9b3361

Ответ 1

Я заметил ту же проблему в течение некоторого времени. Это происходит только на Honeycomb (Android 3.0) и выше. После большого количества экспериментов и вытягивания волос я, похоже, нашел решение, которое работает для меня. Непонятно, что происходит или почему, но вот что я понял.

Похоже, что в Android 3.0+ после того, как блокировка клавиатуры отключена, при нажатии уведомления истекает срок действия старого KeyguardLock, но, к счастью, в этом случае будет запущена трансляция ACTION_USER_PRESENT, поэтому у нас есть возможность исправить проблему.

Один момент, который не совсем очевидно из документации, состоит в том, что кажется необходимым переустановить старый KeyguardLock, прежде чем получить новый и снова отключить его. Еще одна "пропасть", которую я обнаружил, заключается в том, что отключение через новый KeyguardLock сразу после повторного подключения через старый вызывает только прерывистый успех. Я решил это, ожидая 300 мсек до отключения.

Здесь немного упрощенная версия моего кода; его следует легко адаптировать к вашему приложению:

private KeyguardLock kl;
private KeyguardManager km;

private final Handler mHandler = new Handler();

private final Runnable runDisableKeyguard = new Runnable() {
    public void run() {
        kl = km.newKeyguardLock(getPackageName());
        kl.disableKeyguard();
    }
};

private void setEnablednessOfKeyguard(boolean enabled) {
    if (enabled) {
        if (kl != null) {
            unregisterReceiver(mUserPresentReceiver);
            mHandler.removeCallbacks(runDisableKeyguard);
            kl.reenableKeyguard();
            kl = null;
        }
    } else {
        if (km.inKeyguardRestrictedInputMode()) {
            registerReceiver(mUserPresentReceiver, userPresent);
        } else {
            if (kl != null)
                kl.reenableKeyguard();
            else
                registerReceiver(mUserPresentReceiver, userPresent);

            mHandler.postDelayed(runDisableKeyguard,  300);
        }
    }
}

private final BroadcastReceiver mUserPresentReceiver = new BroadcastReceiver() {
    @Override
    public void onReceive(Context context, Intent intent) {
        if (Intent.ACTION_USER_PRESENT.equals(intent.getAction())){
            if (sp_store.getBoolean(KEY_DISABLE_LOCKING, false))
                setEnablednessOfKeyguard(false);
        }
    }
};