Android中使用矢量图(快速运用)

作者: CaptainJno | 来源:发表于2017-03-22 19:26 被阅读0次

    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 (可能需要梯子)

    2、简友文章:http://www.jianshu.com/p/313912ff2f37

    相关文章

      网友评论

        本文标题:Android中使用矢量图(快速运用)

        本文链接:https://www.haomeiwen.com/subject/xgzonttx.html