APP开发过程中,容易遇到以下两个问题:
1、res资源包中图片过多、过大,影响打包后APK大小;
2、更换APP主题色时,需要将许多图标重新做一套;
普通方案解决上述问题费时、费力。用矢量图来做,能轻松解决。本文,只简单讲讲如何在项目中快速上手运用矢量图(vector)。(文章最后附上一篇链接,写的很好,想了解更多关于Android中矢量图的同学可以参考)
上手矢量图分几步?四步!
步骤一、启用矢量图支持库
步骤二、添加矢量图xml
步骤三、矢量图使用
步骤四、selector
步骤一、启用矢量图支持库:
在主Module → build.gradle → defaultConfig 中增加一句:vectorDrawables.useSupportLibrary=true
因为API <= 20 不支持矢量图,为了支持,需要引入支持库(API >= 7 可用矢量图)。
步骤二、res/drawable下添加一个矢量图xml如:
如 vector_phone.xml
(很抱歉,由于代码受编辑器限制无法完整贴出,大家先照着代码完整截图手动码一下。另外,截图中path→pathData的内容比较长,截图下方有单独贴出,大家可以直接拷贝粘贴):
android:pathData="M16,1L8,1C6.34,1 5,2.34 5,4v16c0,1.66 1.34,3 3,3h8c1.66,0 3,-1.34 3,-3L19,4c0,-1.66 -1.34,-3 -3,-3zM14,21h-4v-1h4v1zM17.25,18L6.75,18L6.75,4h10.5v14z"/>
附注:
1、fillColor,是矢量图的填充色;
2、pathData,是图标的样子,了解即可;
步骤三、矢量图加完后,怎么用呢:
静态:
如果你要将矢量图作为ImageView背景使用,这么写:
AppCompactImageView是ImageView的子类,增加了对矢量图的支持。(V7中还提供了如 AppCompactImageButton等控件,大家可以自行找找)
这时候代码爆红:因为,采用V7控件,还需要在布局中加一句:
xmlns:app="http://schemas.android.com/apk/res-auto"
动态:
Drawable drawable = getResources().getDrawable(R.drawable.vector_phone);
到此,项目中就可以用上矢量图了。
另外,如果你的上述AppCompactImageViewsrcCompat等控件的背景,采用的是selector资源。请看步骤四:
步骤四、selector:
如果你要将含矢量图的selector作为背景,除了设置srcCompat外,还需在布局所属Activity的代码顶部加一句(为了兼容5.0以下机器),建议这句代码可以加到你的BaseActivity中:
static{ AppCompatDelegate.setCompatVectorFromSourcesEnabled(true);}
趣味知识:
由于API <= 20 不支持矢量图,所以当你的项目最低API <= 20时,并且你未启用支持库(未设置vectorDrawables.useSupportLibrary=true),当生成APK时Vector Asset Studio(Android Studio里的一个工具)会自动给你的vector.xml生成相应的PNG,并且,每个dpi下都会有,这样的话,最后APP打包后,APK反而会大很多。
参考资料:
1、官方文章:https://developer.android.com/studio/write/vector-asset-studio.html (可能需要梯子)