Як зробити DialogFragment шириною до Fill_Parent


95

Я працюю над додатком для Android, де я використовую DialogFragmentдля відображення діалогове вікно, але його ширина дуже мала. Як я можу зробити цю ширину доfill_parent до нього?

public class AddNoteDialogFragment extends DialogFragment {

    public AddNoteDialogFragment() {
        // Empty constructor required for DialogFragment
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        getDialog().setTitle(getString(R.string.app_name));
        View view = inflater.inflate(R.layout.fragment_add_note_dialog,
                container);

        return view;
    }


    @Override
    public Dialog onCreateDialog(Bundle savedInstanceState) {
        Dialog dialog = super.onCreateDialog(savedInstanceState);

        // request a window without the title
        dialog.getWindow().requestFeature(Window.FEATURE_NO_TITLE);

        return dialog;
    }
}

fragment_add_note_dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin" >

    <EditText
        android:id="@+id/addNoteEditText"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="top"
        android:hint="@string/clock_enter_add_note"
        android:imeOptions="actionDone"
        android:inputType="textCapSentences|textMultiLine"
        android:lines="5" />

    <Button
        android:id="@+id/submit"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:background="@drawable/login_button"
        android:text="@string/submit_button"
        android:textColor="@android:color/white" />

</LinearLayout>


3
Насправді, той самий макет із використанням RelativeLayout відображається дуже добре. Однак я цього не пояснюю ...
Ден Чалтьєл,

Відповіді:


154

Це рішення я вирішив вирішити цю проблему:

@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {
    Dialog dialog = super.onCreateDialog(savedInstanceState);    
    dialog.getWindow().requestFeature(Window.FEATURE_NO_TITLE);

    return dialog;
}

@Override
public void onStart() {
    super.onStart();

    Dialog dialog = getDialog();
    if (dialog != null) {
       dialog.getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
       dialog.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
    }
}

Редагувати:

Ви можете використати наведений нижче код у onCrateViewметоді Fragment перед тим, як повернути завищений вигляд.

getDialog().getWindow().requestFeature(Window.FEATURE_NO_TITLE);
getDialog().getWindow().setBackgroundDrawable(new ColorDrawable(android.graphics.Color.TRANSPARENT));

3
Ви можете просто зателефонуватиdialog.getWindow().setBackgroundDrawable(null);
edwardaa

якщо для нього встановлено нуль, він не буде прозорим ... лише чорний, 4.0.4
Жоао Поло

17
Для мене це працює, якщо я вклав метод getDialog.getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);DialogFragment onResume(). Це не спрацювало на onCreateView()метод. Я трохи змінив відповідь від dialogдо getDialog().
Rock Lee

2
setLayoutв onStartметоді працює ідеально. Дякую.
wonsuc

78

Чи пробували ви використовувати відповідь Елвіса з розділу Як зробити так, щоб діалогове вікно сповіщення заповнювало 90% розміру екрана ?

Це наступне:

dialog.getWindow().setLayout(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);

Оновлення:

Вище код слід додати всередину onStart()методу DialogFragment.


4
Які LayoutParams ви імпортували?
ymerdrengene

1
@ymerdrengene Насправді дуже гарне запитання. Спробуйте WindowManager.LayoutParams.FILL_PARENT.
EpicPandaForce

2
@ymerdrengene, хоча технічно вони всі просто успадковують це значення ViewGroup.LayoutParams, тому воно в будь-якому випадку працює чудово.
EpicPandaForce

9
Цей код повинен бути в onStartметоді DialogFragment для роботи.
Eborbob,

1
Як уже згадувалося тут stackoverflow.com/a/15279400/1641882 я б запропонував перенести цей кодonCreateDialog
Ішан

52

Це спрацювало для мене

Створіть свій власний стиль:

   <style name="DialogStyle" parent="Base.Theme.AppCompat.Dialog">
    <item name="android:windowMinWidthMajor">97%</item>
    <item name="android:windowMinWidthMinor">97%</item>
   </style>

Ви також можете спробувати використовувати правильного батька, щоб відповідати вашим іншим діалоговим вікнам. наприклад parent="ThemeOverlay.AppCompat.Dialog"тощо.

