am af0a0884
: am dd7f7909
: Merge "Change accessibility event type for app-driven speech." into jb-mr1-dev
* commit 'af0a0884463420b1a4e75780ba2b3eacae21c5ff': Change accessibility event type for app-driven speech.
This commit is contained in:
commit
bbd79bc4f0
3 changed files with 29 additions and 10 deletions
|
@ -19,10 +19,15 @@ package com.android.inputmethod.accessibility;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.inputmethodservice.InputMethodService;
|
import android.inputmethodservice.InputMethodService;
|
||||||
import android.media.AudioManager;
|
import android.media.AudioManager;
|
||||||
|
import android.os.Build;
|
||||||
import android.os.SystemClock;
|
import android.os.SystemClock;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
import android.support.v4.view.accessibility.AccessibilityEventCompat;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.view.ViewParent;
|
||||||
import android.view.accessibility.AccessibilityEvent;
|
import android.view.accessibility.AccessibilityEvent;
|
||||||
import android.view.accessibility.AccessibilityManager;
|
import android.view.accessibility.AccessibilityManager;
|
||||||
import android.view.inputmethod.EditorInfo;
|
import android.view.inputmethod.EditorInfo;
|
||||||
|
@ -138,9 +143,10 @@ public class AccessibilityUtils {
|
||||||
* Sends the specified text to the {@link AccessibilityManager} to be
|
* Sends the specified text to the {@link AccessibilityManager} to be
|
||||||
* spoken.
|
* spoken.
|
||||||
*
|
*
|
||||||
* @param text the text to speak
|
* @param view The source view.
|
||||||
|
* @param text The text to speak.
|
||||||
*/
|
*/
|
||||||
public void speak(CharSequence text) {
|
public void announceForAccessibility(View view, CharSequence text) {
|
||||||
if (!mAccessibilityManager.isEnabled()) {
|
if (!mAccessibilityManager.isEnabled()) {
|
||||||
Log.e(TAG, "Attempted to speak when accessibility was disabled!");
|
Log.e(TAG, "Attempted to speak when accessibility was disabled!");
|
||||||
return;
|
return;
|
||||||
|
@ -149,8 +155,7 @@ public class AccessibilityUtils {
|
||||||
// The following is a hack to avoid using the heavy-weight TextToSpeech
|
// The following is a hack to avoid using the heavy-weight TextToSpeech
|
||||||
// class. Instead, we're just forcing a fake AccessibilityEvent into
|
// class. Instead, we're just forcing a fake AccessibilityEvent into
|
||||||
// the screen reader to make it speak.
|
// the screen reader to make it speak.
|
||||||
final AccessibilityEvent event = AccessibilityEvent
|
final AccessibilityEvent event = AccessibilityEvent.obtain();
|
||||||
.obtain(AccessibilityEvent.TYPE_VIEW_FOCUSED);
|
|
||||||
|
|
||||||
event.setPackageName(PACKAGE);
|
event.setPackageName(PACKAGE);
|
||||||
event.setClassName(CLASS);
|
event.setClassName(CLASS);
|
||||||
|
@ -158,20 +163,34 @@ public class AccessibilityUtils {
|
||||||
event.setEnabled(true);
|
event.setEnabled(true);
|
||||||
event.getText().add(text);
|
event.getText().add(text);
|
||||||
|
|
||||||
mAccessibilityManager.sendAccessibilityEvent(event);
|
// Platforms starting at SDK 16 should use announce events.
|
||||||
|
if (Build.VERSION.SDK_INT >= 16) {
|
||||||
|
event.setEventType(AccessibilityEventCompat.TYPE_ANNOUNCEMENT);
|
||||||
|
} else {
|
||||||
|
event.setEventType(AccessibilityEvent.TYPE_VIEW_FOCUSED);
|
||||||
|
}
|
||||||
|
|
||||||
|
final ViewParent viewParent = view.getParent();
|
||||||
|
if ((viewParent == null) || !(viewParent instanceof ViewGroup)) {
|
||||||
|
Log.e(TAG, "Failed to obtain ViewParent in announceForAccessibility");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
viewParent.requestSendAccessibilityEvent(view, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles speaking the "connect a headset to hear passwords" notification
|
* Handles speaking the "connect a headset to hear passwords" notification
|
||||||
* when connecting to a password field.
|
* when connecting to a password field.
|
||||||
*
|
*
|
||||||
|
* @param view The source view.
|
||||||
* @param editorInfo The input connection's editor info attribute.
|
* @param editorInfo The input connection's editor info attribute.
|
||||||
* @param restarting Whether the connection is being restarted.
|
* @param restarting Whether the connection is being restarted.
|
||||||
*/
|
*/
|
||||||
public void onStartInputViewInternal(EditorInfo editorInfo, boolean restarting) {
|
public void onStartInputViewInternal(View view, EditorInfo editorInfo, boolean restarting) {
|
||||||
if (shouldObscureInput(editorInfo)) {
|
if (shouldObscureInput(editorInfo)) {
|
||||||
final CharSequence text = mContext.getText(R.string.spoken_use_headphones);
|
final CharSequence text = mContext.getText(R.string.spoken_use_headphones);
|
||||||
speak(text);
|
announceForAccessibility(view, text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -250,7 +250,7 @@ public class AccessibleKeyboardViewProxy extends AccessibilityDelegateCompat {
|
||||||
text = context.getText(R.string.spoken_description_shiftmode_off);
|
text = context.getText(R.string.spoken_description_shiftmode_off);
|
||||||
}
|
}
|
||||||
|
|
||||||
AccessibilityUtils.getInstance().speak(text);
|
AccessibilityUtils.getInstance().announceForAccessibility(mView, text);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -290,6 +290,6 @@ public class AccessibleKeyboardViewProxy extends AccessibilityDelegateCompat {
|
||||||
}
|
}
|
||||||
|
|
||||||
final String text = context.getString(resId);
|
final String text = context.getString(resId);
|
||||||
AccessibilityUtils.getInstance().speak(text);
|
AccessibilityUtils.getInstance().announceForAccessibility(mView, text);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -667,7 +667,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
||||||
// Forward this event to the accessibility utilities, if enabled.
|
// Forward this event to the accessibility utilities, if enabled.
|
||||||
final AccessibilityUtils accessUtils = AccessibilityUtils.getInstance();
|
final AccessibilityUtils accessUtils = AccessibilityUtils.getInstance();
|
||||||
if (accessUtils.isTouchExplorationEnabled()) {
|
if (accessUtils.isTouchExplorationEnabled()) {
|
||||||
accessUtils.onStartInputViewInternal(editorInfo, restarting);
|
accessUtils.onStartInputViewInternal(inputView, editorInfo, restarting);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!restarting) {
|
if (!restarting) {
|
||||||
|
|
Loading…
Reference in a new issue