Androidアプリで、setAlarmClockで指定した時刻にアラームを起動して、画面ロックを行う機能を実装しました。
アラームセットは以下の様に行っています。
Calendar calendar = Calendar.getInstance(); calendar.add(Calendar.MINUTE, 10); long alarmTime = calendar.getTimeInMillis(); PendingIntent p1 = PendingIntent.getActivity(context.getApplicationContext(), 0, new Intent(context.getApplicationContext(), StartActivity.class), 0); PendingIntent p2 = PendingIntent.getBroadcast(context.getApplicationContext(), 0, new Intent(context.getApplicationContext(), LockReceiver.class), PendingIntent.FLAG_UPDATE_CURRENT); ((AlarmManager) context.getSystemService(ALARM_SERVICE)).setAlarmClock(new AlarmManager.AlarmClockInfo(calendar.getTimeInMillis(),p1),p2);
LockReceiverは以下の様に行っています。
public class LockReceiverextends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Toast.makeText(context, "アプリケーションを終了します。", Toast.LENGTH_LONG).show(); try{ //AsyncHttpClientでパラメーターを取得して次の起動タイマーを取得 }catch (Exception e){ Log.e(LOG_TAG, e.getMessage()); } DevicePolicyManager mDevicePolicyManager; ComponentName mComponentName; mDevicePolicyManager = (DevicePolicyManager) context.getApplicationContext().getSystemService(Context.DEVICE_POLICY_SERVICE); mComponentName = new ComponentName(context.getApplicationContext(), AdminReceiver.class); if (!mDevicePolicyManager.isAdminActive(mComponentName)) { //権限不足の場合はアプリケーションを閉じる Intent i = new Intent(Intent.ACTION_MAIN); i.addCategory(Intent.CATEGORY_HOME); i.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); context.startActivity(i); }else{ //画面ロックを行う Log.d(LOG_TAG, "lockNow!"); mDevicePolicyManager.lockNow(); } } }
この際に、全ての端末でアラームは動作しますが、一部の端末では画面が消えない状態となります。
ログを採取したところ、onStop() が動いた直後(0.5秒前後)にonRestart() が動作していることから、
一旦画面ロックされてまた画面が点灯している様に見受けられます。
また、ログ上は権限も取得出来ており、lockNow!ログが取得出来ます。
onPause()やonStop()ではLog出力以外は特にロジックを入れていません。
考えられる原因やonRestartがなぜ動くかを調べる方法をご存知の方がいましたら教えて頂けないでしょうか。
動作環境は以下です。
Android バージョン
8.1.0
あなたの回答
tips
プレビュー