スリープ中にアラームが受信されません。
アラームが鳴ったらビューを更新するために、アラームを深夜に設定しています。デバイスが起動しているときにアラームが機能します-時間を真夜中などに変更してこれをテストしました。ただし、電話でテストすると、スリープ中に機能しません。真夜中の数時間前にスマートフォンをスリープ状態にし、午前 8 時頃にアプリをチェックしました。ただし、ビューは更新されなかったので、アラームが受信されなかったと想定しました。
エミュレータで次のことを試しました-真夜中の直前にデバイスをスリープ状態にし、真夜中にデバイスを起動します。ただし、データが更新されていることがわかり、ログでアラームが受信されます。
以下のコードで私が間違ったことについてのアイデアはありますか?
アクティビティ:
@Override
protected void onResume(){
super.onResume();
updateReceiver = new AlarmReceiver(new AlarmReceiverCallback(){
@Override
public void onAlarmReceived(Intent intent) {
//update view code
}
});
IntentFilter updateIntentFilter = new IntentFilter("alarm");
registerReceiver(updateReceiver,updateIntentFilter);
}
@Override
protected void onPause(){
super.onPause();
if(this.updateReceiver!=null){
unregisterReceiver(updateReceiver);
}
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//set up view
setRecurringDailyAlarm();
}
private void setRecurringDailyAlarm(){
Calendar updateTime = Calendar.getInstance();
updateTime.setTimeInMillis(System.currentTimeMillis());
//daily alarm at midnight
updateTime.set(Calendar.HOUR_OF_DAY,00);
updateTime.set(Calendar.MINUTE,00);
updateTime.set(Calendar.SECOND,00);
Log.d(TAG, "Alarm time is: " + updateTime.getTime());
Intent myIntent = new Intent();
myIntent.setAction("alarm");
PendingIntent recurringAlarm = PendingIntent.getBroadcast(MainActivity.this, ALARM_ID, myIntent,
PendingIntent.FLAG_CANCEL_CURRENT);
AlarmManager alarms = (AlarmManager)getSystemService(Context.ALARM_SERVICE);
alarms.setRepeating(AlarmManager.RTC_WAKEUP, updateTime.getTimeInMillis(),
AlarmManager.INTERVAL_DAY, recurringAlarm);
}
マニフェスト:
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".receiver.BootUpReceiver" android:enabled="true" android:exported="false"
android:permission="android.premission.RECEIVE_BOOT_COMPLETED">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
<receiver android:name="com.test.receiver.RestartReceiver" android:enabled="true" android:process=":remote"></receiver>
==編集
コードを次のように変更するとIntent myIntent = new Intent(this, AlarmReceiver.class);
次のようにアラームレシーバーを実装しているため、これによりアプリでエラーがスローされます。「コールバック」を使用して UI を更新しています
アラーム受信クラス:
interface AlarmReceiverCallback{
public void onAlarmReceived(Intent intent);
}
public class AlarmReceiver extends BroadcastReceiver{
private AlarmReceiverCallback callback;
public AlarmReceiver(AlarmReceiverCallback callback){
this.callback = callback;
}
@Override
public void onReceive(Context context, Intent intent) {
callback.onAlarmReceived(intent);
}
}
エラーログ:
01-25 16:05:38.655: D/dalvikvm(810): newInstance failed: no <init>()
01-25 16:05:38.686: D/AndroidRuntime(810): Shutting down VM
01-25 16:05:38.686: W/dalvikvm(810): threadid=1: thread exiting with uncaught exception (group=0x40a70930)
01-25 16:05:38.785: E/AndroidRuntime(810): FATAL EXCEPTION: main
01-25 16:05:38.785: E/AndroidRuntime(810): java.lang.RuntimeException: Unable to instantiate receiver com.test.receiver.AlarmReceiver: java.lang.InstantiationException: can't instantiate class com.test.receiver.AlarmReceiver; no empty constructor
01-25 16:05:38.785: E/AndroidRuntime(810): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2357)
01-25 16:05:38.785: E/AndroidRuntime(810): at android.app.ActivityThread.access$1500(ActivityThread.java:141)
01-25 16:05:38.785: E/AndroidRuntime(810): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1310)
01-25 16:05:38.785: E/AndroidRuntime(810): at android.os.Handler.dispatchMessage(Handler.java:99)
01-25 16:05:38.785: E/AndroidRuntime(810): at android.os.Looper.loop(Looper.java:137)
01-25 16:05:38.785: E/AndroidRuntime(810): at android.app.ActivityThread.main(ActivityThread.java:5039)
01-25 16:05:38.785: E/AndroidRuntime(810): at java.lang.reflect.Method.invokeNative(Native Method)
01-25 16:05:38.785: E/AndroidRuntime(810): at java.lang.reflect.Method.invoke(Method.java:511)
01-25 16:05:38.785: E/AndroidRuntime(810): at