4

我在广播接收器中接收到一个意图,然后我开始服务做更多的工作。现在如果设备处于睡眠状态并且发生这种情况怎么办,我是否必须获得唤醒锁(AlarmManger?),我为什么需要它?如果设备在没有唤醒锁的情况下进入睡眠状态,我的服务会停止运行吗?

4

3 回答 3

5

现在如果设备处于睡眠状态并且发生这种情况怎么办,我是否必须获得唤醒锁(AlarmManger?),我为什么需要它?

如果设备一开始就处于睡眠状态,您将不会“在广播接收器中接收到意图”,因为设备处于睡眠状态。

我是否必须获得 Wakelock(AlarmManger?),我为什么需要它?

您不需要它,除非您想确保设备在完成某些工作时保持运行。

如果设备在没有唤醒锁的情况下进入睡眠状态,我的服务会停止运行吗?

是的。

于 2011-04-15T19:07:01.567 回答
1

看起来 Android 的原生WakefulBroadcastReceiver将是您的完美解决方案。需要扩展它而不是常规的BroadcastReceiver并以“唤醒”方式在onReceive()中启动服务:

startWakefulService(context, service);

并表示您的工作已在服务的onHandleIntent()中完成,调用

MyWakefulReceiver.completeWakefulIntent(intent);
于 2016-08-24T10:26:21.967 回答
0
public class WakeLockManager extends BroadcastReceiver {

    private static WakeLock mWakeLock;
    private String LCLT;

    @Override
    public void onReceive(Context context, Intent intent) {
        if (intent.getAction().equals(Consts.WAKELOCK_INTENT)) {
            Log.v("wakelock", "GOT THE wakelock INTENT");
            boolean on = intent.getExtras().getBoolean("on");
            if (mWakeLock == null) {
                PowerManager pm = (PowerManager) context
                        .getSystemService(Context.POWER_SERVICE);
                mWakeLock = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK,
                        "Breeze WakeLock");
            }
            if (on) {
                if (!mWakeLock.isHeld()) {
                    mWakeLock.acquire();
                    Log.v("wakelock", "acquiring wakelock");
                }
            } else {
                if (mWakeLock.isHeld()) {
                    Log.v("wakelock", "releasing wakelock");
                    mWakeLock.release();
                }
                mWakeLock = null;
            }
        }
    }
}

看看上面的代码..把它放在一个单独的类文件中,并在你的清单中为一些自定义意图定义它......现在这个类将响应一个自定义意图......只需广播那个意图,你就可以转由于唤醒锁是静态的,因此在整个应用程序中打开或关闭唤醒锁......就像这样:

public void setWakeup(boolean status) {
    Intent wakelock_Intent = new Intent(CUSTOM_INTENT);
    wakelock_Intent.putExtra("on", status);
    this.sendBroadcast(wakelock_Intent);
}

以上将在您的警报管理器代码中定义,因此它会安排通话

于 2012-08-10T13:14:03.880 回答