Información: Mi dispositivo es un Nexus One con 2.2 y he probado dos proyectos, uno en 1.5 y uno en 2.1.Problemas para comprender el ciclo de vida cuando la pantalla se apaga y en
Problema: Tengo problemas para comprender el ciclo de vida de mi aplicación cuando la pantalla está apagada y encendida.
Aquí está mi salida
// activity starts
08-04 17:24:17.643: ERROR/PlayActivity(6215): onStart executes ...
08-04 17:24:17.643: ERROR/PlayActivity(6215): onResume executes ...
// screen goes off
08-04 17:24:28.943: ERROR/PlayActivity(6215): onPause executes ...
08-04 17:24:32.113: ERROR/PlayActivity(6215): onStop executes ...
08-04 17:24:32.113: ERROR/PlayActivity(6215): onDestroy executes ...
08-04 17:24:32.983: ERROR/PlayActivity(6215): onStart executes ...
08-04 17:24:32.983: ERROR/PlayActivity(6215): onResume executes ...
08-04 17:24:32.983: ERROR/PlayActivity(6215): onPause executes ...
// screen goes on
08-04 17:24:47.683: ERROR/PlayActivity(6215): onResume executes ...
// lock removed
08-04 17:24:56.943: ERROR/PlayActivity(6215): onPause executes ...
08-04 17:24:59.663: ERROR/PlayActivity(6215): onStop executes ...
08-04 17:24:59.663: ERROR/PlayActivity(6215): onDestroy executes ...
08-04 17:25:00.943: ERROR/PlayActivity(6215): onStart executes ...
08-04 17:25:00.943: ERROR/PlayActivity(6215): onResume executes ...
estoy totalmente confundido. ¿Por qué reiniciar la actividad cuando la pantalla se apaga? ¿Y por qué parar y volver a iniciarlo cuando la pantalla ya estaba encendida y solo se quitó el bloqueo?
Para asegurarme de no haber hecho nada incorrecto, creé un nuevo proyecto con solo esta actividad. El resultado es idéntico ...
public class LifeCycleTest extends Activity {
private final static String DEBUG_TAG = "FirstLifeLog";
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Log.e(DEBUG_TAG, "onCreate executes ...");
setContentView(R.layout.main);
}
protected void onRestart() {
super.onRestart();
Log.e(DEBUG_TAG, "onRestart executes ...");
}
protected void onStart() {
super.onStart();
Log.e(DEBUG_TAG, "onStart executes ...");
}
protected void onResume() {
super.onResume();
Log.e(DEBUG_TAG, "onResume executes ...");
}
protected void onPause() {
super.onPause();
Log.e(DEBUG_TAG, "onPause executes ...");
}
protected void onStop() {
super.onStop();
Log.e(DEBUG_TAG, "onStop executes ...");
}
protected void onDestroy() {
super.onDestroy();
Log.e(DEBUG_TAG, "onDestroy executes ...");
}
}
¿Alguien tiene una idea?
actualización a partir de hoy (no entiendo por qué no se comporta como la última vez, tal vez más recursos libres?)
// activity starts
08-09 12:14:03.122: ERROR/FirstLifeLog(15406): onCreate executes ...
08-09 12:14:03.132: ERROR/FirstLifeLog(15406): onStart executes ...
08-09 12:14:03.132: ERROR/FirstLifeLog(15406): onResume executes ...
// screen off
08-09 12:14:07.412: ERROR/FirstLifeLog(15406): onPause executes ...
// screen on
08-09 12:14:11.722: ERROR/FirstLifeLog(15406): onResume executes ...
// no log for removed screen lock
Lo que es extraño es que veo OnDestroy (onStart),(), llamadas onResume(), pero no veo ninguna onCreate() llama. También estoy interesado en comprender el comportamiento. –
Eso es porque mi onCreate perdió la declaración de registro ... También he probado hoy de nuevo ... ahora mi juego tiene el mismo comportamiento, pero el TestProject tiene el comportamiento esperado (véase la actualización) – WarrenFaith