Dialog嵌Dialog打开软键盘设置布局不向顶部位移方案

不得不说 Android 碎片化有时候真的很恶心

在 dialog 里打开 webview 横竖屏适配,在横屏下输入框输入时弹出软键盘一些手机会把布局向上顶一些手机是软键盘直接覆盖在布局上,都会把输入框挡住,如此这样针对两种不同的位移情况要做不挡住输入框的适配就很麻烦了,我选择软键盘直接打开覆盖布局而不顶上去的方案,因为之前webview 大多用在 activity,其实 dialog 也简单,只是一开始没想到,只要修改 theme 即可。

软键盘没打开的时候是这样的

Dialog嵌Dialog打开软键盘设置布局不向顶部位移方案

打开软键盘时这样,布局顶上去了

Dialog嵌Dialog打开软键盘设置布局不向顶部位移方案

修改后是这样,至于输入框被挡住的问题后面补充

Dialog嵌Dialog打开软键盘设置布局不向顶部位移方案

解决方法

在 style.xml 加入

<style name="DialogActivityTheme" parent="@android:style/Theme.Translucent.NoTitleBar.Fullscreen">
    <item  name= "android:windowFullscreen" >true </item>
    <item name="android:windowFrame">@null</item><!--边框-->
    <item name="android:windowIsTranslucent">false</item><!--半透明-->
    <item name="android:windowNoTitle">true</item><!--无标题-->
    <item name="android:background">@android:color/transparent</item>
    <item name="android:windowBackground">@android:color/transparent</item><!--背景透明-->
    <item name="android:backgroundDimEnabled">true</item><!--模糊-->
    <item name="android:windowSoftInputMode">stateVisible|adjustPan</item>
</style>

在代码里加入

if (dialog == null) {
                dialog = new Dialog(activity, R.style.DialogActivityTheme);
            }

 

上一篇:浅拷贝的应用(element-ui中的表格【table】与对话框【Dialog】的综合)


下一篇:【转】 前端笔记之JavaScript面向对象(四)组件化开发&轮播图|俄罗斯方块实战