2

我正在尝试在 Google 材料的 ExtendedFloatingActionButton 中添加一个颜色矢量图标但 它在图标中显示黑色背景。

在布局预览中,它看起来不错,但在移动设备上运行时,它在图标附近显示黑色背景。

 <com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
     android:id="@+id/floating_btn_take_test"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:layout_gravity="bottom|center"
     android:layout_marginBottom="@dimen/dimen_20dp"
     android:text="@string/txt_take_test"
     android:textColor="@color/primaryColor"
     app:backgroundTint="@color/color_white"
     app:elevation="@dimen/dimen_10dp"
     app:icon="@drawable/ic_color_icon"
     app:iconTintMode="add"
     app:layout_anchorGravity="bottom|center"
     app:rippleColor="@color/secondaryColor"
     app:shapeAppearanceOverlay="@style/ShapeAppearance_Button" />

<style name="ShapeAppearance_Button" parent="ShapeAppearance.MaterialComponents.SmallComponent">
    <item name="cornerFamily">rounded</item>
    <item name="cornerSize">@dimen/dimen_10dp</item>
    <item name="android:layout_marginBottom">@dimen/dimen_30dp</item>
</style>

如何去除图标周围的黑色背景?

4

2 回答 2

3

请尝试app:tint如下使用:-

<com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
    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/color_white"
    app:tint="@null"
    app:icon="@drawable/ic_color_icon"
/>

或者

改变app:backgroundTint="@null"

于 2020-06-11T13:50:47.987 回答
1

如果我理解正确,您正在尝试将具有不同颜色的图标添加到 FAB?

这样做时,请确保添加app:tint="@null". 在您的情况下,xml 应该如下所示。

<com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
    android:id="@+id/floating_btn_take_test"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom|center"
    android:layout_marginBottom="@dimen/dimen_20dp"
    android:text="@string/txt_take_test"
    android:textColor="@color/primaryColor"
    app:backgroundTint="@color/color_white"
    app:elevation="@dimen/dimen_10dp"
    app:icon="@drawable/ic_color_icon"
    app:layout_anchorGravity="bottom|center"
    app:rippleColor="@color/secondaryColor"
    app:shapeAppearanceOverlay="@style/ShapeAppearance_Button"
    app:tint="@null" />

<style name="ShapeAppearance_Button" parent="ShapeAppearance.MaterialComponents.SmallComponent">
   <item name="cornerFamily">rounded</item>
   <item name="cornerSize">@dimen/dimen_10dp</item>
   <item name="android:layout_marginBottom">@dimen/dimen_30dp</item>
</style>
于 2020-06-11T14:11:47.583 回答