Материал Дизайн не стилизация диалоговых окон предупреждений


161

Я добавил дизайн приложения appCompat в свое приложение, и похоже, что в диалоговых окнах предупреждений не используются мои основной цвет, основной цвет или акцентные цвета.

Вот мой базовый стиль:

<style name="MaterialNavyTheme" parent="@style/Theme.AppCompat.Light.DarkActionBar">
    <item name="colorPrimary">@color/apptheme_color</item>
    <item name="colorPrimaryDark">@color/apptheme_color_dark</item>
    <item name="colorAccent">@color/apptheme_color</item>
    <item name="android:textColorPrimary">@color/action_bar_gray</item>
</style>

Исходя из моего понимания, диалоги текста кнопки также должны использовать эти цвета. Я ошибаюсь в своем понимании или мне нужно что-то еще сделать?


Решение:

Отмеченный ответ поставил меня на правильный путь.

<style name="MaterialNavyTheme" parent="@style/Theme.AppCompat.Light.DarkActionBar">
    <item name="colorPrimary">@color/apptheme_color</item>
    <item name="colorPrimaryDark">@color/apptheme_color_dark</item>
    <item name="colorAccent">@color/apptheme_color</item>
    <item name="android:actionModeBackground">@color/apptheme_color_dark</item>
    <item name="android:textColorPrimary">@color/action_bar_gray</item>
    <item name="sdlDialogStyle">@style/DialogStyleLight</item>
    <item name="android:seekBarStyle">@style/SeekBarNavyTheme</item>
</style>

<style name="StyledDialog" parent="Theme.AppCompat.Light.Dialog">
    <item name="colorPrimary">@color/apptheme_color</item>
    <item name="colorPrimaryDark">@color/apptheme_color_dark</item>
    <item name="colorAccent">@color/apptheme_color</item>
</style>

Вы можете попробовать эту библиотеку, которую я сделал: github.com/AndroidDeveloperLB/MaterialStuffLibrary
разработчик Android

15
Должна ли нижняя часть быть решением? Если это так, опубликовать его в качестве самостоятельного ответа , не редактируйте ответ на вопрос.
Ади Инбар

Ответы:


463

ОБНОВЛЕНО авг 2019 г. с компонентами Material для библиотеки Android:

С новыми компонентами Material для библиотеки Android вы можете использовать новый com.google.android.material.dialog.MaterialAlertDialogBuilderкласс, который выходит за пределы существующего androidx.appcompat.AlertDialog.Builderкласса и обеспечивает поддержку последних спецификаций Material Design.

Просто используйте что-то вроде этого:

new MaterialAlertDialogBuilder(context)
            .setTitle("Dialog")
            .setMessage("Lorem ipsum dolor ....")
            .setPositiveButton("Ok", /* listener = */ null)
            .setNegativeButton("Cancel", /* listener = */ null)
            .show();

Вы можете настроить цвета, расширяющие ThemeOverlay.MaterialComponents.MaterialAlertDialogстиль:

  <style name="CustomMaterialDialog" parent="@style/ThemeOverlay.MaterialComponents.MaterialAlertDialog">
     <!-- Background Color-->
     <item name="android:background">#006db3</item>
     <!-- Text Color for title and message -->
     <item name="colorOnSurface">@color/secondaryColor</item>
     <!-- Text Color for buttons -->
     <item name="colorPrimary">@color/white</item> 
     ....
  </style>  

Чтобы применить свой собственный стиль, просто используйте конструктор:

new MaterialAlertDialogBuilder(context, R.style.CustomMaterialDialog)

введите описание изображения здесь

Чтобы настроить кнопки, заголовок и основной текст, проверьте этот пост для более подробной информации.

Вы также можете глобально изменить стиль в теме своего приложения:

 <!-- Base application theme. -->
 <style name="AppTheme" parent="Theme.MaterialComponents.Light">
    ...
    <item name="materialAlertDialogTheme">@style/CustomMaterialDialog</item>
 </style>

