Android alertdialog title color

Как я могу изменить цвет заголовка AlertDialog и цвет строки под ним

Я изменил цвет заголовка AlertDialog с помощью этой команды

но я хочу изменить цвет строки, которая появляется под заголовком; Как я могу это сделать ?

примечание: Я не хочу использовать пользовательский макет

14 ответов:

к сожалению, это не особо простая задача. в моем ответе здесь, я подробно как настроить цвет ListSeparator просто проверяя родительский стиль, используемый Android, создавая новое изображение и создавая новый стиль на основе оригинала. К сожалению, в отличие от ListSeparator ‘s стиль, AlertDialog темы являются внутренними, и поэтому на них нельзя ссылаться как на родительские стили. Нет простого способа изменить эту маленькую синюю линию! Таким образом, вам нужно прибегнуть к создание пользовательских диалогов.

если это просто не ваша чашка чая. не сдавайся! Я был очень обеспокоен тем, что не было простого способа сделать это, поэтому я создал небольшой проект на github для быстрого создания диалогов в стиле holo (при условии, что телефон поддерживает стиль Holo). вы можете найти проект здесь:https://github.com/danoz73/QustomDialog

он должен легко позволить перейти от скучного синего к захватывающему оранжевый!

проект в основном является примером использования пользовательского диалогового окна builder, и в этом примере я создал пользовательское представление, которое, казалось, удовлетворяло примеру IP-адреса, который вы даете в своем исходном вопросе.

С QustomDialog , чтобы создать основной диалог (заголовок, сообщение) с желаемым другим цветом для заголовка или разделителя, вы используете следующий код:

и для того, чтобы добавить пользовательский макет (скажем, чтобы добавить маленький IP-адрес EditText ), добавить

к построителю с макетом, который вы разработали (пример IP можно найти в github). Надеюсь, это поможет. большое спасибо Джозефу Эрлу и его ответ тут.

это хак немного, но он отлично работает для меня, и он работает без какой-либо внешней библиотеки (по крайней мере, на Android 4.4).

обновление: цвет заголовка

взломать для изменения цвета заголовка:

вы получаете подробную информацию по следующей ссылке.

это установит цвет для заголовка, значка и разделителя. Должно измениться с новой версией Android.

Не забудьте вызвать диалоговое окно.показать() перед вызовом этого метода.

, следуя Диалог исходный код, я обнаружил, что название генерируется в классе MidWindow путем накачивания dialog_title_holo.xml макет. так что идентификатор mTitleView — это title и идентификатор разделитель titleDivider .

мы можем получить доступ к идентификатор title просто android.R.id.title .

и доступ к Id titleDivider by Resources.getSystem().getIdentifier(«titleDivider»,»id», «android»);

окончательный код, который я использовал для изменения направления заголовка и изменения цвета это:

Если вы не хотите «библиотека», для этого, вы можете использовать это плохо рубить:

Это было проверено и работает на 4.x; не проверено, но если моя память хорошая, она должна работать для 2.x и 3.x

Если вы создаете пользовательский макет для диалогового окна оповещения

тогда вы можете добавить, как этот способ легко изменить цвет

Если вы используете пользовательский макет заголовка затем вы можете использовать его как alertDialog.setCustomTitle (customTitle);

продолжая от этого ответа:https://stackoverflow.com/a/15285514/1865860, я разветвил хороший РЕПО github от @daniel-smith и сделал некоторые улучшения:

  • улучшен пример активности
  • улучшено отображение
  • основные setItems метод
  • добавлены разделители на items_list
  • закрыть диалоги по щелчку
  • поддержка отключенных элементов в setItems методы
  • listItem сенсорный обратная связь
  • прокручиваемое диалоговое сообщение

Я придумал другое решение, которое обрабатывает стиль ваших диалогов в одном месте, и вам не нужно беспокоиться о том, когда вы его применяете — dialog show/not shown, что может вызвать ошибку (следует вызвать requestFocus или что-то в этом роде ;P).

в классе onCreateView, я поставил это:

colorPrimary ссылки на наши цвета.xml-файл, в котором хранятся все цвета. Также d.setTitle обеспечивает хакерский способ установить цвет заголовка.

Читайте также:  Как устанавливать eclipse android

