Merge "Refresh Accessibility key mapping when KeyboardView changes Keyboards." into jb-dev

This commit is contained in:
Charles Chen 2012-06-05 14:55:59 -07:00 committed by Android (Google) Code Review
commit f8233ec32d
3 changed files with 23 additions and 2 deletions

View file

@ -85,9 +85,20 @@ public class AccessibilityEntityProvider extends AccessibilityNodeProviderCompat
*/ */
public void setView(KeyboardView keyboardView) { public void setView(KeyboardView keyboardView) {
mKeyboardView = keyboardView; mKeyboardView = keyboardView;
assignVirtualViewIds();
updateParentLocation(); updateParentLocation();
// Since this class is constructed lazily, we might not get a subsequent
// call to setKeyboard() and therefore need to call it now.
setKeyboard(mKeyboardView.getKeyboard());
}
/**
* Sets the keyboard represented by this node provider.
*
* @param keyboard The keyboard to represent.
*/
public void setKeyboard(Keyboard keyboard) {
assignVirtualViewIds();
} }
/** /**

View file

@ -86,6 +86,12 @@ public class AccessibleKeyboardViewProxy extends AccessibilityDelegateCompat {
} }
} }
public void setKeyboard(Keyboard keyboard) {
if (mAccessibilityNodeProvider != null) {
mAccessibilityNodeProvider.setKeyboard(keyboard);
}
}
/** /**
* Proxy method for View.getAccessibilityNodeProvider(). This method is * Proxy method for View.getAccessibilityNodeProvider(). This method is
* called in SDK version 15 and higher to obtain the virtual node hierarchy * called in SDK version 15 and higher to obtain the virtual node hierarchy

View file

@ -468,6 +468,10 @@ public class LatinKeyboardView extends KeyboardView implements PointerTracker.Ke
if (ProductionFlag.IS_EXPERIMENTAL) { if (ProductionFlag.IS_EXPERIMENTAL) {
ResearchLogger.latinKeyboardView_setKeyboard(keyboard); ResearchLogger.latinKeyboardView_setKeyboard(keyboard);
} }
// This always needs to be set since the accessibility state can
// potentially change without the keyboard being set again.
AccessibleKeyboardViewProxy.getInstance().setKeyboard(keyboard);
} }
/** /**