Merge "Revert "Finish input when the screen state is off"" into rvc-dev am: d99569f88a

Change-Id: Ic669aab90118da2093ddd1c5fb8e6efe77faa904
This commit is contained in:
TreeHugger Robot
2020-05-14 14:29:46 +00:00
committed by Automerger Merge Worker
6 changed files with 40 additions and 21 deletions

View File

@@ -207,26 +207,6 @@ public final class ImeFocusController {
mHasImeFocus = false;
}
/**
* Called by {@link ViewRootImpl} to feedback the state of the screen for this view.
* @param newScreenState The new state of the screen. Can be either
* {@link View#SCREEN_STATE_ON} or {@link View#SCREEN_STATE_OFF}
*/
@UiThread
void onScreenStateChanged(int newScreenState) {
if (!getImmDelegate().isCurrentRootView(mViewRootImpl)) {
return;
}
// Close input connection and IME when the screen is turn off for security concern.
if (newScreenState == View.SCREEN_STATE_OFF && mServedView != null) {
if (DEBUG) {
Log.d(TAG, "onScreenStateChanged, disconnect input when screen turned off");
}
mNextServedView = null;
mViewRootImpl.dispatchCheckFocus();
}
}
/**
* @param windowAttribute {@link WindowManager.LayoutParams} to be checked.
* @return Whether the window is in local focus mode or not.

View File

@@ -1496,7 +1496,6 @@ public final class ViewRootImpl implements ViewParent,
final int newScreenState = toViewScreenState(newDisplayState);
if (oldScreenState != newScreenState) {
mView.dispatchScreenStateChanged(newScreenState);
mImeFocusController.onScreenStateChanged(newScreenState);
}
if (oldDisplayState == Display.STATE_OFF) {
// Draw was suppressed so we need to for it to happen here.

View File

@@ -44,6 +44,12 @@ public abstract class InputMethodManagerInternal {
void onInputMethodListUpdated(List<InputMethodInfo> info, @UserIdInt int userId);
}
/**
* Called by the power manager to tell the input method manager whether it
* should start watching for wake events.
*/
public abstract void setInteractive(boolean interactive);
/**
* Hides the current input method, if visible.
*/
@@ -107,6 +113,10 @@ public abstract class InputMethodManagerInternal {
*/
private static final InputMethodManagerInternal NOP =
new InputMethodManagerInternal() {
@Override
public void setInteractive(boolean interactive) {
}
@Override
public void hideCurrentInputMethod(@SoftInputShowHideReason int reason) {
}

View File

@@ -4202,6 +4202,9 @@ public class InputMethodManagerService extends IInputMethodManager.Stub
+ ((ClientState)msg.obj).uid);
}
return true;
case MSG_SET_INTERACTIVE:
handleSetInteractive(msg.arg1 != 0);
return true;
case MSG_REPORT_FULLSCREEN_MODE: {
final boolean fullscreen = msg.arg1 != 0;
final ClientState clientState = (ClientState)msg.obj;
@@ -4276,6 +4279,20 @@ public class InputMethodManagerService extends IInputMethodManager.Stub
return false;
}
private void handleSetInteractive(final boolean interactive) {
synchronized (mMethodMap) {
mIsInteractive = interactive;
updateSystemUiLocked(interactive ? mImeWindowVis : 0, mBackDisposition);
// Inform the current client of the change in active status
if (mCurClient != null && mCurClient.client != null) {
executeOrSendMessage(mCurClient.client, mCaller.obtainMessageIIO(
MSG_SET_ACTIVE, mIsInteractive ? 1 : 0, mInFullscreenMode ? 1 : 0,
mCurClient));
}
}
}
private boolean chooseNewDefaultIMELocked() {
final InputMethodInfo imi = InputMethodUtils.getMostApplicableDefaultIME(
mSettings.getEnabledInputMethodListLocked());
@@ -4884,6 +4901,13 @@ public class InputMethodManagerService extends IInputMethodManager.Stub
mService = service;
}
@Override
public void setInteractive(boolean interactive) {
// Do everything in handler so as not to block the caller.
mService.mHandler.obtainMessage(MSG_SET_INTERACTIVE, interactive ? 1 : 0, 0)
.sendToTarget();
}
@Override
public void hideCurrentInputMethod(@SoftInputShowHideReason int reason) {
mService.mHandler.removeMessages(MSG_HIDE_CURRENT_INPUT_METHOD);

View File

@@ -170,6 +170,11 @@ public final class MultiClientInputMethodManagerService {
LocalServices.addService(InputMethodManagerInternal.class,
new InputMethodManagerInternal() {
@Override
public void setInteractive(boolean interactive) {
reportNotSupported();
}
@Override
public void hideCurrentInputMethod(@SoftInputShowHideReason int reason) {
reportNotSupported();

View File

@@ -413,6 +413,7 @@ public class Notifier {
// Start input as soon as we start waking up or going to sleep.
mInputManagerInternal.setInteractive(interactive);
mInputMethodManagerInternal.setInteractive(interactive);
// Notify battery stats.
try {