更改 MaterialButtonToggleGroup 的背景颜色

Posted

技术标签:

【中文标题】更改 MaterialButtonToggleGroup 的背景颜色【英文标题】:Change the background color of MaterialButtonToggleGroup 【发布时间】:2021-05-05 10:16:01 【问题描述】:

我正在使用 MaterialButtonToggleGroup 创建选择器按钮。 我想更改 MaterialButton 按钮的背景颜色。它的默认颜色是浅蓝色,我想把它改成浅绿色。目前,我正在使用可绘制扇区来更改背景颜色,但它不起作用。

默认颜色

想要这个颜色,

这是我的布局,

<com.google.android.material.button.MaterialButtonToggleGroup
    android:id="@+id/toggleContent"
    android:layout_
    android:layout_
    app:checkedButton="@id/btnOutline"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintLeft_toLeftOf="parent"
    android:visibility="visible"
    app:layout_constraintRight_toRightOf="parent"
    app:singleSelection="true">

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnOutline"
        style="@style/Widget.MaterialComponents.Button.OutlinedButton"
        android:layout_
        android:layout_
        android:background="@drawable/button_selector"
        android:text="@string/outline"
        android:textAllCaps="false" />

    <com.google.android.material.button.MaterialButton
        android:id="@+id/btnMain"
        style="@style/Widget.MaterialComponents.Button.OutlinedButton"
        android:background="@drawable/button_selector"
        android:layout_
        android:layout_
        android:text="@string/main"
        android:textAllCaps="false" />

</com.google.android.material.button.MaterialButtonToggleGroup>

这是我的可绘制文件“button_selector”,

    <?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_selected="true" android:drawable="@drawable/selector_color"/>

</selector>

这里是“selector_color”文件,

  <?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">

    <solid android:color="#93cdcb"/>
</shape>

【问题讨论】:

【参考方案1】:

对于材质按钮,您应该使用 app:backgroundTint 而不是 android:background Android 文档在这里也提到了它: https://developer.android.com/reference/com/google/android/material/button/MaterialButton

不要使用 android:background 属性。 MaterialButton 管理 它自己的背景可绘制,并设置一个新的背景意味着 MaterialButton 不能再保证它的新属性 引入将正常运行

对于填充按钮,此类使用您的主题的 ?attr/colorPrimary 用于背景色调颜色和 ?attr/colorOnPrimary 用于文本 颜色。对于未填充的按钮,此类使用 ?attr/colorPrimary 背景色调的文本颜色和透明度。

【讨论】:

【参考方案2】:

您可以尝试在“android:backgroundTint”属性上设置选择器,而不是将其设置为“android:background”。如果您想更新边框颜色,请考虑更新和 'app:strokeColor'

【讨论】:

【参考方案3】:

MaterialButton 的背景颜色由 backgroundTint 属性定义。

默认值为:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
  <item android:color="?attr/colorPrimary" android:state_enabled="true"/>
  <item android:alpha="0.12" android:color="?attr/colorOnSurface"/>
</selector>

您可以在xml布局中更改它,也可以定义自定义样式:

<com.google.android.material.button.MaterialButton
           style="@style/ButtonStyle"
           .. />

与:

<style name="ButtonStyle" parent="Widget.MaterialComponents.Button">
    <item name="backgroundTint">@color/your_button_background_selector</item>
    ...
</style>

【讨论】:

[来源:***.com/a/60619835/421467]【参考方案4】:

我遇到了同样的问题,并通过在选择器中使用 android:state_checked="true" 而不是 android:state_selected="true" 解决了它。

【讨论】:

以上是关于更改 MaterialButtonToggleGroup 的背景颜色的主要内容,如果未能解决你的问题,请参考以下文章

在运行时更改方向更改 ViewControllers

UIScrollView 更改 contentOffset 时更改框架

HAC集群更改IP(单节点更改全部节点更改)

HAC集群更改IP(单节点更改全部节点更改)

设备方向更改时更改 UIImage

phpmyadmin 在更改任何值时更改日期