我已经有一个问题很长时间了,我发现CWAC清醒,这可以解决我的所有问题。我想…“:”(
简而言之,为了解决这个问题,我实现了一个最简单的应用程序,它每60秒安排一次警报,每次记录。
这是我的代码:
主要活动:

package com.par.hasard.mysimpleapplication;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button button = (Button)findViewById(R.id.myExportButton);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                MyLogManager.copyLogToClipboard(view.getContext());
                MyLogManager.emptyLogFile(view.getContext());
            }
        });
        try {
            MyLogManager.createLogFile(this);
            MyLogManager.write(this, "Application launched\n");
            MyAlarmPlanner.planAlarm_v2(this);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

我的AlarmPlanner:
package com.par.hasard.mysimpleapplication;

import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.os.SystemClock;
import android.widget.Toast;
import com.commonsware.cwac.wakeful.WakefulIntentService;
import java.io.IOException;

public class MyAlarmPlanner {
    public static void planAlarm_v2(Context context) throws IOException {
        MyLogManager.write(context, "Beginning of planAlarm_v2\n");
        WakefulIntentService.scheduleAlarms(new MyAppListener(), context, true);
        MyLogManager.write(context, "End of planAlarm_v2\n");
    }
}

MyApplistener公司:
package com.par.hasard.mysimpleapplication;

import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.Context;
import android.os.SystemClock;

import com.commonsware.cwac.wakeful.AlarmReceiver;
import com.commonsware.cwac.wakeful.WakefulIntentService;

import java.io.IOException;

public class MyAppListener implements WakefulIntentService.AlarmListener {
    @Override
    public void scheduleAlarms(AlarmManager alarmManager, PendingIntent pendingIntent, Context context) {
        try {
            MyLogManager.write(context, "Beginning of scheduleAlarms\n");
            alarmManager.setExact(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime()+60000, pendingIntent);
            MyLogManager.write(context, "End of scheduleAlarms\n");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void sendWakefulWork(Context context) {
        try {
            MyLogManager.write(context, "Beginning of sendWakefulWork\n");
            WakefulIntentService.sendWakefulWork(context, MyAppService.class);
            MyLogManager.write(context, "End of sendWakefulWork\n");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Override
    public long getMaxAge(Context context) {
        return (AlarmManager.INTERVAL_FIFTEEN_MINUTES * 2);
    }
}

我的应用程序服务:
package com.par.hasard.mysimpleapplication;
import android.content.Intent;
import com.commonsware.cwac.wakeful.WakefulIntentService;
import java.io.IOException;

public class MyAppService extends WakefulIntentService {
    public MyAppService(){
        super("MyAppService");
    }

    @Override
    protected void doWakefulWork(Intent intent) {
        try {
            MyLogManager.write(this, "Beginning of doWakefulWork\n");
            MyAlarmPlanner.planAlarm_v2(this);
            MyLogManager.write(this, "End of doWakefulWork\n");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

显示:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.par.hasard.mysimpleapplication">
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />


    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <receiver android:name="com.par.hasard.mysimpleapplication.MySimpleWakefulReceiver">
            <intent-filter android:priority="1">
                <action android:name="com.par.hasard.mysimpleapplication.REGULAR_ALARM" />
            </intent-filter>
        </receiver>

        <receiver android:name="com.commonsware.cwac.wakeful.AlarmReceiver">
            <intent-filter>
                <action android:name="android.intent.action.BOOT_COMPLETED"/>
            </intent-filter>

            <meta-data
                android:name="com.commonsware.cwac.wakeful"
                android:resource="@xml/wakeful"/>
        </receiver>
        <service android:enabled="true" android:name="com.par.hasard.mysimpleapplication.MySimpleWakefulService" />
        <service android:enabled="true" android:name="com.par.hasard.mysimpleapplication.MyAppService" />
    </application>

</manifest>

wakeful.xml文件:
<WakefulIntentService
    listener="com.par.hasard.mysimpleapplication.MyAppListener"
    />

所有这些工作都很好,但有时,它不会记录任何东西。我想是因为我手机的睡眠模式(索尼Xperia)。但在其他手机上似乎也有同样的行为。
下面是日志的一个示例:
18/12 2h47m37s304 => Beginning of sendWakefulWork
18/12 2h47m37s311 => End of sendWakefulWork
18/12 2h47m37s316 => Beginning of doWakefulWork
18/12 2h47m37s317 => Beginning of planAlarm_v2
18/12 2h47m37s320 => Beginning of scheduleAlarms
18/12 2h47m37s322 => End of scheduleAlarms
18/12 2h47m37s323 => End of planAlarm_v2
18/12 2h47m37s324 => End of doWakefulWork
18/12 2h48m37s332 => Beginning of sendWakefulWork
18/12 2h48m37s338 => End of sendWakefulWork
18/12 2h48m37s347 => Beginning of doWakefulWork
18/12 2h48m37s348 => Beginning of planAlarm_v2
18/12 2h48m37s350 => Beginning of scheduleAlarms
18/12 2h48m37s351 => End of scheduleAlarms
18/12 2h48m37s352 => End of planAlarm_v2
18/12 2h48m37s353 => End of doWakefulWork
18/12 3h35m6s293 => Beginning of sendWakefulWork    //nothing before ??
18/12 3h35m6s298 => End of sendWakefulWork
18/12 3h35m6s319 => Beginning of doWakefulWork
18/12 3h35m6s327 => Beginning of planAlarm_v2
18/12 3h35m6s331 => Beginning of scheduleAlarms
18/12 3h35m6s338 => End of scheduleAlarms
18/12 3h35m6s340 => End of planAlarm_v2
18/12 3h35m6s345 => End of doWakefulWork
18/12 3h36m7s307 => Beginning of sendWakefulWork
18/12 3h36m7s313 => End of sendWakefulWork
18/12 3h36m7s319 => Beginning of doWakefulWork
18/12 3h36m7s320 => Beginning of planAlarm_v2
18/12 3h36m7s322 => Beginning of scheduleAlarms
18/12 3h36m7s323 => End of scheduleAlarms
18/12 3h36m7s324 => End of planAlarm_v2
18/12 3h36m7s325 => End of doWakefulWork

有人能帮我吗?

最佳答案

从时间间隔来看,很可能你在android 6.0+设备上体验到了打盹模式,或者是一些老设备制造商提供的类似模式(例如,索尼的耐力模式)。除了将您的应用程序添加到适当的白名单(例如,用于打瞌睡、设置>应用程序>(齿轮图标)>特殊访问>电池优化)之外,您几乎无能为力。
欢迎您切换到API级别23+设备上的setExactAndAllowWhileIdle(),但是:
你不会每分钟都有控制权(我认为限制在每9分钟)
当你获得控制权时,你将无法访问互联网(这可能是你真正想要做的事情所必需的)
这对于制造商特定的前6.0设备(因为该方法不存在)是无济于事的。
总的来说,设计你的应用程序来处理打瞌睡的模式,而不是假设它会在后台得到控制,是一个更可靠的方法。

关于android - sendWakefulWork并不总是与cwac-wakeful-1.1.0一起调用,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41301575/

10-09 02:36