diff options
author | Paul Gardiner <paulg.artifex@glidos.net> | 2012-11-20 15:07:55 +0000 |
---|---|---|
committer | Paul Gardiner <paulg.artifex@glidos.net> | 2012-11-20 15:14:29 +0000 |
commit | 4fa01e0858b2aa2b78bfc3897abe49b275bb831e (patch) | |
tree | 23e34ce2e5eb7c388778161f337e9537f17b4360 /android | |
parent | 9ab064d3058a4fa217bf8c20f97b258c30bd9e58 (diff) | |
download | mupdf-4fa01e0858b2aa2b78bfc3897abe49b275bb831e.tar.xz |
Android: fix problem if screen timesout during alert display
Diffstat (limited to 'android')
-rw-r--r-- | android/src/com/artifex/mupdf/MuPDFActivity.java | 69 |
1 files changed, 45 insertions, 24 deletions
diff --git a/android/src/com/artifex/mupdf/MuPDFActivity.java b/android/src/com/artifex/mupdf/MuPDFActivity.java index 501d6bea..194bc3d9 100644 --- a/android/src/com/artifex/mupdf/MuPDFActivity.java +++ b/android/src/com/artifex/mupdf/MuPDFActivity.java @@ -106,9 +106,12 @@ public class MuPDFActivity extends Activity private AlertDialog.Builder mAlertBuilder; private LinkState mLinkState = LinkState.DEFAULT; private final Handler mHandler = new Handler(); + private boolean mAlertsActive= false; private AsyncTask<Void,Void,MuPDFAlert> mAlertTask; + private AlertDialog mAlertDialog; public void createAlertWaiter() { + mAlertsActive = true; // All mupdf library calls are performed on asynchronous tasks to avoid stalling // the UI. Some calls can lead to javascript-invoked requests to display an // alert dialog and collect a reply from the user. The task has to be blocked @@ -121,10 +124,17 @@ public class MuPDFActivity extends Activity mAlertTask.cancel(true); mAlertTask = null; } + if (mAlertDialog != null) { + mAlertDialog.cancel(); + mAlertDialog = null; + } mAlertTask = new AsyncTask<Void,Void,MuPDFAlert>() { @Override protected MuPDFAlert doInBackground(Void... arg0) { + if (!mAlertsActive) + return null; + return core.waitForAlert(); } @@ -138,23 +148,26 @@ public class MuPDFActivity extends Activity pressed[i] = MuPDFAlert.ButtonPressed.None; DialogInterface.OnClickListener listener = new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { - int index = 0; - switch (which) { - case AlertDialog.BUTTON1: index=0; break; - case AlertDialog.BUTTON2: index=1; break; - case AlertDialog.BUTTON3: index=2; break; + mAlertDialog = null; + if (mAlertsActive) { + int index = 0; + switch (which) { + case AlertDialog.BUTTON1: index=0; break; + case AlertDialog.BUTTON2: index=1; break; + case AlertDialog.BUTTON3: index=2; break; + } + result.buttonPressed = pressed[index]; + // Send the user's response to the core, so that it can + // continue processing. + core.replyToAlert(result); + // Create another alert-waiter to pick up the next alert. + createAlertWaiter(); } - result.buttonPressed = pressed[index]; - // Send the user's response to the core, so that it can - // continue processing. - core.replyToAlert(result); - // Create another alert-waiter to pick up the next alert. - createAlertWaiter(); } }; - AlertDialog alert = mAlertBuilder.create(); - alert.setTitle(result.title); - alert.setMessage(result.message); + mAlertDialog = mAlertBuilder.create(); + mAlertDialog.setTitle(result.title); + mAlertDialog.setMessage(result.message); switch (result.iconType) { case Error: @@ -169,31 +182,34 @@ public class MuPDFActivity extends Activity switch (result.buttonGroupType) { case OkCancel: - alert.setButton(AlertDialog.BUTTON2, "Cancel", listener); + mAlertDialog.setButton(AlertDialog.BUTTON2, "Cancel", listener); pressed[1] = MuPDFAlert.ButtonPressed.Cancel; case Ok: - alert.setButton(AlertDialog.BUTTON1, "Ok", listener); + mAlertDialog.setButton(AlertDialog.BUTTON1, "Ok", listener); pressed[0] = MuPDFAlert.ButtonPressed.Ok; break; case YesNoCancel: - alert.setButton(AlertDialog.BUTTON3, "Cancel", listener); + mAlertDialog.setButton(AlertDialog.BUTTON3, "Cancel", listener); pressed[2] = MuPDFAlert.ButtonPressed.Cancel; case YesNo: - alert.setButton(AlertDialog.BUTTON1, "Yes", listener); + mAlertDialog.setButton(AlertDialog.BUTTON1, "Yes", listener); pressed[0] = MuPDFAlert.ButtonPressed.Yes; - alert.setButton(AlertDialog.BUTTON2, "No", listener); + mAlertDialog.setButton(AlertDialog.BUTTON2, "No", listener); pressed[1] = MuPDFAlert.ButtonPressed.No; break; } - alert.setOnCancelListener(new DialogInterface.OnCancelListener() { + mAlertDialog.setOnCancelListener(new DialogInterface.OnCancelListener() { public void onCancel(DialogInterface dialog) { - result.buttonPressed = MuPDFAlert.ButtonPressed.None; - core.replyToAlert(result); - createAlertWaiter(); + mAlertDialog = null; + if (mAlertsActive) { + result.buttonPressed = MuPDFAlert.ButtonPressed.None; + core.replyToAlert(result); + createAlertWaiter(); + } } }); - alert.show(); + mAlertDialog.show(); } }; @@ -201,6 +217,11 @@ public class MuPDFActivity extends Activity } public void destroyAlertWaiter() { + mAlertsActive = false; + if (mAlertDialog != null) { + mAlertDialog.cancel(); + mAlertDialog = null; + } if (mAlertTask != null) { mAlertTask.cancel(true); mAlertTask = null; |