DialogFragment全屏显示时两侧有留白问题

34

我正在创建一个自定义的DialogFragment,它显示在操作栏下方。到目前为止一切正常。对话框片段的布局参数是match_parent(宽度)和wrap_content(高度)。

我已经尝试了每一个解决方案,包括设置布局参数的.width和获取Display大小以及删除主题。然而,无论如何,对话框左侧、右侧和顶部都存在一小部分不可见空间。我需要知道如何去除这个空间,使其实际匹配屏幕的宽度,并希望能够消除顶部填充。


尝试更改对话框的样式/主题。 - An-droid
尝试下面的代码,如果可以运行请告诉我。对话框将占用整个可用空间。 - Raghunandan
是的,我有。有几个主题可以去除填充,但也会删除设置为片段的所有其他参数。DialogFragment仅以全屏显示(宽度和高度均为match_parent,并删除任何x偏移量以适应操作栏)。这不是我想要的东西。 - ahmad
11个回答

35

我使用自定义对话框主题找到了解决方法。将windowIsFloating设置为true将消除背景,但会在背景下方添加一些额外的空间作为背景。在这种情况下,您可以使用windowBackground @null来擦除它。

<style name="CustomDialog" parent="@android:style/Theme.Holo.Light" >
    <item name="android:windowBackground">@null</item>
    <item name="android:windowIsFloating">true</item>
</style>

使用方法:

AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(), R.style.CustomDialog);

感谢Raghunandan提供了包含所有样式属性的链接。我花了一些时间浏览了那个文件,发现了非常有趣的元素。肯定要查看下面发布的链接以探索主题风格。

https://android.googlesource.com/platform/frameworks/base/+/refs/heads/master/core/res/res/values/themes.xml


在调用 new Dialog(getActivity(), R.style.CustomDialog) 之后,对我来说是可以正常工作的。 - Weiyi

15

终于解决了!我的问题是父级主题: parent="@android:style/Theme.Dialog", 改成另一个主题后,我的 DialogFragment 看起来很好,有合适的边距。 - Marcelo Baccelli
你的解决方案对我有用。但是当我从onTextQuerySubmit()调用DialogFragment时,我的对话框会出现黄色边框。你知道这个问题吗? - Kousalya
@Kousalya,这个答案是在2013年回答的。最好你提出一个新问题来涉及这个话题。 - Raghunandan

10
如果将这个主题设置为您的对话框,它将始终全屏显示。
<!-- DIALOG STYLE -->
<style name="You.Dialog" parent="android:Theme.Holo.Dialog" >
    <item name="android:windowNoTitle">true</item>
    <item name="android:windowFullscreen">true</item>
    <item name="android:windowIsFloating">false</item>
</style>

为了实现此操作,您可以使用此setStyle(int,int)方法。
dialogFragment.setStyle( DialogFragment.STYLE_NORMAL, R.style.You_Dialog );

我正在尝试您的解决方案。我不想要全屏,我只想从两侧删除填充。如果我使用其中任何一个主题,我将失去对以编程方式分配任何参数的控制。 - ahmad

7

对于支持API 11以下版本的设备,这个方法适用。

创建一个全屏且具有透明背景的样式:

<style name="TransparentDialog" parent="@android:style/Theme">
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:background">@android:color/transparent</item>
</style>

然后是你的DialogFragment代码:
public class MyDialog extends DialogFragment {

     public static MyDialog newInstance() {
         MyDialog dialog = new MyDialog();
         dialog.setStyle(DialogFragment.STYLE_NO_FRAME, R.style.TransparentDialog);
         return dialog;
     }

     @Override
     public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.my_custom_layout, container, false);
        return view;
    }
}

最后,为了更加清晰,这是my_custom_layout.xml的内容:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res/com.kabx"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/semi_transparent_grey" >

..........................
..Whatever You Want Here..
..........................

</RelativeLayout>

7

首先,您需要知道Dialog Fragment中的全屏处理与普通对话框组件不同,其次,在实际创建对话框之前需要自定义Dialog Fragment @(OnCreateDialog),根据“user3244180”的回答进行操作。详情请参阅全屏DialogFragment

 @Override
 public Dialog onCreateDialog(final Bundle savedInstanceState) {

     // the content
     final RelativeLayout root = new RelativeLayout(getActivity());
     root.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));

     // creating the fullscreen dialog
     final Dialog dialog = new Dialog(getActivity());
     dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
     dialog.setContentView(root);
     dialog.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
     dialog.getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);

     return dialog;
 }

一个 FrameLayout 同样可以工作,而且它是一个更轻量级的 ViewGroup。另外 -- 我注意到当我省略 dialog.requestWindowFeature(Window.FEATURE_NO_TITLE) 时没有任何区别。 - AutonomousApps

6

我之前遇到过这个问题:在设置全屏后,总是有一个填充。在dialogFragment的onActivityCreated()方法中尝试以下代码:

public void onActivityCreated(Bundle savedInstanceState)
{   
    Window window = getDialog().getWindow();
    LayoutParams attributes = window.getAttributes();
    //must setBackgroundDrawable(TRANSPARENT) in onActivityCreated()
    window.setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
    if (needFullScreen)
    {
        window.setLayout(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
    }
}

2
<style name="WideDialog" parent="Theme.AppCompat.Light.DialogWhenLarge">
        <item name="android:windowNoTitle">true</item>
        <item name="android:windowFullscreen">false</item>
        <item name="android:windowIsFloating">false</item>
    </style>

@Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setStyle(DialogFragment.STYLE_NORMAL, R.style.WideDialog);
    }

1
以下内容对我非常有效。它让我可以拥有一个全宽的对话框(不带填充地填满屏幕宽度),但高度为wrap_content,并保留我在构建器中进行的所有其他样式设置:
<style name="DialogTheme">

    <item name="windowMinWidthMajor">100%</item>
    <item name="windowMinWidthMinor">100%</item>

    <item name="android:windowBackground">@null</item>
    <item name="android:windowIsFloating">true</item>

    <item name="android:background">#ffffff</item>

</style>

必须设置背景,否则会出现奇怪的重复问题,但是只需将其设置为您想要对话框背景的颜色即可。需要WindowBackground和WindowIsFloating以正确包裹大小。

像这样将您的主题添加到构建器中:

builder = new AlertDialog.Builder(_context, R.style.DialogTheme);

并且你就可以开始了!

1

如果没有明确指定,DialogFragment将使用其内部样式将您的自定义布局包装在其中(不全屏等)。

无需为此问题创建自定义主题。只需使用此方法并设置所选样式和主题:

/* theme is optional, I am using leanback... */
setStyle(STYLE_NORMAL, R.style.AppTheme_Leanback);

0

关于全屏对话框,我已经发布了一个答案

在这个帖子中

请检查这是否是最有效和最短的方法。 希望能帮到你 :)


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接