如和优雅地实现键盘展开/收起监听
Android 键盘的展开与收起一直是个很遭人诟病的东西
方法各式各样都有,但是基本都不是很好用,有各种限制
这里编写了一个优雅地实现方式,利用屏幕实际高度与显示区域的高度对比可以优雅地判断出是否弹出键盘.
众所周知键盘是会侵占实际应用的显示区域,导致实际显示区域要远小于屏幕高度文章来源地址https://www.toymoban.com/news/detail-523606.html
上代码 拉走直接用
/**
* CreateTime 2023/2/616:08
* 键盘 打开/收起 监听 实时回调
*/
class KeyBoardUtil(
activity: Activity,
var keyboardVisibilityListener: ((isVisibility: Boolean) -> Unit)?
) {
private val contentView: View
var height: Int = 0
var isVisibility = false
init {
contentView = activity.window.decorView
//初始化时先判断当前键盘状态
isVisibility = getScreenHeight(activity) > getWindowContentHeight(activity)
//这个监听的主要作用是在键盘弹出布局发生改变时 动态的通知用户键盘是否弹出
contentView.viewTreeObserver.addOnGlobalLayoutListener {
isVisibility = if (getScreenHeight(activity) > getWindowContentHeight(activity)) {
keyboardVisibilityListener?.invoke(true)
true
} else {
keyboardVisibilityListener?.invoke(false)
false
}
}
}
//屏幕高度 固定不变 = 屏幕高度 - titlebar
private fun getScreenHeight(context: Context?): Int {
val displayMetrics = context!!.resources.displayMetrics
return displayMetrics.heightPixels
}
//可视区域高度 会根据显示区域变化 出现键盘时变小 不出现时 大于等于 getScreenHeight()高度
private fun getWindowContentHeight(activity: Activity?):Int{
if (activity==null)return 0
val rect = Rect()
activity.window.decorView.getWindowVisibleDisplayFrame(rect)
return rect.height()
}
companion object{
/**
* 隐藏键盘的方法
*
* @param context
*/
fun hideKeyboard(context:Activity?) {
val imm = context?.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
// 隐藏软键盘
imm.hideSoftInputFromWindow(context.window.decorView.windowToken, 0);
}
}
}
使用方式
var keyBoardUtil: KeyBoardUtil = KeyBoardUtil(activity){isVisibility->
}
fun show(){
if (keyBoardUtil?.isVisibility==true){//判断当前键盘是否显示
KeyBoardUtil.hideKeyboard(this)//收起键盘
keyBoardUtil?.keyboardVisibilityListener={//键盘收起监听
if (!it){//键盘收起后下一步
//todo 操作
keyBoardUtil?.keyboardVisibilityListener = null//取消监听,防止后续键盘持续监听
}
}
}else{
//todo 当前键盘未显示 下一步
}
}
原创不易,有用的兄弟给个三连哈
文章来源:https://www.toymoban.com/news/detail-523606.html
到了这里,关于Android 键盘监听 键盘展开/收起监听的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!