Le minuteur androïde sonne tard quand l'écran du téléphone est verrouillé
j'ai un service qui exécute un TimerTask dans une méthode, qui doit compter chaque seconde et faire quelque chose après un certain temps. Mon service fonctionne correctement et quand je commence la méthode en service, le minuteur commence à marquer chaque seconde (1000 millisecondes). Le problème est que, lorsque l'écran de l'appareil s'éteint, mon minuteur s'arrête parfois et ne compte pas correctement. Je peux voir dans le fichier journal que le minuteur s'arrête pendant 15 secondes, puis tourne 5 secondes, puis s'arrête à nouveau... Lorsque l'appareil est connecté à l'ordinateur, minuterie fonctionne toujours normalement, ce problème se produit quand j'ai débrancher l'appareil de l'ordinateur.
Voici mon service:
public class MyService extends Service {
private String TAG = getClass().getName();
public void count() {
Log.i(TAG, "Service Count Method Start");
int counter;
Timer mTimer = new Timer();
mTimer.schedule(new TimerTask() {
@Override
public void run() {
Log.i(TAG, "Timer count value : " + counter);
if (!someCondition) {
counter++;
if (DefaultApplication.notOnDisplayTime >= 180) {
Log.d(TAG, "APPLICATION REACHED TIME LIMIT!");
someCondition = true;
} else
someCondition = false;
} else {
counter = 0;
}
}
}, 0, 1000);
}
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return mBinder;
}
public class MyServiceBinder extends Binder {
public MyService getService() {
return MyService.this;
}
}
private final IBinder mBinder = new MyServiceBinder();
@Override
public boolean onUnbind(Intent intent) {
// TODO Auto-generated method stub
Log.i(TAG, "MyService Unbound");
return super.onUnbind(intent);
}
}
Et voici la sortie logcat:
04-25 14:35:22.951 I/com.mypackagename.MyService( 6745): Timer count value : 73
04-25 14:35:23.949 I/com.mypackagename.MyService( 6745): Timer count value : 74
04-25 14:35:24.019 D/dalvikvm( 6832): GC_FOR_MALLOC freed 6656 objects / 495856 bytes in 61ms
04-25 14:35:24.951 I/com.mypackagename.MyService( 6745): Timer count value : 75
04-25 14:35:25.951 I/com.mypackagename.MyService( 6745): Timer count value : 76
#### Écran est s'enfermer ici ####
04-25 14:35:26.929 I/power ( 96): *** set_screen_state 0]
04-25 14:35:26.959 V/KeyguardViewMediator( 96): password timeout now
04-25 14:35:26.959 D/KeyguardViewManager( 96): show()
04-25 14:35:26.999 D/Sensors ( 96): close_akm, fd=138
04-25 14:35:26.999 I/com.mypackagename.MyService( 6745): Timer count value : 77
04-25 14:35:27.039 D/HtcLockScreen( 96): onScreenRestart
04-25 14:35:27.039 I/HtcLockScreen( 96): updateStatusViewByPriority, mIsSimCheckView = false, mIsBatteryInfo = false, mIsMusicPlaying = false, mIsAirPlaneMode = false
04-25 14:35:27.049 I/HtcLockScreen( 96): HtcLockScreen:onResume
04-25 14:35:27.069 D/SurfaceFlinger( 96): Layer::setBuffers(this=0x785580), pid=96, w=480, h=762
04-25 14:35:27.079 D/SurfaceFlinger( 96): Layer::setBuffers(this=0x785580), pid=96, w=480, h=762
04-25 14:35:27.109 D/SurfaceFlinger( 96): Layer::requestBuffer(this=0x785580), index=0, pid=96, w=480, h=762 success
04-25 14:35:27.339 D/alogcat ( 6832): stopping ...
04-25 14:35:27.339 D/alogcat ( 6832): paused
04-25 14:35:27.609 D/SurfaceFlinger( 96): About to give-up screen, flinger = 0xb4e28
04-25 14:35:27.669 D/AK8973 ( 72): Compass CLOSE
#### Écran Verrouillé ####
04-25 14:35:27.949 I/com.mypackagename.MyService( 6745): Timer count value : 78
04-25 14:35:28.949 I/com.mypackagename.MyService( 6745): Timer count value : 79
04-25 14:35:44.602 I/com.mypackagename.MyService( 6745): Timer count value : 80
04-25 14:35:45.603 I/com.mypackagename.MyService( 6745): Timer count value : 81
04-25 14:35:45.784 I/wpa_supplicant( 256): CTRL-EVENT-SCAN-RESULTS Ready
04-25 14:35:45.799 D/LocationMasfClient( 96): getNetworkLocation(): Returning cache location with accuracy 75.0
04-25 14:35:46.603 I/com.mypackagename.MyService( 6745): Timer count value : 82
04-25 14:35:47.603 I/com.mypackagename.MyService( 6745): Timer count value : 83
04-25 14:35:48.604 I/com.mypackagename.MyService( 6745): Timer count value : 84
04-25 14:35:49.604 I/com.mypackagename.MyService( 6745): Timer count value : 85
04-25 14:36:10.558 D/SurfaceFlinger( 96): Layer::requestBuffer(this=0x785580), index=1, pid=96, w=480, h=762 success
04-25 14:36:11.033 I/com.mypackagename.MyService( 6745): Timer count value : 86
04-25 14:36:13.269 I/com.mypackagename.MyService( 6745): Timer count value : 87
04-25 14:36:13.289 D/com.mypackagename.utils.XUtil( 6745): return 0 char $
04-25 14:36:14.039 D/com.mypackagename.utils.XUtil( 6745): return 0 char $
04-25 14:36:14.269 I/com.mypackagename.MyService( 6745): Timer count value : 88
04-25 14:36:17.009 I/com.mypackagename.MyService( 6745): Timer count value : 89
04-25 14:36:29.512 I/com.mypackagename.MyService( 6745): Timer count value : 90
vous pouvez voir qu'après le verrouillage de l'écran, le minuteur ne semble pas pointer chaque seconde. Il s'arrête pendant 15 à 20 secondes puis fonctionne normalement 5 secondes...
avez-vous une opinion sur la façon d'empêcher le minuteur de s'arrêter lorsque l'écran de l'appareil est verrouillé?
1 réponses
Sons comme vous avez besoin d'un Verrouillage De Sillage Partiel Cela empêchera L'unité centrale de dormir lorsque l'écran est éteint. Soyez averti cependant, l'utilisation abusive peut causer des problèmes de batterie et vous avez besoin d'une permission pour utiliser les serrures wake.