From 7d62419c85dbf4fff1895e91d38edccf5d1f46ec Mon Sep 17 00:00:00 2001 From: alanv Date: Mon, 21 May 2012 14:23:17 -0700 Subject: Make TextView respect ACCESSIBILITY_SPEAK_PASSWORD preference. Bug: 6523447 Change-Id: I2610b558395dc53a74b5c8c36c09673898da44f2 --- core/java/android/widget/TextView.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) (limited to 'core/java/android/widget/TextView.java') diff --git a/core/java/android/widget/TextView.java b/core/java/android/widget/TextView.java index aef7929b898c..81a44fdf09c5 100644 --- a/core/java/android/widget/TextView.java +++ b/core/java/android/widget/TextView.java @@ -39,6 +39,7 @@ import android.os.Message; import android.os.Parcel; import android.os.Parcelable; import android.os.SystemClock; +import android.provider.Settings; import android.text.BoringLayout; import android.text.DynamicLayout; import android.text.Editable; @@ -7705,14 +7706,23 @@ public class TextView extends View implements ViewTreeObserver.OnPreDrawListener super.onPopulateAccessibilityEvent(event); final boolean isPassword = hasPasswordTransformationMethod(); - if (!isPassword) { - CharSequence text = getTextForAccessibility(); + if (!isPassword || shouldSpeakPasswordsForAccessibility()) { + final CharSequence text = getTextForAccessibility(); if (!TextUtils.isEmpty(text)) { event.getText().add(text); } } } + /** + * @return true if the user has explicitly allowed accessibility services + * to speak passwords. + */ + private boolean shouldSpeakPasswordsForAccessibility() { + return (Settings.Secure.getInt(mContext.getContentResolver(), + Settings.Secure.ACCESSIBILITY_SPEAK_PASSWORD, 0) == 1); + } + @Override public void onInitializeAccessibilityEvent(AccessibilityEvent event) { super.onInitializeAccessibilityEvent(event); -- cgit v1.2.3