вместо использования разделителя в диалоговом окне используйте представление в пользовательском макете и установите макет в качестве пользовательского макета в диалоговом окне.

в случае, если вы используете расширение диалогового окна использование:

Источник

Material Design — Custom Alert Dialog

Jun 19, 2019 · 2 min read

Prerequisites

Make sure your AppTheme inherited from a material theme like:

Then you can then customize the style of the title, body, button, or other elements by overriding the corresponding item in the alert dialog theme.

For example, customize the text color and font size of the title by creating a materialAlertDialogTitleTextStyle that inherited from MaterialAlertDialog.MaterialComponents.Title.Text :

Examples

Example 1:

Change the background color and define the style for title text, body text, positive and negative button:

To apply th e custom theme to the dialog you need to use the MaterialAlertDialogBuilder and pass the theme id to it:

If you want to let every dialog use the same theme, then override the materialAlertDialogTheme attribute it in your AppTheme :

Now the context will provide custom dialog theme instead of the default one. You can initialize the dialog builder without the theme parameter:

Example 2:

Let the title and icon center and set different colors to title pane and button bar:

Conclusion

MaterialAlertDialog provides a beautiful base style and you can easily customize the style with writing some XML.

Источник

Material Design — Custom Alert Dialog

Jun 19, 2019 · 2 min read

Prerequisites

Make sure your AppTheme inherited from a material theme like:

Then you can then customize the style of the title, body, button, or other elements by overriding the corresponding item in the alert dialog theme.

For example, customize the text color and font size of the title by creating a materialAlertDialogTitleTextStyle that inherited from MaterialAlertDialog.MaterialComponents.Title.Text :

Examples

Example 1:

Change the background color and define the style for title text, body text, positive and negative button:

To apply th e custom theme to the dialog you need to use the MaterialAlertDialogBuilder and pass the theme id to it:

If you want to let every dialog use the same theme, then override the materialAlertDialogTheme attribute it in your AppTheme :

Now the context will provide custom dialog theme instead of the default one. You can initialize the dialog builder without the theme parameter:

Example 2:

Let the title and icon center and set different colors to title pane and button bar:

Conclusion

MaterialAlertDialog provides a beautiful base style and you can easily customize the style with writing some XML.

Источник

Диалоговые окна

В Android 3.0 (API 11) появилась новинка — класс android.app.DialogFragment и его аналог android.support.v4.app.DialogFragment, а чуть позже и android.support.v7.app.AppCompatDialogFragment из библиотеки совместимости, позволяющие выводить диалоговое окно поверх своей активности. Раньше использовался класс Dialog и его производные, например, AlertDialog. Они никуда не делись, только теперь их нужно встраивать в фрагмент, который выступает в качестве контейнера. Поэтому условно разговор о диалоговых окнах можно разбить на две части — как использовать DialogFragment и как пользоваться классами Dialog, AlertDialog и другими диалоговыми окнами. После появления AndroidX имена пакетов очередной раз изменились, теперь следует импортировать androidx.fragment.app.DialogFragment, androidx.appcompat.app.AlertDialog и другие аналогичные классы.

Использование фрагментов для диалоговых окон в силу своей архитектуры является удобным вариантом в приложениях, который лучше справляется с поворотами устройства, нажатием кнопки Назад, лучше подходит под разные экраны и т.д.

Для создания диалога следует наследоваться от класса DialogFragment. Создадим новый класс MyDialogFragment:

Допустим у нас есть кнопка на экране активности. Вызвать диалоговое окно можно через метод show().

Скорее всего вы увидите пустой прямоугольник или квадрат. А возможно у вас просто потемнеет экран активности.

Читайте также:  Leeco cool 1 обновление до android 7

Так как это обычный фрагмент, то нам нужно позвать менеджера фрагментов и попросить его показать фрагмент.

Для вызова диалога мы создаём экземпляр класса MyDialogFragment и вызываем метод show(). Метод принимает два параметра: объект класса FragmentManager, получаемый через метод getSupportFragmentManager(), и тег — идентификатор диалога в виде строковой константы, по которому можно идентифицировать диалоговое окно, если их будет много в нашем проекте.

Существует и альтернативный вариант показа окна через транзакцию.

