本来使用自定义键盘,使用popuwindow来弹出界面,在7.0以前的手机上好,有一天测试人员说在android 7.0的手机上,键盘的位置会跑掉,赶紧搜了一下,发现很多人遇到这个问题,应该是谷歌自身的bug,解决的方式就是检查如果是7.0的手机的话,就使用决定定位,如下代码:
mKeyboardView.setKeyboard(mKeyboard); mKeyboardWindow.setAnimationStyle(R.style.AnimBottom); if (Build.VERSION.SDK_INT < 24) { mKeyboardWindow.showAtLocation(this.mDecorView, Gravity.RIGHT | Gravity.BOTTOM, 0, 0); } else { // 适配 android 7.0 int[] location = new int[2]; getLocationOnScreen(location); int x = location[0]; int y = location[1]; mKeyboardWindow.showAtLocation(mDecorView, Gravity.TOP, 0, DensityDpToPx.dpToPx(context, CommDataUtil.getAndroiodScreenProperty(context))); }
其中DensityDpToPx.dpToPx方法,和CommDataUtil.getAndroiodScreenProperty方法的代码如下:
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public static int dpToPx(final Context context, final float dp) { return (int) (dp * context.getResources().getDisplayMetrics().density); }
public static int getAndroiodScreenProperty(Context context) {//获取屏幕高度 WindowManager wm = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE); DisplayMetrics dm = new DisplayMetrics(); wm.getDefaultDisplay().getMetrics(dm); int width = dm.widthPixels; // 屏幕宽度(像素) int height = dm.heightPixels; // 屏幕高度(像素) float density = dm.density; // 屏幕密度(0.75 / 1.0 / 1.5) int densityDpi = dm.densityDpi; // 屏幕密度dpi(120 / 160 / 240) // 屏幕宽度算法:屏幕宽度(像素)/屏幕密度 int screenWidth = (int) (width / density); // 屏幕宽度(dp) int screenHeight = (int) (height / density);// 屏幕高度(dp) return screenHeight; }其中关键是这个:mKeyboardWindow.showAtLocation(mDecorView, Gravity.TOP, 0,
DensityDpToPx.dpToPx(context, CommDataUtil.getAndroiodScreenProperty(context)));//设置键盘从底部弹出来