С БИБЛИОТЕКОЙ ПОДДЕРЖКИ и ТЕМЫ APPCOMPAT:

С новым AppCompat v22.1вы можете использовать новый android.support.v7.app.AlertDialog .

Просто используйте такой код:

import android.support.v7.app.AlertDialog

AlertDialog.Builder builder =
       new AlertDialog.Builder(this, R.style.AppCompatAlertDialogStyle);
builder.setTitle("Dialog");
builder.setMessage("Lorem ipsum dolor ....");
builder.setPositiveButton("OK", null);
builder.setNegativeButton("Cancel", null);
builder.show();

И используйте такой стиль:

<style name="AppCompatAlertDialogStyle" parent="Theme.AppCompat.Light.Dialog.Alert">
        <item name="colorAccent">#FFCC00</item>
        <item name="android:textColorPrimary">#FFFFFF</item>
        <item name="android:background">#5fa3d0</item>
    </style>

В противном случае вы можете определить в вашей текущей теме:

<style name="AppTheme" parent="Theme.AppCompat.Light">
    <!-- your style -->
    <item name="alertDialogTheme">@style/AppCompatAlertDialogStyle</item>
</style>

а затем в вашем коде:

 import android.support.v7.app.AlertDialog

    AlertDialog.Builder builder =
           new AlertDialog.Builder(this);

Вот AlertDialog на Киткат: введите описание изображения здесь


2
Зачем заставлять AlertDialog.Builder использовать точную тему вместо обновления по умолчанию? Я бы предпочел решить эту проблему в файле styles.xml вместо кода Java.
Томаш Губалек

2
Шрифты Title и Buttons не выделяются жирным шрифтом на устройствах перед леденцом на палочке.
jimmy0251

9
Мне пришлось добавить «android:», чтобы заставить его работать:<item name="android:alertDialogTheme">@style/AppCompatAlertDialogStyle</item>

1
+1 за превосходный ответ, но Как я могу добиться того же интерфейса для Android версии ниже Lollypop ... потому что с этим в нижеприведенном интерфейсе устройства выглядит так странно.
realpranav

1
добавить импорт android.support.v7.app.AlertDialog работает
FlipNovid

9

при инициализации диалогового редактора передайте второй параметр в качестве темы. Он автоматически покажет дизайн материала с уровнем API 21.

AlertDialog.Builder builder = new AlertDialog.Builder(this, AlertDialog.THEME_DEVICE_DEFAULT_DARK);

или,

AlertDialog.Builder builder = new AlertDialog.Builder(this, AlertDialog.THEME_DEVICE_DEFAULT_LIGHT);

4

AppCompat не делает этого для диалогов (пока, по крайней мере)

РЕДАКТИРОВАТЬ: это делает сейчас. убедитесь, что используетеandroid.support.v7.app.AlertDialog


Похоже, вы можете внести некоторые изменения в стили диалогов с помощью AppCompat
Matthew

моя Android Studio по умолчанию дала мне import app.AlertDialogне appCompat. Я пытался выяснить, что не так в течение примерно 40 минут, прежде чем я на самом деле проверил это ... Черт возьми, Google!
Глорифинд

2

Вы можете рассмотреть этот проект: https://github.com/fengdai/AlertDialogPro

Он может предоставить вам диалоговые окна с сообщениями о теме материала, почти такие же, как у леденцов. Совместим с Android 2.1.


Просто примечание: этот ответ старше, чем принятый.
rekire

2

Вы могли бы использовать

Библиотека дизайна материалов

Material Design Library сделана для довольно диалогов , кнопок и других вещей, таких как закусочные. В настоящее время это сильно развито.

Руководство, код, пример - https://github.com/navasmdc/MaterialDesignLibrary

Руководство по добавлению библиотеки в Android Studio 1.0 - Как импортировать библиотеку материалов в Android Studio?

,

Удачного кодирования;)


1

Попробуйте эту библиотеку:

https://github.com/avast/android-styled-dialogs

