From c45baecabd157ee8e9ce75791e1afe4c702c25a8 Mon Sep 17 00:00:00 2001 From: Yorke Lee Date: Thu, 5 Sep 2013 18:25:48 -0700 Subject: Fix accessibility issues with dialpad Bug: 10314426 Change-Id: Ieecb5cc64ce93fb8457ed0cab0d054b5a1b1586c --- .../android/dialer/dialpad/DialpadFragment.java | 29 +++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) (limited to 'src/com/android/dialer/dialpad/DialpadFragment.java') diff --git a/src/com/android/dialer/dialpad/DialpadFragment.java b/src/com/android/dialer/dialpad/DialpadFragment.java index 79e830730..361f60d75 100644 --- a/src/com/android/dialer/dialpad/DialpadFragment.java +++ b/src/com/android/dialer/dialpad/DialpadFragment.java @@ -57,6 +57,7 @@ import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; +import android.view.MotionEvent; import android.view.View; import android.view.ViewConfiguration; import android.view.ViewGroup; @@ -136,6 +137,30 @@ public class DialpadFragment extends Fragment } } + /** + * LinearLayout that always returns true for onHoverEvent callbacks, to fix + * problems with accessibility due to the dialpad overlaying other fragments. + */ + public static class HoverIgnoringLinearLayout extends LinearLayout { + + public HoverIgnoringLinearLayout(Context context) { + super(context); + } + + public HoverIgnoringLinearLayout(Context context, AttributeSet attrs) { + super(context, attrs); + } + + public HoverIgnoringLinearLayout(Context context, AttributeSet attrs, int defStyle) { + super(context, attrs, defStyle); + } + + @Override + public boolean onHoverEvent(MotionEvent event) { + return true; + } + } + public interface OnDialpadQueryChangedListener { void onDialpadQueryChanged(String query); } @@ -611,7 +636,9 @@ public class DialpadFragment extends Fragment dialpadKey.setOnPressedListener(this); numberView = (TextView) dialpadKey.findViewById(R.id.dialpad_key_number); lettersView = (TextView) dialpadKey.findViewById(R.id.dialpad_key_letters); - numberView.setText(resources.getString(numberIds[i])); + final String numberString = resources.getString(numberIds[i]); + numberView.setText(numberString); + dialpadKey.setContentDescription(numberString); if (lettersView != null) { lettersView.setText(resources.getString(letterIds[i])); } -- cgit v1.2.3