diff options
author | Yorke Lee <yorkelee@google.com> | 2013-10-04 16:25:47 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2013-10-04 16:25:48 +0000 |
commit | 524bc0b58afabd947cfaa4c13c28fa9660f398da (patch) | |
tree | 13600778a3b6154de190f19f75b702bdcc5f1eab /src/com/android | |
parent | 1f06f0ad1229f3b4e00553c294e664ffa5234c90 (diff) | |
parent | 2d471771184f504c10b8d2ccef3bb2480c45f5a7 (diff) | |
download | packages_apps_Dialer-524bc0b58afabd947cfaa4c13c28fa9660f398da.tar.gz packages_apps_Dialer-524bc0b58afabd947cfaa4c13c28fa9660f398da.tar.bz2 packages_apps_Dialer-524bc0b58afabd947cfaa4c13c28fa9660f398da.zip |
Merge "Fix infinite dialpad tones due to rapid presses" into klp-dev
Diffstat (limited to 'src/com/android')
-rw-r--r-- | src/com/android/dialer/dialpad/DialpadFragment.java | 38 |
1 files changed, 12 insertions, 26 deletions
diff --git a/src/com/android/dialer/dialpad/DialpadFragment.java b/src/com/android/dialer/dialpad/DialpadFragment.java index 46364b23c..bcf058b02 100644 --- a/src/com/android/dialer/dialpad/DialpadFragment.java +++ b/src/com/android/dialer/dialpad/DialpadFragment.java @@ -93,6 +93,8 @@ import com.android.phone.common.CallLogAsync; import com.android.phone.common.HapticFeedback; import com.google.common.annotations.VisibleForTesting; +import java.util.HashSet; + /** * Fragment that displays a twelve-key phone dialpad. */ @@ -205,12 +207,9 @@ public class DialpadFragment extends Fragment private final Object mToneGeneratorLock = new Object(); private View mDialpad; /** - * Remembers the number of dialpad buttons which are pressed at this moment. - * If it becomes 0, meaning no buttons are pressed, we'll call - * {@link ToneGenerator#stopTone()}; the method shouldn't be called unless the last key is - * released. + * Set of dialpad keys that are currently being pressed */ - private int mDialpadPressCount; + private final HashSet<View> mPressedDialpadKeys = new HashSet<View>(12); private View mDialButtonContainer; private View mDialButton; @@ -701,8 +700,8 @@ public class DialpadFragment extends Fragment } } stopWatch.lap("tg"); - // Prevent unnecessary confusion. Reset the press count anyway. - mDialpadPressCount = 0; + + mPressedDialpadKeys.clear(); configureScreenFromIntent(getActivity()); @@ -758,8 +757,7 @@ public class DialpadFragment extends Fragment // Make sure we don't leave this activity with a tone still playing. stopTone(); - // Just in case reset the counter too. - mDialpadPressCount = 0; + mPressedDialpadKeys.clear(); synchronized (mToneGeneratorLock) { if (mToneGenerator != null) { @@ -939,20 +937,11 @@ public class DialpadFragment extends Fragment break; } } - mDialpadPressCount++; + mPressedDialpadKeys.add(view); } else { view.jumpDrawablesToCurrentState(); - mDialpadPressCount--; - if (mDialpadPressCount < 0) { - // e.g. - // - when the user action is detected as horizontal swipe, at which only - // "up" event is thrown. - // - when the user long-press '0' button, at which dialpad will decrease this count - // while it still gets press-up event here. - if (DEBUG) Log.d(TAG, "mKeyPressCount become negative."); - stopTone(); - mDialpadPressCount = 0; - } else if (mDialpadPressCount == 0) { + mPressedDialpadKeys.remove(view); + if (mPressedDialpadKeys.isEmpty()) { stopTone(); } } @@ -1040,12 +1029,9 @@ public class DialpadFragment extends Fragment removePreviousDigitIfPossible(); keyPressed(KeyEvent.KEYCODE_PLUS); - // Stop tone immediately and decrease the press count, so that possible subsequent - // dial button presses won't honor the 0 click any more. - // Note: this *will* make mDialpadPressCount negative when the 0 key is released, - // which should be handled appropriately. + // Stop tone immediately stopTone(); - if (mDialpadPressCount > 0) mDialpadPressCount--; + mPressedDialpadKeys.remove(view); return true; } |