AlarmManager 有时不唤醒 phone (XPERIA)
AlarmManager doesn't wake up the phone sometimes (XPERIA)
我使用 JellyBean,而不是 KitKat 或更高版本 API,因此应该在正确的时间调用 onReceive
方法。
问题是大多数时候我的 phone 被唤醒,只是有时没有(我查看日志保存的时间)。
这就是我创建待定意向的方式:
PendingIntent pendingIntent;
AlarmManager manager;
Intent alarmIntent = new Intent(this, AlarmReceiver.class);
pendingIntent = PendingIntent.getBroadcast(this, idSms, alarmIntent, 0);
manager.set(AlarmManager.RTC_WAKEUP, time, pendingIntent);
现在 BroadcastReceiver
:
public class AlarmReceiver extends BroadcastReceiver {
private static final String TAG = "AlarmReceiver";
@Override
public void onReceive(Context arg0, Intent arg1) {
Log.d(TAG, "onReceive()");
}
}
所以,就是这样。 BroadcastReceiver
是在 Manifest 中声明的,正如我之前写的那样它大部分时间都有效,但有时我必须自己转动我的 phone 才能看到日志......
我读了几个主题,我没有找到任何答案为什么会发生。
我也知道 WakeLocker
,我在日志之后尝试这样做,但我检查了 onReceive
我认为甚至没有被调用,至少日志有时不显示它。
希望得到一些建议或解释为什么它不能一直工作。
谢谢
编辑 1:我添加了一些代码,当 phone 正在睡觉时仍然不起作用:
public void onReceive(Context arg0, Intent arg1) {
PowerManager pm = (PowerManager) arg0.getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "WakeLock");
wl.acquire();
Log.d(TAG, "onReceive()");
wl.release();
}
编辑 2:更改代码:
public class AlarmReceiver extends WakefulBroadcastReceiver {
private static final String TAG = "AlarmWakefulReceiver";
@Override
public void onReceive(Context arg0, Intent arg1) {
Log.d(TAG, "onReceive()");
Intent service = new Intent(arg0, SmsService.class);
Log.d(TAG, "Creating service");
startWakefulService(arg0, service);
}
}
public class SmsService extends IntentService {
private static final String TAG = "IntentService";
public SmsService() {
super("SmsService");
}
@Override
protected void onHandleIntent(Intent intent) {
Toast.makeText(this, "Service completed", Toast.LENGTH_SHORT).show();
Log.i(TAG, "Completed service");
AlarmReceiver.completeWakefulIntent(intent);
}
}
服务已注册并运行,我在 8:47 上设置了时间,在 8:49 上检查了 phone 并在那个时候获得了 onReceive()。日志:
01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): onReceive()
01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): Creating service
01-15 08:49:04.914: I/IntentService(32576): Completed service
编辑 3:
我在 phone 上测试了这个:http://wptrafficanalyzer.in/blog/setting-up-alarm-using-alarmmanager-and-waking-up-screen-and-unlocking-keypad-on-alarm-goes-off-in-android/
我的phone是Xperia L,系统4.2.2
http://commonsware.com/blog/2013/03/08/warning-xperia-z-stamina-alarmmanager.html
我有 Xperia L 并检查了这个 link...嗯...我的 Xperia 有 Stamina 模式。似乎 Stamina 有时会阻止我的唤醒功能。
要解决此问题,您需要转到电源管理选项,转到耐力模式并将其关闭或将我们的应用程序设置为例外。到目前为止工作正常,我会测试更多并判断是否有问题!
编辑 1:
10:04 - 我将闹钟设置为在 10:21 触发,在 10:28 检查了效果,有效!
日志:
01-15 10:21:16.804: D/AlarmWakefulReceiver(11202): onReceive()
01-15 10:21:16.814: D/AlarmWakefulReceiver(11202): Creating service
01-15 10:21:16.834: I/IntentService(11202): Completed service
我使用 JellyBean,而不是 KitKat 或更高版本 API,因此应该在正确的时间调用 onReceive
方法。
问题是大多数时候我的 phone 被唤醒,只是有时没有(我查看日志保存的时间)。
这就是我创建待定意向的方式:
PendingIntent pendingIntent;
AlarmManager manager;
Intent alarmIntent = new Intent(this, AlarmReceiver.class);
pendingIntent = PendingIntent.getBroadcast(this, idSms, alarmIntent, 0);
manager.set(AlarmManager.RTC_WAKEUP, time, pendingIntent);
现在 BroadcastReceiver
:
public class AlarmReceiver extends BroadcastReceiver {
private static final String TAG = "AlarmReceiver";
@Override
public void onReceive(Context arg0, Intent arg1) {
Log.d(TAG, "onReceive()");
}
}
所以,就是这样。 BroadcastReceiver
是在 Manifest 中声明的,正如我之前写的那样它大部分时间都有效,但有时我必须自己转动我的 phone 才能看到日志......
我读了几个主题,我没有找到任何答案为什么会发生。
我也知道 WakeLocker
,我在日志之后尝试这样做,但我检查了 onReceive
我认为甚至没有被调用,至少日志有时不显示它。
希望得到一些建议或解释为什么它不能一直工作。 谢谢
编辑 1:我添加了一些代码,当 phone 正在睡觉时仍然不起作用:
public void onReceive(Context arg0, Intent arg1) {
PowerManager pm = (PowerManager) arg0.getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "WakeLock");
wl.acquire();
Log.d(TAG, "onReceive()");
wl.release();
}
编辑 2:更改代码:
public class AlarmReceiver extends WakefulBroadcastReceiver {
private static final String TAG = "AlarmWakefulReceiver";
@Override
public void onReceive(Context arg0, Intent arg1) {
Log.d(TAG, "onReceive()");
Intent service = new Intent(arg0, SmsService.class);
Log.d(TAG, "Creating service");
startWakefulService(arg0, service);
}
}
public class SmsService extends IntentService {
private static final String TAG = "IntentService";
public SmsService() {
super("SmsService");
}
@Override
protected void onHandleIntent(Intent intent) {
Toast.makeText(this, "Service completed", Toast.LENGTH_SHORT).show();
Log.i(TAG, "Completed service");
AlarmReceiver.completeWakefulIntent(intent);
}
}
服务已注册并运行,我在 8:47 上设置了时间,在 8:49 上检查了 phone 并在那个时候获得了 onReceive()。日志:
01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): onReceive()
01-15 08:49:04.894: D/AlarmWakefulReceiver(32576): Creating service
01-15 08:49:04.914: I/IntentService(32576): Completed service
编辑 3: 我在 phone 上测试了这个:http://wptrafficanalyzer.in/blog/setting-up-alarm-using-alarmmanager-and-waking-up-screen-and-unlocking-keypad-on-alarm-goes-off-in-android/
我的phone是Xperia L,系统4.2.2
http://commonsware.com/blog/2013/03/08/warning-xperia-z-stamina-alarmmanager.html
我有 Xperia L 并检查了这个 link...嗯...我的 Xperia 有 Stamina 模式。似乎 Stamina 有时会阻止我的唤醒功能。
要解决此问题,您需要转到电源管理选项,转到耐力模式并将其关闭或将我们的应用程序设置为例外。到目前为止工作正常,我会测试更多并判断是否有问题!
编辑 1:
10:04 - 我将闹钟设置为在 10:21 触发,在 10:28 检查了效果,有效!
日志:
01-15 10:21:16.804: D/AlarmWakefulReceiver(11202): onReceive()
01-15 10:21:16.814: D/AlarmWakefulReceiver(11202): Creating service
01-15 10:21:16.834: I/IntentService(11202): Completed service