Eu recomendo o uso de um LifecycleObserver que faz parte do Manipulando Ciclos de Vida com Componentes Reconhecidos pelo Ciclo de Vida do Android Jetpack .
Quero abrir e fechar o teclado quando o fragmento / atividade aparecer. Primeiro, defina duas funções de extensão para o EditText. Você pode colocá-los em qualquer lugar do seu projeto:
fun EditText.showKeyboard() {
requestFocus()
val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
imm.showSoftInput(this, InputMethodManager.SHOW_IMPLICIT)
}
fun EditText.hideKeyboard() {
val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
imm.hideSoftInputFromWindow(this.windowToken, 0)
}
Em seguida, defina um LifecycleObserver que abra e feche o teclado quando a Atividade / Fragmento atingir onResume()
ou onPause
:
class EditTextKeyboardLifecycleObserver(private val editText: WeakReference<EditText>) :
LifecycleObserver {
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
fun openKeyboard() {
editText.get()?.postDelayed({ editText.get()?.showKeyboard() }, 100)
}
@OnLifecycleEvent(Lifecycle.Event.ON_PAUSE)
fun closeKeyboard() {
editText.get()?.hideKeyboard()
}
}
Em seguida, adicione a seguinte linha a qualquer um dos seus Fragmentos / Atividades. Você pode reutilizar o LifecycleObserver a qualquer momento. Por exemplo, para um fragmento:
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
// inflate the Fragment layout
lifecycle.addObserver(EditTextKeyboardLifecycleObserver(WeakReference(myEditText)))
// do other stuff and return the view
}