软键盘(挡住button,和点击外部软键盘消失)
来源:互联网 发布:mc怎么知道网络lp 编辑:程序博客网 时间:2024/05/21 14:02
软键盘(挡住button,和点击外部软键盘消失)
以下是解决挡住button的逻辑 (写的比较急,黄色的部分就是edittext)
// 控制是否移动布局。比如只有密码输入框获取到焦点时才执行。public boolean flag = true;/** * @param act activiry用于获取底部导航栏高度。 * @param root 最外层布局,需要调整的布局 * @param scrollToView 被键盘遮挡的scrollToView,滚动root,使scrollToView在root可视区域的底部 */public void controlKeyboardLayout(Context act, final View root, final View scrollToView) { final int navigationBarHeight = getNavigationBarHeight(act); root.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { @Override public void onGlobalLayout() { Rect rect = new Rect(); //获取root在窗体的可视区域 root.getWindowVisibleDisplayFrame(rect); //获取root在窗体的不可视区域高度(被其他View遮挡的区域高度) int rootInvisibleHeight = root.getRootView().getHeight() - rect.bottom; //若不可视区域高度大于100,则键盘显示 if (rootInvisibleHeight > navigationBarHeight && flag) { int[] location = new int[2]; //获取scrollToView在窗体的坐标 scrollToView.getLocationInWindow(location); //计算root滚动高度,使scrollToView在可见区域 int srollHeight = (location[1] + scrollToView.getHeight()) - rect.bottom; if (root.getScrollY() != 0) {// 如果已经滚动,要根据上次滚动,重新计算位置。 srollHeight += root.getScrollY(); } root.scrollTo(0, srollHeight); } else { //键盘隐藏 root.scrollTo(0, 0); } } });}
以下是解决控制点击可选择的区域让软键盘消失或者不消失
/** * 获取底部导航栏高度 * * @param act * @return */private int getNavigationBarHeight(Context act) { Resources resources = act.getResources(); int resourceId = resources.getIdentifier("navigation_bar_height", "dimen", "android"); int height = resources.getDimensionPixelSize(resourceId); Log.v("dbw", "Navi height:" + height); return height;}//软键盘消失的管理//region软键盘的处理/** * 清除editText的焦点 * * @param v 焦点所在View * @param ids 输入框 */public void clearViewFocus(View v, int... ids) { if (null != v && null != ids && ids.length > 0) { for (int id : ids) { if (v.getId() == id) { v.clearFocus(); break; } } }}/** * 隐藏键盘 * * @param v 焦点所在View * @param ids 输入框 * @return true代表焦点在edit上 */public boolean isFocusEditText(View v, int... ids) { if (v instanceof EditText) { EditText tmp_et = (EditText) v; for (int id : ids) { if (tmp_et.getId() == id) { return true; } } } return false;}//是否触摸在指定view上面,对某个控件过滤public boolean isTouchView(View[] views, MotionEvent ev) { if (views == null || views.length == 0) return false; int[] location = new int[2]; for (View view : views) { view.getLocationOnScreen(location); int x = location[0]; int y = location[1]; if (ev.getX() > x && ev.getX() < (x + view.getWidth()) && ev.getY() > y && ev.getY() < (y + view.getHeight())) { return true; } } return false;}//region 右滑返回上级@Overridepublic boolean dispatchTouchEvent(MotionEvent ev) { if (ev.getAction() == MotionEvent.ACTION_DOWN) { if (isTouchView(filterViewByIds(), ev)) return super.dispatchTouchEvent(ev); if (hideSoftByEditViewIds() == null || hideSoftByEditViewIds().length == 0) return super.dispatchTouchEvent(ev); View v = getCurrentFocus(); if (isFocusEditText(v, hideSoftByEditViewIds())) { //隐藏键盘 hideInputForce(this); clearViewFocus(v, hideSoftByEditViewIds()); } } return super.dispatchTouchEvent(ev);}/** * 传入EditText的Id * 没有传入的EditText不做处理 * * @return id 数组 */public int[] hideSoftByEditViewIds() { return null;}/** * 传入要过滤的View * 过滤之后点击将不会有隐藏软键盘的操作 * * @return id 数组 */public View[] filterViewByIds() { return null;}/** * des:隐藏软键盘,这种方式参数为activity * * @param activity */public static void hideInputForce(Activity activity) { if (activity == null || activity.getCurrentFocus() == null) return; ((InputMethodManager) activity.getSystemService(INPUT_METHOD_SERVICE)) .hideSoftInputFromWindow(activity.getCurrentFocus() .getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS);}
以下Demo全部代码
package fengan.softinputdemo;
import android.app.Activity;
import android.content.Context;
import android.content.res.Resources;
import android.graphics.Rect;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewTreeObserver;
import android.view.inputmethod.InputMethodManager;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
public class MainActivity extends AppCompatActivity {
private EditText mEt1;private EditText mEt2;@Overrideprotected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Button btn = (Button) findViewById(R.id.btn); mEt1 = (EditText) findViewById(R.id.et1); mEt2 = (EditText) findViewById(R.id.et2); LinearLayout LL = (LinearLayout) findViewById(R.id.LL); controlKeyboardLayout(this,LL,btn);}// 控制是否移动布局。比如只有密码输入框获取到焦点时才执行。public boolean flag = true;/** * @param act activiry用于获取底部导航栏高度。 * @param root 最外层布局,需要调整的布局 * @param scrollToView 被键盘遮挡的scrollToView,滚动root,使scrollToView在root可视区域的底部 */public void controlKeyboardLayout(Context act, final View root, final View scrollToView) { final int navigationBarHeight = getNavigationBarHeight(act); root.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { @Override public void onGlobalLayout() { Rect rect = new Rect(); //获取root在窗体的可视区域 root.getWindowVisibleDisplayFrame(rect); //获取root在窗体的不可视区域高度(被其他View遮挡的区域高度) int rootInvisibleHeight = root.getRootView().getHeight() - rect.bottom; //若不可视区域高度大于100,则键盘显示 if (rootInvisibleHeight > navigationBarHeight && flag) { int[] location = new int[2]; //获取scrollToView在窗体的坐标 scrollToView.getLocationInWindow(location); //计算root滚动高度,使scrollToView在可见区域 int srollHeight = (location[1] + scrollToView.getHeight()) - rect.bottom; if (root.getScrollY() != 0) {// 如果已经滚动,要根据上次滚动,重新计算位置。 srollHeight += root.getScrollY(); } root.scrollTo(0, srollHeight); } else { //键盘隐藏 root.scrollTo(0, 0); } } });}/** * 获取底部导航栏高度 * * @param act * @return */private int getNavigationBarHeight(Context act) { Resources resources = act.getResources(); int resourceId = resources.getIdentifier("navigation_bar_height", "dimen", "android"); int height = resources.getDimensionPixelSize(resourceId); Log.v("dbw", "Navi height:" + height); return height;}//软键盘消失的管理//region软键盘的处理/** * 清除editText的焦点 * * @param v 焦点所在View * @param ids 输入框 */public void clearViewFocus(View v, int... ids) { if (null != v && null != ids && ids.length > 0) { for (int id : ids) { if (v.getId() == id) { v.clearFocus(); break; } } }}/** * 隐藏键盘 * * @param v 焦点所在View * @param ids 输入框 * @return true代表焦点在edit上 */public boolean isFocusEditText(View v, int... ids) { if (v instanceof EditText) { EditText tmp_et = (EditText) v; for (int id : ids) { if (tmp_et.getId() == id) { return true; } } } return false;}//是否触摸在指定view上面,对某个控件过滤public boolean isTouchView(View[] views, MotionEvent ev) { if (views == null || views.length == 0) return false; int[] location = new int[2]; for (View view : views) { view.getLocationOnScreen(location); int x = location[0]; int y = location[1]; if (ev.getX() > x && ev.getX() < (x + view.getWidth()) && ev.getY() > y && ev.getY() < (y + view.getHeight())) { return true; } } return false;}//region 右滑返回上级@Overridepublic boolean dispatchTouchEvent(MotionEvent ev) { if (ev.getAction() == MotionEvent.ACTION_DOWN) { if (isTouchView(filterViewByIds(), ev)) return super.dispatchTouchEvent(ev); if (hideSoftByEditViewIds() == null || hideSoftByEditViewIds().length == 0) return super.dispatchTouchEvent(ev); View v = getCurrentFocus(); if (isFocusEditText(v, hideSoftByEditViewIds())) { //隐藏键盘 hideInputForce(this); clearViewFocus(v, hideSoftByEditViewIds()); } } return super.dispatchTouchEvent(ev);}/** * 传入EditText的Id * 没有传入的EditText不做处理 * * @return id 数组 */public int[] hideSoftByEditViewIds() { int [] ids = {R.id.et1,R.id.et2}; return ids;}/** * 传入要过滤的View * 过滤之后点击将不会有隐藏软键盘的操作 * * @return id 数组 */public View[] filterViewByIds() { View [] views = {mEt1,mEt2};//点击这两个控件,软键盘不会消失 return views;}/** * des:隐藏软键盘,这种方式参数为activity * * @param activity */public static void hideInputForce(Activity activity) { if (activity == null || activity.getCurrentFocus() == null) return; ((InputMethodManager) activity.getSystemService(INPUT_METHOD_SERVICE)) .hideSoftInputFromWindow(activity.getCurrentFocus() .getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS);}
}
以下是布局文件
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="fengan.softinputdemo.MainActivity"> <LinearLayout android:id="@+id/LL" android:layout_marginTop="100dp" android:layout_width="match_parent" android:orientation="vertical" android:layout_height="wrap_content"> <EditText android:id="@+id/et1" android:layout_marginTop="60dp" android:background="#ff0" android:layout_width="match_parent" android:layout_height="60dp"/> <EditText android:id="@+id/et2" android:layout_marginTop="20dp" android:background="#ff0" android:layout_width="match_parent" android:layout_height="60dp"/> <Button android:text="软键盘挡住button" android:id="@+id/btn" android:layout_marginTop="30dp" android:layout_width="match_parent" android:layout_height="wrap_content"/> </LinearLayout></LinearLayout>
可以将隐藏显示的代码封装到BaseActivity
阅读全文
0 0
- 软键盘(挡住button,和点击外部软键盘消失)
- edittext点击文本外部使软键盘消失
- 软键盘挡住EditText
- 点击屏幕任意区域软键盘消失
- 点击按钮时软键盘消失
- 点击空白处,软键盘消失
- Android 点击空白区域 软键盘消失
- 点击空白处,软键盘消失
- android软键盘挡住界面
- edittext 被软键盘挡住
- EditText被软键盘挡住
- 带输入框的自定义dialog 点击外部消失 输入框可以弹出软键盘 去除外部黑框
- Android 点击EditText的时候弹出软键盘,点击EditText之外空白处软键盘消失
- Android--点击EditText的时候弹出软键盘,点击EditText之外空白处软键盘消失
- 安卓editview点击时打开软键盘,点击其他地方软键盘消失(Activity中)
- 安卓editview点击时打开软键盘,点击其他地方软键盘消失(fragment中)
- android实现点击空白处,软键盘消失事件
- Android 点击屏幕除TextView区域软键盘自动消失
- feign-底层http请求组件剖析
- nodejs 动态加载模块 _compile
- 微信放大招,和整个互联网为敌?
- python2.7基于selenium的web自动化测试项目--contract
- 如何将pdf等非标准数据文件转换成可供EXCEL等软件分析的数据
- 软键盘(挡住button,和点击外部软键盘消失)
- Spring boot中使用工具类 无需注入获取.yml中的值
- 错误:无法与 SFTP 服务器建立 FTP 连接
- Hive 元数据表结构详解
- Android 自定义View 日历
- // 十六进制字符串 换成字符数组转
- angular入门--分页
- Android中的“再按一次返回键退出程序”实现
- 【剑指offer】单链表尾部插入一个节点