欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

android 记一次解决键盘遮挡问题

程序员文章站 2022-06-19 23:16:42
文章链接: "https://mp.weixin.qq.com/s/1gkMtLu0BTXOUOj6isDjUw" 日常android开发过程中,会遇到编辑框输入内容弹出软键盘,往往会出现键盘遮挡内容,或者出现页面整体上移的,或多或少在体验上都不是很优雅,今天提供个方法是自行控制页面上移距离,竟可能 ......

文章链接:https://mp.weixin.qq.com/s/1gkmtlu0btxouoj6isdjuw

日常android开发过程中,会遇到编辑框输入内容弹出软键盘,往往会出现键盘遮挡内容,或者出现页面整体上移的,或多或少在体验上都不是很优雅,今天提供个方法是自行控制页面上移距离,竟可能让页面呈现给用户友好点。

一般我们会在androidmanifest.xml 里配置windowsoftinputmode来控制键盘与页面的交互。

举个栗子,一个简单的登录页面。

adjustresize

activity 加<activity android:windowsoftinputmode="adjustresize">
adjustresize:activity总是调整屏幕的大小以便留出软键盘的空间,可以看到页面整体上移,最下面的一行字也可以看到。
android 记一次解决键盘遮挡问题

adjustpan

activity 加<activity android:windowsoftinputmode="adjustpan">
adjustpan:当前窗口的内容将自动移动以便当前焦点不被键盘覆盖,用户能总是看到输入内容的部分。
可以发现页面会自动移动,以便获取焦点的edittext 不被键盘遮住,但是确定按钮被遮住了,用户需要自行隐藏键盘 再确定。
android 记一次解决键盘遮挡问题

而我想要的效果是用户输入过程中 确定 按钮一直可见,且要底部的内容被遮挡,这就需要我们自己控制页面上移距离。
监听键盘弹出/隐藏的过程,获取键盘高度,计算需要上移的高度,以便按钮可见。

//监听键盘弹出/隐藏
container.getviewtreeobserver().addongloballayoutlistener(new viewtreeobserver.ongloballayoutlistener() {
    @override
    public void ongloballayout() {
        rect rect = new rect();
        //getwindowvisibledisplayframe 获取当前窗口可视区域大小
        getwindow().getdecorview().getwindowvisibledisplayframe(rect);
        int screenheight = getwindow().getdecorview().getheight();
        //键盘弹出时,可视区域大小改变,屏幕高度 - 窗口可视区域高度 = 键盘弹出高度
        int softheight = screenheight - rect.bottom;
        /**
         * 上移的距离 = 键盘的高度 - 按钮距离屏幕底部的高度(如果手机高度很大,上移的距离会是负数,界面将不会上移)
         * 按钮距离屏幕底部的高度是用屏幕高度 - 按钮底部距离父布局顶部的高度
         * 注意这里 btn.getbottom() 是按钮底部距离父布局顶部的高度,这里也就是距离最外层布局顶部高度
         */
        int scrolldistance = softheight - (screenheight - btn.getbottom());
        if (scrolldistance > 0) {
            //具体移动距离可自行调整
            container.scrollto(0, scrolldistance + 60);
        } else {
            //键盘隐藏,页面复位
            container.scrollto(0, 0);
        }
    }
});

效果如下:
android 记一次解决键盘遮挡问题
这样用户输入完成之后就可以直接点击确定按钮,体验上有所改善。

当然,具体使用哪种方法得看页面需求。

github地址:https://github.com/taixiang/input

欢迎关注我的个人博客:

更多精彩欢迎关注微信号:春风十里不如认识你
一起学习,一起进步,欢迎上车,有问题随时联系,一起解决!!!

android 记一次解决键盘遮挡问题