为什么我的 FloatingActionButton 图标是黑色的?

88
以下是我正在使用的代码。 我正在使用androidx。 每个FAB都有一个黑色图标,即使它具有白色颜色。
mylayout.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_gravity="center"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

    <include layout="@layout/content_geral" />

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|end"
        android:layout_margin="24dp"
        app:backgroundTint="@color/colorPrimary"
        app:srcCompat="@drawable/ic_cloud_upload"
        tools:ignore="VectorDrawableCompat" />

</androidx.coordinatorlayout.widget.CoordinatorLayout>
 <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.MaterialComponents.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        <item name="windowNoTitle">true</item>
        <item name="windowActionBar">false</item>
    </style>

在此输入图片描述

6个回答

206
如果你正在使用AndroidX,想要改变图标的颜色,必须使用app:tint而不是android:tint
<com.google.android.material.floatingactionbutton.FloatingActionButton
    style="@style/Widget.MaterialComponents.FloatingActionButton"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginEnd="16dp"
    android:layout_marginBottom="16dp"
    app:backgroundTint="@color/colorPrimary"
    app:tint="@color/white"
    app:srcCompat="@drawable/ic_add"
/>

6
如果“app:tint”对你不起作用,那么“app:iconTint”对我在ic_input_add按钮上起作用。 - Kraigolas

101

我有一个多彩的图标(向量),但是我不能使用app:tint="@color/white",因为我的图标颜色会变成单一的白色,而我不需要这样。

所以我通过将app:tint设置为null来解决了我的问题:

  app:tint="@null"

我的图标(SVG):

这里输入图片描述


13

来自AndroidX的FloatingActionButton类使用colorOnSecondary主题属性来着色其图标。

https://github.com/material-components/material-components-android/blob/master/lib/java/com/google/android/material/floatingactionbutton/res/values/styles.xml#L39

如果你跟随{{MaterialComponents}}主题定义进入基本定义,你会看到colorOnSecondary的默认值是design_default_color_on_secondary... 而那个被定义为#000000

https://github.com/material-components/material-components-android/blob/master/lib/java/com/google/android/material/color/res/values/colors.xml#L26

你可以通过直接将app:tint属性添加到你的FloatingActionButton上或重新定义主题中的@color/colorOnSecondary来解决此问题。

6

您正在更改 FAB 的 背景 颜色,而不是图标颜色。 要更改 图标 颜色,请使用:

android:tint

更新

你也可以通过编程来改变颜色:

Drawable myFabSrc = getResources().getDrawable(android.R.drawable.ic_input_add);
Drawable willBeWhite = myFabSrc.getConstantState().newDrawable();
willBeWhite.mutate().setColorFilter(Color.WHITE, PorterDuff.Mode.MULTIPLY);
myFabName.setImageDrawable(willBeWhite);

不起作用。=( - Álysson Alexandre
你也可以通过使用ColorFilter在程序中编程更改颜色(已更新我的答案)。 - alexandrov

2
你正在使用android:backgroundTint属性来设置FAB的背景颜色,但要更改FAB图标的颜色,请使用android:tint属性,像这样:
    <android.support.design.widget.FloatingActionButton
    android:id="@+id/fab"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom|end"
    android:tint="@android:color/white"
    android:src="@android:drawable/ic_input_add"
   />

2
在您的drawable文件夹中,点击


ic_cloud_upload

将fillColor更改为
android:fillColor="#FFFFFF" // #FFFFFF is for white color

这将把您的黑色图标变成白色。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接