1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except 5 * in compliance with the License. You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software distributed under the License 10 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 11 * or implied. See the License for the specific language governing permissions and limitations under 12 * the License. 13 */ 14 package androidx.leanback.widget; 15 16 import android.view.KeyEvent; 17 import android.widget.EditText; 18 19 /** 20 * Interface for an EditText subclass that can delegate calls to onKeyPreIme up to a registered 21 * listener. 22 * <p> 23 * Used in editable actions within {@link androidx.leanback.app.GuidedStepFragment} to 24 * allow for custom back key handling. Specifically, this is used to implement the behavior that 25 * dismissing the IME also clears edit text focus. Clients who need to supply custom layouts for 26 * {@link GuidedActionsStylist} with their own EditText classes should satisfy this interface in 27 * order to inherit this behavior. 28 */ 29 public interface ImeKeyMonitor { 30 31 /** 32 * Listener interface for key events intercepted pre-IME by edit text objects. 33 */ 34 public interface ImeKeyListener { 35 /** 36 * Callback invoked from EditText's onKeyPreIme method override. Returning true tells the 37 * caller that the key event is handled and should not be propagated. 38 */ onKeyPreIme(EditText editText, int keyCode, KeyEvent event)39 public abstract boolean onKeyPreIme(EditText editText, int keyCode, KeyEvent event); 40 } 41 42 /** 43 * Set the listener for this edit text object. The listener's onKeyPreIme method will be 44 * invoked from the host edit text's onKeyPreIme method. 45 */ setImeKeyListener(ImeKeyListener listener)46 public void setImeKeyListener(ImeKeyListener listener); 47 } 48