dialog弹出,手动关闭输入法之后,dialog还在,需要二次关闭dialog这就让用户体验很不好。那么如何让输入法关闭的同时,让dialog也跟着消失呢?跟着小编一起来看一下吧。
请看效果图:
这个GIF图里,可以看到,我手动关闭了输入法之后Dialog也跟着消失了,而且我点击手机上的返回键也能达到同样的效果。那么就来实现这个效果吧:
我们这次用的是BottomSheetDialogFragment来做这个效果。上代码:
将这个代码复制到你的项目中去。
public class SendCommentDialogFragment extends BottomSheetDialogFragment {
private Dialog dialog;
private int mLastDiff = 0;//键盘弹出过程中最后的高度值
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setStyle(DialogFragment.STYLE_NO_FRAME, R.style.DialogTheme);//给dialog设置主题为透明背景 不然会有默认的白色背景
}
@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
dialog = super.onCreateDialog(savedInstanceState);
dialog.setCanceledOnTouchOutside(true);//设置点击外部可消失
Window win = dialog.getWindow();
WindowManager.LayoutParams params = win.getAttributes();
win.setSoftInputMode(params.SOFT_INPUT_STATE_VISIBLE | params.SOFT_INPUT_ADJUST_RESIZE);//配置输入法,避免弹出遮挡布局
win.setWindowAnimations(R.style.Anim_Dialog_Bottom);//这里设置dialog的进出动画
return dialog;
}
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
//绑定你的Dialog布局文件
View view = inflater.inflate(R.layout.dialog_sendcomment, container, false);
view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT));
return view;
}
@Override
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
//R.id.dialog_ly这里是根布局
LinearLayout dialogLy = view.findViewById(R.id.dialog_ly);
dialogLy.addOnLayoutChangeListener(new View.OnLayoutChangeListener() {
//监听输入法的弹出与关闭,让输入法关闭时dialog也消失
@Override
public void onLayoutChange(View view, int i, int i1, int i2, int i3, int i4, int i5, int i6, int i7) {
Rect r = new Rect();
dialog.getWindow().getDecorView().getWindowVisibleDisplayFrame(r);//获取当前界面可视部分
int screenHeight = dialog.getWindow().getDecorView().getRootView().getHeight();//获取屏幕的高度
int heightDifference = screenHeight - r.bottom;//此处就是用来获取键盘的高度的, 在键盘没有弹出的时候 此高度为0 键盘弹出的时候为一个正数
if (heightDifference <= 0 && mLastDiff > 0) {
onDismiss(dialog);//手动关闭输入法时,对话框也跟着关闭
}
mLastDiff = heightDifference;
}
});
}
@Override
public void onStart() {
super.onStart();
final View view = getView();
view.post(new Runnable() {
@Override
public void run() {
View parent = (View) view.getParent();
CoordinatorLayout.LayoutParams params = (CoordinatorLayout.LayoutParams) (parent).getLayoutParams();
CoordinatorLayout.Behavior behavior = params.getBehavior();
BottomSheetBehavior mBottomSheetBehavior = (BottomSheetBehavior) behavior;
mBottomSheetBehavior.setHideable(false);//禁止下拉取消弹框
mBottomSheetBehavior.setPeekHeight(view.getMeasuredHeight());//让内容显示完整
}
});
}
}
调用:
SendCommentDialogFragment dialogFragment = new SendCommentDialogFragment();
dialogFragment.show(getFragmentManager(),dialogFragment.getClass().getName());
然后你就会发现对话框和输入法就展示出来了,但是你也会发现部分的布局被输入法遮挡了,那怎么办呢?解决办法如下:
在你的项目中的res/values/styles文件中找到该对话框的主题文件,然后配置输入法,像这样:
<style name="DialogTheme">
<item name="android:windowIsFloating">false</item>
<item name="android:windowSoftInputMode">adjustResize</item>
</style>
加上这两句代码,布局也能完整地显示啦。