Мы получили пустой бесполезный фрагмент. Следует заняться его конструированием. В созданном классе нужно переопределить метод onCreateDialog(). Если используется разметка, то также используется метод onCreateView(), как и у обычных фрагментов. Скорее всего вы не будете заново изобретать велосипед, а будете использовать готовые варианты диалоговых окон.

AlertDialog

Самый распространённый вариант диалогового окна — это AlertDialog. С него и начнём.

Диалоговое окно AlertDialog является расширением класса Dialog, и это наиболее используемое диалоговое окно в практике программиста. Очень часто требуется показать диалог с кнопками Да и Нет, а также Мур и Мяу . В создаваемых диалоговых окнах можно задавать следующие элементы:

  • заголовок
  • текстовое сообщение
  • кнопки: от одной до трёх
  • список
  • флажки
  • переключатели

AlertDialog с одной кнопкой

Начнём с простого примера — покажем на экране диалоговое окно с одной кнопкой.

В класс фрагмента добавляем метод.

Внешний вид от версии к версии может меняться. В частности, недавно поменяли цвет текста для кнопки.

Сначала мы создаём объект класса AlertDialog.Builder, передав в качестве параметра ссылку на активность. Затем, используя методы класса Builder, задаём для создаваемого диалога заголовок (метод setTitle()), текстовое сообщение в теле диалога (метод setMessage()), значок (метод setIcon()), а также кнопку через метод под странным названием setPositiveButton().

Сама обработка нажатия кнопки внутри диалогового окна задаётся внутри метода setPositiveButton(). В нашем случае мы просто закрываем окно диалога через метод cancel().

Обратите внимание на не совсем обычный способ вызова череды методов цепочкой через точку .setMessage(«Покормите кота!»).setIcon(R.drawable.ic_android_cat) и т.д. Такой синтаксис можно часто увидеть в jQuery. При таком способе не нужно использовать точку с запятой в конце каждого метода, вы просто склеиваете все вызовы. Но можете использовать и обычный синтаксис.

Если вы используете Java 8, то студия предложит использовать лямбда-выражение вместо анонимного класса. Решайте сами, в каком стиле писать код.

Заголовок. Метод setTitle()

Немного остановимся на заголовке. Старайтесь использовать небольшие сообщения. Если сообщение будет средней длины, то оно может разместиться на двух строках. Если сообщение будет слишком длинным, то оно обрежется.

А если очень хочется вывести длинную строку в заголовке? Тогда вместо setTitle() можно вызвать setCustomTitle() и передать ему View, в нашем случае это будет TextView.

При этом перестал выводиться значок. Обидно.

Нелёгкий выбор — пример с двумя кнопками

Теперь рассмотрим пример создания диалогового окна с двумя кнопками на основе иллюстрации.

Внешний вид диалоговых окон в разных версиях Android.

Общая часть кода осталась прежней — объект класса AlertDialog.Builder, методы для настройки окна, а также кнопки диалога и обработку событий на них. В AlertDialog можно добавить только по одной кнопке каждого типа: Positive, Neutral и Negative, т. е. максимально возможное количество кнопок в диалоге — три. На названия кнопок не обращайте внимания, они не несут смысловой нагрузки, а только определяют порядок вывода. Причём в разных версиях Android порядок менялся. Поэтому на старых устройствах кнопка «Да» может быть первой, а на новых — последней. Для каждой кнопки используется один из методов с префиксом set. Button, которые принимают в качестве параметров надпись для кнопки и интерфейс DialogInterface.OnClickListener, определяющий действие при нажатии. Чтобы пользователь не мог закрыть диалог нажатием в любой точке экрана, вызывается метод setCancelable() с значением true.

Три кнопки

Рассмотрим пример с тремя кнопками. Разницы практически нет. Повторяем все предыдущие шаги, для отображения диалогового окна вызывается метод builder.create(). Например, для создания диалога с кнопками Мяу, Гав, Сам дурак! код будет выглядеть приблизительно так:

Читайте также:  Как собрать свое кастомную прошивку андроид

AlertDialog со списком

Если вам нужно диалоговое окно со списком выбираемых пунктов вместо кнопок, то используйте метод setItems(), где нужно указать массив данных для отображения в списке диалога. Данный метод нельзя использовать вместе с методом setMessage(), так они выводят содержимое в основной части окна.

