Android AppCompat AlertDialog样式与主题

时间:2017-07-31 05:34:56

标签: android android-appcompat android-theme android-styles

我希望能够在AppCompat AlertDialog中设置主题以设置消息文本大小。主题需要parent="@style/Theme.AppCompat.Dialog"。我花了几个小时搜索并尝试了所有的建议,但它们似乎都没有使用那个基本主题。

如果父级更改为Holo主题,那么我可以使用textAppearanceMedium更改消息文本大小,但对话框的其余部分看起来非常难看:S

目前我的主题是(所有这些目前已经连接并正常工作):

<?xml version="1.0" encoding="utf-8"?>
<resources>
  <style name="MyDialogTheme" parent="@style/Theme.AppCompat.Dialog">
    <!-- Used for the buttons -->
    <item name="colorAccent">@color/colorPrimary</item>
    <!-- Button text size -->
    <item name="android:textSize">@dimen/ui_text_size</item>
    <!-- Content text color -->
    <item name="android:textColorPrimary">@color/ui_text_color</item>
    <!-- Title style -->
    <item name="android:windowTitleStyle">@style/MyDialogTitleStyle</item>
    <!-- Button style (except size) -->
    <item name="android:textAppearanceButton">@style/MyDialogButtonTextAppearance</item>
    <!-- Dialog background -->
    <item name="android:windowBackground">@color/ui_background</item>
  </style>

  <style name="MyDialogTitleStyle" parent="@style/RtlOverlay.DialogWindowTitle.AppCompat">
    <item name="android:textAppearance">@style/MyDialogTitleTextAppearance</item>
    <item name="android:textSize">@dimen/ui_large_text_size</item>
  </style>

  <style name="MyDialogTitleTextAppearance">
    <item name="android:textSize">@dimen/ui_large_text_size</item>
    <item name="android:textAllCaps">true</item>
    <item name="android:textColor">@color/ui_title_color</item>
  </style>

  <style name="MyDialogButtonTextAppearance">
    <item name="android:fontFamily">sans-serif-light</item>
    <item name="android:textAllCaps">true</item>
  </style>
</resources>

1 个答案:

答案 0 :(得分:5)

似乎没有办法通过主题属性。我们来看看appcompat-v7 library的源代码。在TextView之后反映了AlertDialog

的消息
<android.support.v7.widget.AlertDialogLayout ... >

    <!-- ... -->

                <TextView
                    android:id="@android:id/message"
                    style="@style/TextAppearance.AppCompat.Subhead"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:paddingLeft="?attr/dialogPreferredPadding"
                    android:paddingRight="?attr/dialogPreferredPadding"/>

    <!-- ... -->

</android.support.v7.widget.AlertDialogLayout>

正如您所看到的,TextView使用TextAppearance.AppCompat.Subhead作为样式。遵循其定义:

<style name="TextAppearance.AppCompat.Subhead" parent="Base.TextAppearance.AppCompat.Subhead"/>
<style name="Base.TextAppearance.AppCompat.Subhead">
    <item name="android:textSize">@dimen/abc_text_size_subhead_material</item>
    <item name="android:textColor">?android:textColorPrimary</item>
</style>

textSize是静态的,不会通过textColor(使用textColorPrimary)等属性解析。因此,我们没有选择设置textSize。唯一的方法是通过将TextAppearance.AppCompat.Subhead样式添加到您自己的styles.xml文件中来覆盖textSize样式,并将TextAppearance.AppCompat.Subhead设置为您需要的任何值。但请注意,可能存在副作用,因为此样式也可用于其他地方。

TL;博士

选项:

  1. 在styles.xml文件中定义textSize并覆盖TextView属性。
  2. 以编程方式(通过id和#setTextSize查找<a href="https://somelink.com" target="_blank"> SOMENAME <i class="fa fa-chevron-right"></i> </a>
  3. 在对话框中使用您自己的布局 - appcompat-v7的源代码可能是一个很好的起点。