本来使用自定义键盘,使用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)));//设置键盘从底部弹出来