Здесь снимок экрана моего состояния предупреждения AlertDialog:
На заднем плане зеленая плитка, красный шар внутри черно-белой цели, все три растровые изображения непрерывно отображаются в потоке рендеринга, который блокирует/разблокирует фоновый холст на моем телефоне. Это безответственное действие всегда выполняется, когда я нажимаю кнопку OK, независимо от того, какой текст я вставляю в EditText.
Здесь код:
Класс PlayActivity:
package nttu.edu.activities;
import nttu.edu.graphics.RenderView;
import nttu.edu.handler.Accelero;
import nttu.edu.handler.TouchHandler;
import nttu.edu.score.Score;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.content.res.AssetManager;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.util.Log;
import android.view.Window;
import android.view.WindowManager;
import android.widget.EditText;
public class PlayActivity extends Activity implements OnClickListener
{
public RenderView renderView = null;
public Accelero accelerometer = null;
public AssetManager assetManager = null;
public TouchHandler touchHandler = null;
public Score leaderboard = null;
final int REQUEST_CODE = 0x1;
private EditText input = null;
private AlertDialog.Builder dialog = null;
public void onCreate(Bundle b)
{
super.onCreate(b);
accelerometer = new Accelero();
touchHandler = new TouchHandler();
leaderboard = new Score(this);
renderView = new RenderView(this, accelerometer, touchHandler);
renderView.setOnTouchListener(touchHandler);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
input = new EditText(this);
dialog = new AlertDialog.Builder(this);
dialog.setTitle("Enter High Score!");
dialog.setMessage("Enter your name: ");
dialog.setView(input);
dialog.setPositiveButton("OK", PlayActivity.this);
setContentView(renderView);
}
public void onResume()
{
super.onResume();
if(renderView != null)
renderView.resume();
if(accelerometer != null)
accelerometer.resume(this);
}
public void onPause()
{
super.onPause();
if(renderView != null)
renderView.pause();
if(accelerometer != null)
accelerometer.pause();
}
public void addPlayer()
{
// FIXME: The dialog won't exit.
Looper.prepare();
dialog.show();
Looper.loop();
}
public void onClick(DialogInterface dialog, int button)
{
String name = input.getText().toString();
if(name == null)
name = "Player";
this.leaderboard.open();
this.leaderboard.createEntry(name, this.renderView.getScore());
this.leaderboard.close();
if (Looper.myLooper() != null)
Looper.myLooper().quit();
else if (Looper.getMainLooper() != null)
Looper.getMainLooper().quit();
Log.d("PlayActivity.onClick()", "I'm escaping from Looper.loop()");
//renderView.running = false;
//PlayActivity.this.finish();
}
}
По какой-то неизвестной причине AlertDialog будет выполняться только тогда, когда будет создан подготовленный Looper до вызова AlertDialog.show().
Проблема заключается в том, что после вызова AlertDialog.show(), и после вызова Looper.quit(), AlertDialog каким-то образом не выходит, что делает телефон невосприимчивым.
И когда я вызвал метод PlayActivity.this.finish() в методе onClick(), я могу выйти из диалогового окна, остановить фоновое рендеринг и вернуться в главное меню (это то, что я хотел), но Eclipse DDMS сообщает об этом:
06-26 16:40:29.049: E/WindowManager(1642): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
06-26 16:40:29.049: E/WindowManager(1642): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
06-26 16:40:29.049: E/WindowManager(1642): at android.view.Window$LocalWindowManager.addView(Window.java:433)
06-26 16:40:29.049: E/WindowManager(1642): at android.app.Dialog.show(Dialog.java:265)
06-26 16:40:29.049: E/WindowManager(1642): at android.app.AlertDialog$Builder.show(AlertDialog.java:802)
06-26 16:40:29.049: E/WindowManager(1642): at nttu.edu.activities.PlayActivity.addPlayer(PlayActivity.java:77)
06-26 16:40:29.049: E/WindowManager(1642): at nttu.edu.graphics.RenderView.tick(RenderView.java:119)
06-26 16:40:29.049: E/WindowManager(1642): at nttu.edu.graphics.RenderView.run(RenderView.java:69)
06-26 16:40:29.049: E/WindowManager(1642): at java.lang.Thread.run(Thread.java:1027)
06-26 16:40:29.079: W/MessageQueue(1642): Handler{405399b8} sending message to a Handler on a dead thread
06-26 16:40:29.079: W/MessageQueue(1642): java.lang.RuntimeException: Handler{405399b8} sending message to a Handler on a dead thread
06-26 16:40:29.079: W/MessageQueue(1642): at android.os.MessageQueue.enqueueMessage(MessageQueue.java:196)
Короче говоря, AlertDialog просачивается, когда я хочу выйти из своей PlayActivity, вызвав функцию finish(). Я не знаю, что еще нужно сделать, чтобы исправить эту проблему.
Пожалуйста, помогите мне. Благодарю! Если вам нужно больше исходного кода, пожалуйста, дайте мне знать.
РЕДАКТИРОВАТЬ:
Как раз перед ошибками утечки, это то, что регистрировалось DDMS:
06-26 16:40:22.182: D/Level.render()(1642): Drawing Tee.
06-26 16:40:22.182: D/Level.render()(1642): Drawing Hole.
06-26 16:40:22.182: D/Level.render()(1642): Drawing Ball.
06-26 16:40:22.192: D/Level.render()(1642): Drawing background.
06-26 16:40:22.202: D/Level.render()(1642): Drawing Tee.
06-26 16:40:22.202: D/Level.render()(1642): Drawing Hole.
06-26 16:40:22.202: D/Level.render()(1642): Drawing Ball.
06-26 16:40:22.212: D/Level.render()(1642): Drawing background.
06-26 16:40:22.212: D/Level.render()(1642): Drawing Tee.
06-26 16:40:22.222: D/Level.render()(1642): Drawing Hole.
06-26 16:40:22.222: D/Level.render()(1642): Drawing Ball.
06-26 16:40:22.222: D/FrameRate(1642): 59
06-26 16:40:22.232: D/Level.tick()(1642): Obtaining score.
06-26 16:40:22.232: D/Level.render()(1642): Drawing background.
06-26 16:40:22.232: D/Level.render()(1642): Drawing Tee.
06-26 16:40:22.242: D/Level.render()(1642): Drawing Hole.
06-26 16:40:22.242: D/Level.render()(1642): Drawing Ball.
06-26 16:40:22.242: D/Level.render()(1642): Outputting the phrase: Game Over
06-26 16:40:23.713: D/Database(1642): dbopen(): path = /data/data/nttu.edu/databases/Scoreboard, flag = 6, file size = 5120
06-26 16:40:23.713: D/Database(1642): dbopen(): path = /data/data/nttu.edu/databases/Scoreboard, mode: wal, disk free size: 1014 M, handle: 0x38b4a8
06-26 16:40:23.844: D/Database(1642): dbclose(): path = /data/data/nttu.edu/databases/Scoreboard, handle = 0x38b4a8
06-26 16:40:28.608: D/PlayActivity.onClick()(1642): I'm escaping from Looper.loop()
06-26 16:40:28.618: D/Level.render()(1642): Drawing background.
06-26 16:40:28.628: D/Level.render()(1642): Drawing Tee.
06-26 16:40:28.628: D/Level.render()(1642): Drawing Hole.
06-26 16:40:28.628: D/Level.render()(1642): Drawing Ball.
06-26 16:40:28.628: D/Level.render()(1642): Outputting the phrase: Game Over
06-26 16:40:28.648: D/FrameRate(1642): 2
06-26 16:40:28.798: W/MessageQueue(1642): Handler{4053dbd0} sending message to a Handler on a dead thread
06-26 16:40:28.798: W/MessageQueue(1642): java.lang.RuntimeException: Handler{4053dbd0} sending message to a Handler on a dead thread
06-26 16:40:28.798: W/MessageQueue(1642): at android.os.MessageQueue.enqueueMessage(MessageQueue.java:196)
06-26 16:40:28.798: W/MessageQueue(1642): at android.os.Handler.sendMessageAtTime(Handler.java:457)
06-26 16:40:28.798: W/MessageQueue(1642): at android.os.Handler.sendMessageDelayed(Handler.java:430)
06-26 16:40:28.798: W/MessageQueue(1642): at android.os.Handler.sendMessage(Handler.java:367)
06-26 16:40:28.798: W/MessageQueue(1642): at com.android.internal.view.IInputConnectionWrapper.dispatchMessage(IInputConnectionWrapper.java:240)
06-26 16:40:28.798: W/MessageQueue(1642): at com.android.internal.view.IInputConnectionWrapper.finishComposingText(IInputConnectionWrapper.java:151)
06-26 16:40:28.798: W/MessageQueue(1642): at com.android.internal.view.IInputContext$Stub.onTransact(IInputContext.java:137)
06-26 16:40:28.798: W/MessageQueue(1642): at android.os.Binder.execTransact(Binder.java:320)
06-26 16:40:28.798: W/MessageQueue(1642): at dalvik.system.NativeStart.run(Native Method)
06-26 16:40:28.888: W/MessageQueue(1642): Handler{405399b8} sending message to a Handler on a dead thread
06-26 16:40:28.888: W/MessageQueue(1642): java.lang.RuntimeException: Handler{405399b8} sending message to a Handler on a dead thread
06-26 16:40:28.888: W/MessageQueue(1642): at android.os.MessageQueue.enqueueMessage(MessageQueue.java:196)
06-26 16:40:28.888: W/MessageQueue(1642): at android.os.Handler.sendMessageAtTime(Handler.java:457)
06-26 16:40:28.888: W/MessageQueue(1642): at android.os.Handler.sendMessageDelayed(Handler.java:430)
Вы должны обнаружить все места, в которых приложение окажется, и использовать Dialog.dismiss()