Використовуйте цей стиль у своєму діалоговому вікні

public class MessageDialog extends DialogFragment {

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

// your code 
}

3
гарне рішення з <item name = "android: windowBackground"> ​​@ null </item>.
Євген Синицький

1
подбайте про те, щоб використовувати правильного батька, щоб відповідати вашим іншим діалоговим вікнам. у моєму випадку це був ThemeOverlay.AppCompat.Dialog
quealegriamasalegre

29

Для мене це спрацювало, коли я замінив батька LinearLayout макета, завищеного в onCreateView на RelativeLayout. Жодної іншої зміни коду не потрібно.


6
Типова, завжди найпопулярніша відповідь на переповнення стека вирішує мою проблему. Дякую
busuu

1
Ця відповідь мені дуже сподобалась, але чи не причина, чому вона працює лише для відносного розміщення?
Пратеек Гупта

19
    <!-- A blank view to force the layout to be full-width -->
    <View
        android:layout_width="wrap_content"
        android:layout_height="1dp"
        android:layout_gravity="fill_horizontal" />

у верхній частині мого діалогового макета зробив свою справу.


3
Це працює для мене, і мені подобається, що це не вимагає від нас додавати щось зайве в код, але мені цікаво, чому це працює ...
shela

Неймовірно, це єдине, що мені вдалося. Нестандартний стиль не зробив.
Magnus W

19
public class FullWidthDialogFragment extends AppCompatDialogFragment {
    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setStyle(DialogFragment.STYLE_NORMAL, R.style.Theme_AppCompat_Light_Dialog_Alert);
    }
}

а якщо ви хочете набагато більшої гнучкості, можете розширити AppCompat_Dialog_Alert та власні атрибути


12

На основі інших рішень я створив своє власне.

<style name="AppTheme.Dialog.Custom" parent="Theme.AppCompat.Light.Dialog.Alert">
    <item name="android:windowNoTitle">true</item>
    <item name="android:windowMinWidthMajor">100%</item>
    <item name="android:windowMinWidthMinor">100%</item>
</style>
abstract class BaseDialogFragment : DialogFragment() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setStyle(DialogFragment.STYLE_NO_TITLE, R.style.AppTheme_Dialog_Custom)
    }
}

11

У моєму випадку я також використовував такий підхід:

    @Override
    public void onStart() {
        super.onStart();
        getDialog().getWindow().setLayout(LayoutParams.MATCH_PARENT, (int) getResources().getDimension(R.dimen.dialog_height));
    }
}

Але все-таки були невеликі прогалини між лівим і правим краями діалогового вікна та краями екрану на деяких пристроях Lollipop + (наприклад, Nexus 9).

Це було не очевидно, але, нарешті, я зрозумів, що для того, щоб зробити його повною шириною на всіх пристроях і платформах, слід задавати фон вікна всередині styles.xml, як показано нижче:

<style name="Dialog.NoTitle" parent="Theme.AppCompat.Dialog">
    <item name="android:windowNoTitle">true</item>
    <item name="android:padding">0dp</item>
    <item name="android:windowBackground">@color/window_bg</item>
</style>

І звичайно, цей стиль потрібно використовувати, коли ми створюємо діалогове вікно, як показано нижче:

    public static DialogFragment createNoTitleDlg() {
        DialogFragment frag = new Some_Dialog_Frag();
        frag.setStyle(DialogFragment.STYLE_NO_TITLE, R.style.Dialog_NoTitle);
        return frag;
}

2
Це має бути прийнятою відповіддю! Врятував мені стільки часу! Фон вікна зробив свою справу.
Каран

10

Я хочу це пояснити. Обидва способи правильні, але з різними DialogFragment .

Використовуючи android.app.DialogFragment

@Override
public void onStart()
{
    super.onStart();
    Dialog dialog = getDialog();
    if (dialog != null)
    {
        int width = ViewGroup.LayoutParams.MATCH_PARENT;
        int height = ViewGroup.LayoutParams.MATCH_PARENT;
        dialog.getWindow().setLayout(width, height);
    }
}

