Android Studio现在在21+上支持矢量资产,并将在编译时为低版本生成png。我有一个矢量资产(来自材质图标),我想改变填充颜色。这适用于21+,但生成的png不改变颜色。有办法做到这一点吗?

<vector android:height="48dp" android:viewportHeight="24.0"
android:viewportWidth="24.0" android:width="48dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@color/primary" android:pathData="M9,16.17L4.83,12l-1.42,1.41L9,19 21,7l-1.41,-1.41z"/>


当前回答

Android工作室现在支持矢量前棒棒糖。不进行PNG转换。你仍然可以改变你的填充颜色,它会工作。

在ImageView中,使用

 app:srcCompat="@drawable/ic_more_vert_24dp"

在gradle文件中,

 // Gradle Plugin 2.0+  
 android {  
   defaultConfig {  
     vectorDrawables.useSupportLibrary = true  
   }  
 }  

 compile 'com.android.support:design:23.4.0'

其他回答

如果你想支持旧版前棒棒糖

使用相同的XML代码,只是做了一些更改

而不是普通的ImageView——> AppCompatImageView

而不是android:src——> app:srcCompat

这里有一个例子

<android.support.v7.widget.AppCompatImageView
        android:layout_width="48dp"
        android:layout_height="48dp"
        android:id="@+id/button"
        app:srcCompat="@drawable/ic_more_vert_24dp"
        android:tint="@color/primary" />

别忘了更新你的gradle @ Sayooj Valsan提到

// Gradle Plugin 2.0+ android { defaultConfig { vectorDrawables。useSupportLibrary = true } } 编译“com.android.support:设计:23.4.0”

注意:对于任何一个使用矢量,永远永远不要给你的矢量引用颜色,就像这个android:fillColor="@color/primary"给出它的十六进制值。

对于我的ImageButton,我使用app:tint="@color/green"而不是android:tint

不要直接编辑矢量资产。如果你在ImageButton中使用矢量绘图,只需在android:tint中选择你的颜色。

<ImageButton
        android:layout_width="48dp"
        android:layout_height="48dp"
        android:id="@+id/button"
        android:src="@drawable/ic_more_vert_24dp"
        android:tint="@color/primary" />

如果向量没有使用fillColor显示单独设置的颜色,那么它们可能被设置为默认的小部件参数。

尝试在activity_main.xml中添加app:itemIconTint="@color/lime"来为小部件图标设置默认颜色类型。

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout 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:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:openDrawer="start">

    <include
        layout="@layout/app_bar_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

    <android.support.design.widget.NavigationView
        android:id="@+id/nav_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_main"
        app:itemIconTint="@color/lime"
        app:menu="@menu/activity_main_drawer" />

</android.support.v4.widget.DrawerLayout>

可记录的

对于那些不使用ImageView的人,下面的工作为我在一个普通的视图(因此行为应该复制在任何类型的视图)

<View
    android:background="@drawable/ic_reset"
    android:backgroundTint="@color/colorLightText" />