Wake Locks Android-сервис повторяющихся - PullRequest
7 голосов
/ 13 марта 2011

У меня есть это приложение, которое должно запускать службу (фоновый режим), которая периодически подает звуковой сигнал.Телефон должен подавать звуковой сигнал весь день в течение 5 секунд каждую минуту (в сервисе используется обработчик).Я реализовал этот сервис, который делает это прекрасно, но когда телефон переходит в режим глубокого сна, выполнение этого обработчика останавливается.Используя этот ответ на вопрос в SO, мне удалось использовать блокировку от пробуждения, и она отлично работает.Но когда я явно переведу телефон в режим глубокого сна, обработчик прекращает выполнение.Где я могу разместить wakelock в сервисе.Фрагмент кода ниже.

public class PlaySound extends Service{
PowerManager.WakeLock wl ;
    PowerManager pm;
private SoundManager mSoundManager;
    boolean wakeUpFlag = false;

@Override
    public void onCreate(){
        super.onCreate();
        mSoundManager = new SoundManager();
        mSoundManager.initSounds(getBaseContext());
        mSoundManager.addSound(1, R.raw.sound);
    }
@Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        startservice();
        return START_STICKY;
    }
private void startservice() {
        System.out.println("Started the service");
        timer.scheduleAtFixedRate( new TimerTask() {
            public void run() {
                toastHandler.sendEmptyMessage(0);
            }
        }, 0, 60000);
    }
private final Handler toastHandler = new Handler()
    {
        @Override
        public void handleMessage(Message msg)
        {
            result =start();

                System.out.println("result"+result);
                close();
        }
    };

protected void close() {
        try {
            if(wakeUpFlag){
                wl.release();
                System.out.println("Released the wakelock");
            }

            if(!pm.isScreenOn()){
                System.out.println("Screen is off - back to sleep");
                pm.goToSleep(1000);
            }
            else{
                System.out.println("Screen is on - no need to sleep");
            }
            bs.close();
            writer.close();
            System.out.println("Closed socket and writer");
            System.out.println("Size of file:"+f.length()/1024);
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
public void start(){
        try{
            wakeUpFlag = false;
            pm = (PowerManager)getSystemService(Context.POWER_SERVICE);


            if(!pm.isScreenOn()) {
                wakeUpFlag  = true;
                wl = pm.newWakeLock(PowerManager.SCREEN_DIM_WAKE_LOCK | PowerManager.ON_AFTER_RELEASE,"CollectData");
                System.out.println("Screen off - wake lock acquired");
                wl.acquire();
            }
            else{
                System.out.println("Screen on - no need of wake lock");
            }



        }
        catch(Exception e){
            e.printStackTrace();
        }
mSoundManager.playSound(1);
}

Ответы [ 3 ]

4 голосов
/ 13 марта 2011

Я не думаю, что вы используете правильный флаг в соответствии с документацией для Android fior PowerManager :

* Если вы удерживаете частичную блокировку, процессор продолжит работу независимо от таймеров и даже после того, как пользователь нажмет кнопку питания. Во всех других блокировках пробуждения процессор будет работать, но пользователь все равно сможет перевести устройство в спящий режим с помощью кнопки питания.

Другими словами, попробуйте использовать PARTIAL_WAKE_LOCK, так как это единственный процессор, который гарантирует запуск процессора

3 голосов
/ 13 марта 2011

Следуйте шаблону, который Марк Мерфи предоставляет с помощью WakefulIntentService . Я бы предложил поднять его книги не только для подробного объяснения этого класса и примера, который он включает в одну из них, но и для другой информации, которую вы найдете в них.

Я только недавно реализовал этот шаблон для своего основного приложения, и этот класс работает как шарм.

1 голос
/ 29 октября 2011

Я думаю, вам лучше использовать android.app.AlarmManager для планирования будильника. Однако будьте осторожны - вы не хотите выполнять какую-либо длительную работу в вашем методе onReceive (), так как он обычно вызывается в основном потоке и будет зависать. Вам все еще нужно будет приобрести замок для пробуждения на время выполнения задачи, чтобы телефон не спал на полпути.

...