Выбранный элемент содержится в параметре which. При выборе одного из пунктов меню появится всплывающее уведомление, показывающее выбранного кота.

Напоминаю, что внешний вид окна менялся от версии к версии.

AlertDialog с переключателями

Для создания диалогового окна с переключателями применяется метод setSingleChoiceitems() вместо метода setItems().

Обратите внимание на следующие детали. При выборе переключателя диалоговое окно закрываться не будет. Поэтому необходимо предусмотреть механизм закрытия окна, например, добавить кнопку. Второй момент — в методе setSingleChoiceitems для первого параметра используется массив значений для переключателей, а для второго параметра используется целочисленное значение индекса переключателя, который будет включён по умолчанию при вызове диалогового окна. Если вы хотите, чтобы все переключатели при запуске были в выключенном состоянии, то используйте значение -1.

AlertDialog с флажками

Если вы хотите использовать вместо переключателей флажки (CheckBox) для множественного выбора, то вам нужен метод setMultiChoiceItems(). Код практически идентичен предыдущему примеру:

Первый параметр в методе setMultiChoiceItems() — массив значений для списка с флажками, второй параметр — булевый массив состояний флажков списка по умолчанию при вызове диалога. Например, мы хотим, чтобы второй элемент списка был отмечен флажком, а остальные элементы нужно оставить неотмеченными. В этом случае используем массив из булевых значений:

Как и в предыдущем случае с переключателями, для диалогового окна с флажками необходимо использовать кнопки для закрытия окна.

Автоматическое закрытие окна

В отличие от сообщения Toast, которое закрывается через одну-две секунды, диалоговые окна сами не закрываются, а ждут реакции пользователя. Но если мы воспользуемся таймером, то сможем обойти это ограничение.

Добавим в проект кнопку для вызова самозакрывающего диалогового окна и напишем код для обработчика щелчка кнопки (старый пример без использования фрагмента):

AlertDialog с рейтингом (проблемный пример)

Однажды я повстречал в сети пример включения компонента RatingBar в диалог. При тестировании обнаружил, что код работает не совсем корректно. На экран всегда выводятся шесть звёздочек, несмотря на установленные настройки. А если развернуть приложение в альбомный режим, то выводятся и семь звёздочек и больше, в зависимости от размеров экрана. Оставил пример на память, если кто-то разберётся в чём тут была проблема, то дайте знать. Это тоже старый пример без использования фрагмента.

Решение проблемы

Читатели предложили несколько вариантов решения проблемы. Как следует из документации, компонент RatingBar следует размещать в макете, который имеет свойство wrap_content. Поступим следующим образом. Создадим отдельную разметку с RatingBar, которую присоединим к диалоговому окну. Итак, разметка:

res/layout/ratingdialog.xml

Теперь модифицированный код:

Обратите внимание, что для доступа к свойствам RatingBar, мы вызываем метод View.findViewById(), а не Activity.findViewById(), как обычно мы привыкли делать в методе onCreate(), когда опускаем название класса.

Передать данные в активность

Для обработки щелчков кнопок в диалоговом окне вы пишете код, в котором указываете родительскую активность.

В коде каких-то сложностей нет — устанавливаем заголовок, значок, кнопки. При построении диалогового окна указываем родительскую активность и название методов в ней, которые будут отвечать за обработку нажатий кнопок диалога — в нашем случае это методы okClicked() и cancelClicked(). Кстати, имена методов будут подчёркнуты красной линией и среда разработки предложит создать данные методы в классе активности (используйте комбинацию клавиш Alt+Enter).

Возвращаемся в код главной активности и пропишем код для нажатий кнопок диалогового окна:

Пример был написан по принципу — «работает и ладно». На самом деле пример не совсем грамотный, хотя даже в документации он ещё встречается.

Правильный вариант рассматривается во второй части о диалоговых окнах DialogFragment.

AlertDialog с собственной разметкой

Если стандартный вид AlertDialog вас не устраивает, то можете придумать свою разметку и подключить её через метод setView()

Вы познакомились с базовыми принципами использования диалоговых окон.

Источник

Оцените статью