Это основано на DialogFragmentsвместо AlertDialogs(как тот из @afollestad). Основное преимущество: диалоги не исчезают после поворота, а обратные вызовы по-прежнему работают.


Моя библиотека гораздо более способна. И вы всегда можете обернуть диалог с DialogFragment. Af
Афоллестад

1

По какой-то причине кажется, что android: textColor обновляет цвет заголовка. Вы можете изменить цвет текста сообщения, используя

SpannableString.AlertDialog.Builder builder = new AlertDialog.Builder(new ContextThemeWrapper(this, R.style.MyDialogTheme));

AlertDialog dialog = builder.create();
                Spannable wordtoSpan = new SpannableString("I know just how to whisper, And I know just how to cry,I know just where to find the answers");
                wordtoSpan.setSpan(new ForegroundColorSpan(Color.BLUE), 15, 30, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
                dialog.setMessage(wordtoSpan);
                dialog.show();

0

Диалоговые окна предупреждений о дизайне материала: пользовательский шрифт, кнопка, цвет и форма, ..

 MaterialAlertDialogBuilder(requireContext(),
                R.style.MyAlertDialogTheme
            )
                .setIcon(R.drawable.ic_dialogs_24px)
                .setTitle("Feedback")
                //.setView(R.layout.edit_text)
                .setMessage("Do you have any additional comments?")
                .setPositiveButton("Send") { dialog, _ ->

                    val input =
                        (dialog as AlertDialog).findViewById<TextView>(
                            android.R.id.text1
                        )
                    Toast.makeText(context, input!!.text, Toast.LENGTH_LONG).show()

                }
                .setNegativeButton("Cancel") { _, _ ->
                    Toast.makeText(requireContext(), "Clicked cancel", Toast.LENGTH_SHORT).show()
                }
                .show()

Стиль:

  <style name="MyAlertDialogTheme" parent="Theme.MaterialComponents.DayNight.Dialog.Alert">
  
        <item name="android:textAppearanceSmall">@style/MyTextAppearance</item>
        <item name="android:textAppearanceMedium">@style/MyTextAppearance</item>
        <item name="android:textAppearanceLarge">@style/MyTextAppearance</item>

        <item name="buttonBarPositiveButtonStyle">@style/Alert.Button.Positive</item>
        <item name="buttonBarNegativeButtonStyle">@style/Alert.Button.Neutral</item>
        <item name="buttonBarNeutralButtonStyle">@style/Alert.Button.Neutral</item>

        <item name="android:backgroundDimEnabled">true</item>

        <item name="shapeAppearanceOverlay">@style/ShapeAppearanceOverlay.MyApp.Dialog.Rounded
        </item>

    </style>




    <style name="MyTextAppearance" parent="TextAppearance.AppCompat">
        <item name="android:fontFamily">@font/rosarivo</item>
    </style>


        <style name="Alert.Button.Positive" parent="Widget.MaterialComponents.Button.TextButton">
   <!--     <item name="backgroundTint">@color/colorPrimaryDark</item>-->
        <item name="backgroundTint">@android:color/transparent</item>
        <item name="rippleColor">@color/colorAccent</item>
        <item name="android:textColor">@color/colorPrimary</item>
       <!-- <item name="android:textColor">@android:color/white</item>-->
        <item name="android:textSize">14sp</item>
        <item name="android:textAllCaps">false</item>
    </style>


    <style name="Alert.Button.Neutral" parent="Widget.MaterialComponents.Button.TextButton">
        <item name="backgroundTint">@android:color/transparent</item>
        <item name="rippleColor">@color/colorAccent</item>
        <item name="android:textColor">@color/colorPrimary</item>
        <!--<item name="android:textColor">@android:color/darker_gray</item>-->
        <item name="android:textSize">14sp</item>
        <item name="android:textAllCaps">false</item>
    </style>


  <style name="ShapeAppearanceOverlay.MyApp.Dialog.Rounded" parent="">
        <item name="cornerFamily">rounded</item>
        <item name="cornerSize">8dp</item>
    </style>

Вывод: введите описание изображения здесь

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.