文章连接: https://mp.weixin.qq.com/s/1gkMtLu0BTXOUOj6isDjUw
平常android开发过程当中,会遇到编辑框输入内容弹出软键盘,每每会出现键盘遮挡内容,或者出现页面总体上移的,或多或少在体验上都不是很优雅,今天提供个方法是自行控制页面上移距离,竟可能让页面呈现给用户友好点。 android
通常咱们会在AndroidManifest.xml
里配置windowSoftInputMode
来控制键盘与页面的交互。git
举个栗子,一个简单的登陆页面。github
activity 加<activity android:windowSoftInputMode="adjustResize">
adjustResize
:Activity老是调整屏幕的大小以便留出软键盘的空间,能够看到页面总体上移,最下面的一行字也能够看到。 微信
activity 加<activity android:windowSoftInputMode="adjustPan">
adjustPan
:当前窗口的内容将自动移动以便当前焦点不被键盘覆盖,用户能老是看到输入内容的部分。
能够发现页面会自动移动,以便获取焦点的editText 不被键盘遮住,可是肯定按钮被遮住了,用户须要自行隐藏键盘 再肯定。 ide
而我想要的效果是用户输入过程当中 肯定 按钮一直可见,且要底部的内容被遮挡,这就须要咱们本身控制页面上移距离。
监听键盘弹出/隐藏的过程,获取键盘高度,计算须要上移的高度,以便按钮可见。布局
//监听键盘弹出/隐藏 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); } } });
效果以下:
这样用户输入完成以后就能够直接点击肯定按钮,体验上有所改善。 学习
固然,具体使用哪一种方法得看页面需求。 spa
github地址:https://github.com/taixiang/Inputcode
欢迎关注个人我的博客:https://www.manjiexiang.cn/ server
更多精彩欢迎关注微信号:春风十里不如认识你
一块儿学习,一块儿进步,欢迎上车,有问题随时联系,一块儿解决!!!