a461660fa8
- Add a feature flag for IME Latency logging. - Removed mShowImeAfterFirstLayout from ExtendedEditText. http://ag/1414509 added `mShowImeAfterFirstLayout`and cl description says "Show IME when search query != null after rotation". I verified the behavior by turning on "Allow home screen rotation". Keyboard is not getting dismissed on rotation in AA+ screen in a-z list or even in the search screen. Video : https://drive.google.com/file/d/1BWUTrW9OSEo6ojErj8INMwjFCPArVD4B/view?usp=sharing&resourcekey=0-SXTcKyUw1wCSi8Bm37ktow Bug: 240192346 Test: Manual. Verified by setting `ENABLE_KEYBOARD_TRANSITION_SYNC` to false and for following usecases. - All apps entry with ime enabled, scrolling a-z list to hide keyboard - Folder name change - showing and dismissing keyboard - Toast entry from Allapps and QSB - showing and dismissing keyboard Change-Id: I1a6b5759b8e71e77744f58677b6d1b73e2f633e8
134 lines
4.1 KiB
Java
134 lines
4.1 KiB
Java
/*
|
|
* Copyright (C) 2015 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
package com.android.launcher3;
|
|
|
|
import static com.android.launcher3.logging.KeyboardStateManager.KeyboardState.SHOW;
|
|
import static com.android.launcher3.util.UiThreadHelper.hideKeyboardAsync;
|
|
|
|
import android.content.Context;
|
|
import android.text.TextUtils;
|
|
import android.util.AttributeSet;
|
|
import android.view.DragEvent;
|
|
import android.view.KeyEvent;
|
|
import android.view.inputmethod.InputMethodManager;
|
|
import android.widget.EditText;
|
|
|
|
import com.android.launcher3.views.ActivityContext;
|
|
|
|
|
|
/**
|
|
* The edit text that reports back when the back key has been pressed.
|
|
* Note: AppCompatEditText doesn't fully support #displayCompletions and #onCommitCompletion
|
|
*/
|
|
public class ExtendedEditText extends EditText {
|
|
private boolean mForceDisableSuggestions = false;
|
|
|
|
/**
|
|
* Implemented by listeners of the back key.
|
|
*/
|
|
public interface OnBackKeyListener {
|
|
boolean onBackKey();
|
|
}
|
|
|
|
private OnBackKeyListener mBackKeyListener;
|
|
|
|
public ExtendedEditText(Context context) {
|
|
// ctor chaining breaks the touch handling
|
|
super(context);
|
|
}
|
|
|
|
public ExtendedEditText(Context context, AttributeSet attrs) {
|
|
// ctor chaining breaks the touch handling
|
|
super(context, attrs);
|
|
}
|
|
|
|
public ExtendedEditText(Context context, AttributeSet attrs, int defStyleAttr) {
|
|
super(context, attrs, defStyleAttr);
|
|
}
|
|
|
|
public void setOnBackKeyListener(OnBackKeyListener listener) {
|
|
mBackKeyListener = listener;
|
|
}
|
|
|
|
@Override
|
|
public boolean onKeyPreIme(int keyCode, KeyEvent event) {
|
|
// If this is a back key, propagate the key back to the listener
|
|
if (keyCode == KeyEvent.KEYCODE_BACK && event.getAction() == KeyEvent.ACTION_UP) {
|
|
if (TextUtils.isEmpty(getText())) {
|
|
hideKeyboard();
|
|
}
|
|
if (mBackKeyListener != null) {
|
|
return mBackKeyListener.onBackKey();
|
|
}
|
|
return false;
|
|
}
|
|
return super.onKeyPreIme(keyCode, event);
|
|
}
|
|
|
|
@Override
|
|
public boolean onDragEvent(DragEvent event) {
|
|
// We don't want this view to interfere with Launcher own drag and drop.
|
|
return false;
|
|
}
|
|
|
|
public void showKeyboard() {
|
|
onKeyboardShown();
|
|
showSoftInput();
|
|
}
|
|
|
|
public void hideKeyboard() {
|
|
hideKeyboardAsync(ActivityContext.lookupContext(getContext()), getWindowToken());
|
|
clearFocus();
|
|
}
|
|
|
|
protected void onKeyboardShown() {
|
|
ActivityContext.lookupContext(getContext()).getStatsLogManager()
|
|
.keyboardStateManager().setKeyboardState(SHOW);
|
|
}
|
|
|
|
private boolean showSoftInput() {
|
|
return requestFocus() &&
|
|
getContext().getSystemService(InputMethodManager.class)
|
|
.showSoftInput(this, InputMethodManager.SHOW_IMPLICIT);
|
|
}
|
|
|
|
public void dispatchBackKey() {
|
|
hideKeyboard();
|
|
if (mBackKeyListener != null) {
|
|
mBackKeyListener.onBackKey();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Set to true when you want isSuggestionsEnabled to return false.
|
|
* Use this to disable the red underlines that appear under typos when suggestions is enabled.
|
|
*/
|
|
public void forceDisableSuggestions(boolean forceDisableSuggestions) {
|
|
mForceDisableSuggestions = forceDisableSuggestions;
|
|
}
|
|
|
|
@Override
|
|
public boolean isSuggestionsEnabled() {
|
|
return !mForceDisableSuggestions && super.isSuggestionsEnabled();
|
|
}
|
|
|
|
public void reset() {
|
|
if (!TextUtils.isEmpty(getText())) {
|
|
setText("");
|
|
}
|
|
}
|
|
}
|