summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPierre Fröjd <pierre.frojd.x@sonyericsson.com>2011-01-19 13:46:57 +0100
committerJohan Redestig <johan.redestig@sonymobile.com>2012-09-13 09:17:35 +0200
commit99fccc1c113d9b7a030dc7c945d0750748cc4af9 (patch)
treebd85ace68998855f628e61ac2570864846fcf66b
parentaf0dd9f082ff3ab5295cbf00eb2ea6d8db820ce6 (diff)
downloadandroid_packages_apps_Stk-99fccc1c113d9b7a030dc7c945d0750748cc4af9.tar.gz
android_packages_apps_Stk-99fccc1c113d9b7a030dc7c945d0750748cc4af9.tar.bz2
android_packages_apps_Stk-99fccc1c113d9b7a030dc7c945d0750748cc4af9.zip
No response sent when backlight is OFF
When the LCD backlight is OFF while receiving a PLAY TONE command, the onDestroy() method is called immediately since the app is in the background. In onDestroy() the STOP message is removed from the handler queue which leads to no response is sent back to StkAppService. This causes the RIL layer to send TR 'ME currently unable to process command' back to the SIM. Solution is to check if a response is sent before removing any messages from the handler queue. Change-Id: I7ac2e99b85b38576acfe72370aa55850cdc304a0
-rw-r--r--src/com/android/stk/ToneDialog.java7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/com/android/stk/ToneDialog.java b/src/com/android/stk/ToneDialog.java
index 3251aba..0370939 100644
--- a/src/com/android/stk/ToneDialog.java
+++ b/src/com/android/stk/ToneDialog.java
@@ -38,6 +38,7 @@ public class ToneDialog extends Activity {
TextMessage toneMsg = null;
ToneSettings settings = null;
TonePlayer player = null;
+ boolean mIsResponseSent = false;
/**
* Handler used to stop tones from playing when the duration ends.
@@ -98,8 +99,9 @@ public class ToneDialog extends Activity {
@Override
protected void onDestroy() {
super.onDestroy();
-
- mToneStopper.removeMessages(MSG_ID_STOP_TONE);
+ if (mIsResponseSent) {
+ mToneStopper.removeMessages(MSG_ID_STOP_TONE);
+ }
player.stop();
player.release();
mVibrator.cancel();
@@ -129,5 +131,6 @@ public class ToneDialog extends Activity {
args.putInt(StkAppService.OPCODE, StkAppService.OP_RESPONSE);
args.putInt(StkAppService.RES_ID, resId);
startService(new Intent(this, StkAppService.class).putExtras(args));
+ mIsResponseSent = true;
}
}