android 键盘弹出,布局重绘

在我们一般写登录、注册页面的时候,经常会因为软键盘弹出导致页面上移,导致布局被遮挡,用户体验很不好。
我们可以使用自定义Layout,动态判断layout是否改变,在根据权重进行适配。


class AdjustLayout(context: Context, attributes: AttributeSet) : LinearLayout(context, attributes) {

    var keyboardShowed = false

    override fun onLayout(changed: Boolean, left: Int, top: Int, right: Int, bottom: Int) {
        super.onLayout(changed, left, top, right, bottom)
        if (changed) {
            val width = right - left
            val height = bottom - top
            if (height.toFloat() / width.toFloat() < 4f / 3f) { // 如果高宽比小于4:3说明此时键盘弹出
                post {
                      loginBgLayout.visibility = View.INVISIBLE
                      val params = loginLayout.layoutParams as LayoutParams
                      params.weight = 1.5f
                      keyboardShowed = true
                      loginLayoutTop.requestLayout()
                }
            } else {
                if (keyboardShowed) {
                    post {
                          loginBgWallLayout.visibility = View.VISIBLE
                          val params = loginLayout.layoutParams as LayoutParams
                          params.weight = 6f
                          loginLayout.requestLayout()
                    }
                }
            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值