Використовуючи android.support.v4.app.DialogFragment

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

В основному мені потрібна була повна ширина, і це спрацювало. Дякую!
sud007

4

Ще одне рішення, яке працює для мене без побічних ефектів:

У вашому класі, який розширює DialogFragment:

@Override
public void onCreate(final Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setStyle(DialogFragment.STYLE_NO_TITLE, R.style.DialogStyle);
}

У ваших стилях:

<style name="DialogStyle" parent="ThemeOverlay.AppCompat.Dialog.Alert"></style>

Ви можете безпосередньо використовувати тему оповіщення вsetStyle()
Sony

3

Це для мене чудово працює.

android:minWidth="300dp"

Через це ви можете надати ширину діалоговому вікні Фрагмент.


2

Користувач AlertDialog.Builder всередині вашого DialogFragment. Додайте йогоonCreateDialog спосіб. І onCreateViewнічого не робити.

public Dialog onCreateDialog(Bundle savedInstanceState)
{

    AlertDialog.Builder builder = new AlertDialog.Builder(getContext());
    View view = LayoutInflater.from(getContext()).inflate(R.layout.gf_confirm_order_timeout_dialog, null);
    final Bundle args = getArguments();
    String message = args.getString(GfConstant.EXTRA_DATA);
    TextView txtMessage = (TextView) view.findViewById(R.id.txt_message);
    txtMessage.setText(message);

    view.findViewById(R.id.btn_confirm).setOnClickListener(new View.OnClickListener()
    {
        @Override
        public void onClick(View v)
        {
            if (mListener != null)
            {
                mListener.onDialogConfirmOK();
            }
        }
    });
    builder.setView(view);
    Dialog dialog = builder.create();
    dialog.setCanceledOnTouchOutside(false);
    dialog.getWindow().requestFeature(Window.FEATURE_NO_TITLE);
    return dialog;
}

2

Створіть власний стиль у файлі style.xml. Просто скопіюйте цей код у свій файл style.xml

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

Потім у методі createDialog вашого DialogFragment створіть діалоговий об’єкт за кодом

 dialog = new Dialog(getActivity(), R.style.CustomDialog);

Це працює на мене і сподіваюся, це допоможе і вам


Мені довелося додати до стилю наступне, щоб він працював для мене: <item name = "android: windowMinWidthMajor"> 100% </item> <item name = "android: windowMinWidthMinor"> 100% </item>
Arnout

2

Ось як я вирішив, коли зіткнувся з цією проблемою. Спробуйте це.

у onActivityCreated у вашому DialogFragment додайте цей код відповідно до ваших потреб ....

 @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        myview=inflater.inflate(R.layout.fragment_insurance_detail, container, false);
        intitviews();
        return myview;
    }
    @Override
    public void onActivityCreated(Bundle arg0) {
        super.onActivityCreated(arg0);
        getDialog().getWindow().getAttributes().windowAnimations = R.style.DialogAnimation;
        getDialog().getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
        getDialog().getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        getDialog().getWindow().setGravity(Gravity.CENTER);
    }

1

використовуйте це в методі onCreateView DialogFragment

    Display display = getActivity().getWindowManager().getDefaultDisplay();
    int width = display.getWidth();
    int px = (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, **220**, getResources().getDisplayMetrics());
    getDialog().getWindow().setLayout(width,px);

220 - висота фрагмента діалогового вікна, змініть його, як вам заманеться


1

у вашому корінці макета встановіть для android: minWidth дуже велике значення, наприклад

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:minWidth="9999999dp">

   ...

</LinearLayout>

0

Я спробував кілька перелічених вище відповідей; вони не працювали на мене. Це рішення мого питання:

В DialogFragment(), додати коди нижче:

override fun onResume() {
    super.onResume()
    if (showsDialog) {
        val width = ViewGroup.LayoutParams.MATCH_PARENT
        val height = ViewGroup.LayoutParams.WRAP_CONTENT
        dialog?.window?.apply {
            setBackgroundDrawable(ColorDrawable(Color.WHITE))
            attributes.gravity = Gravity.BOTTOM
            setLayout(width, height)
        }
    }
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.