资讯专栏INFORMATION COLUMN

Android4.4 及以下TextView,Button等控件使用矢量图报错

fyber / 3336人阅读

摘要:问题描述最近项目开发中,图标资源我尽量使用了矢量图,然而配置了基本的兼容设置,程序在低版本中运行还是出现了问题。布局文件中,在中使用矢量图,比如这些属性直接引用矢量图资源。

1 问题描述

最近项目开发中,图标资源我尽量使用了矢量图,然而配置了基本的兼容设置,程序在低版本中运行还是出现了问题。

xml布局文件中,在TextView中使用矢量图,比如android:drawableStart,android:drawableStart这些属性直接引用矢量图资源。这样在Android5.0及以上是没问题的,但是5.0以下就抛出找不到图片资源的问题。

2 原因

support库并没有为AppcompatTextView,AppcompatButton等控件适配设置矢量图属性,反正我就记得ImageView,ImageButton有srcCompat属性就是适配了的。

3 解决方案

基础配置(必须):

1 在gradle里加上vectorDrawables 兼容支持

android {
    ...
    defaultConfig {
        ...
       vectorDrawables.useSupportLibrary = true 
    }
    ...
}

2 在Application或者Activity上加上AppCompateDelegate开启CompatVectorFromResources支持

    /**
     * vector兼容5.0以下系统
     */
    static {
        int currentapiVersion = android.os.Build.VERSION.SDK_INT;
        if (currentapiVersion < 21){
            //适配android5.0以下
            AppCompatDelegate.setCompatVectorFromResourcesEnabled(true);
        }
    }
方案1:矢量图包装为selector

如果将就Android4.4,Button就不能用矢量图,要用位图,那还叫锤子的兼容支持,我也不知道Google官方为毛不在兼容控件上多加几个支持属性。

参考stackOverFlow的回答,Button,TextView,应用矢量图,保险的是先把矢量图转为selector,然后selector代替矢量图使用,我觉得这是最佳的办法。

例如:

  

selector_setting.xml



    

这里android:drawableStart,android:drawableEnd,我引用的是selector,但是selector里面就是一个默认的矢量图,但用这种方式布局,在Android4.4下运行程序就不会报错。

方案2:不支持的就使用位图

如果项目做了大半,突然说之前的矢量图不能用,要改为位图,这是很崩溃的。

4 扩展:为什么我要用矢量图,而不是位图

最常见的设置界面:

我不知道各位实现设置Item的方式是怎样的,我实现UI的原则是能用一个控件实现就用一个实现,所以Item我用一个Button控件就实现了。Button,TextView自带drawableStart属性,可以在上下左右放图标,所以何必要用LinearLayout包三个控件实现呢。

例如:

    

但是如果drawableStart引用的是位图,这样图标的大小就很难调节,总是要找设计师重新切图,麻烦。但是用vector向量图就可以通过android:width,android:height调大小,这对开发来说很方便。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/14739.html

相关文章

  • GitHub Top 100 的 Android 开源库简介

    摘要:它采用一种假定有序快速匹配的算法,把的性能提升到极致,是目前语言中最快的库。 继上一篇 Android 学习资料收集 得到不少响应,你们给了我很多动力, 因此我决定再整理下 GitHub 上前 100 的 Android 开源库简介,希望对你们有所帮助 本项目主要对目前 GitHub 上排名前 100 的 Android 开源库进行简单的介绍, 至于排名完全是根据GitHub搜索Jav...

    oneasp 评论0 收藏0
  • 很值得收藏的安卓开源控件

    摘要:日历日历列表视图星期视图日历提交日历日期风格的日历相结合的弹出日历横向日历风格的各种样式类似显示进度数字显示进度圆形进度条有进度动画效果下载带进度带动画效果圆形进度条基于贝塞尔曲线更顺滑的进度条各种效果风格的进度条菜单仿弹出菜单方 日历 日历列表视图 https://github.com/traex/CalendarListview showImg(https://segmentfau...

    gaosboy 评论0 收藏0
  • 安卓开发学习笔记(七):仿写腾讯QQ登录注册界面

    摘要:上面这一段代码主要是用到了活动的跳转,不然登录是登录不进去的这里因为我们直接使用了当中活动的跳转。点击登录就会立刻跳转到下一个界面进行登录,当然简介,是的直接子类。这些标签都需要类的支持,但是并不包括所有的标签。这段代码的关键主要是在我们的相对布局以及线性布局上面,我们首先在总体布局里设置为线性布局,然后再在里面设置为相对布局,这是一个十分常见的XML布局模式。 废话不多说,直接上代码:一....

    geekzhou 评论0 收藏0
  • 【腾讯Bugly干货分享】Android动态布局入门NinePatchChunk解密

    摘要:使用定义布局的方式,有着结构清晰可预览等优势,因而极为通用。可是,偏偏在某些场景下,布局是需要根据运行时的状态变化的,无法使用预先定义。这时候,我们只能通过控制,在程序运行时,动态的实现对应的布局。这是动态布局中最基础最常用的步骤。 本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57c7f... 作者:黄进——QQ...

    leanxi 评论0 收藏0
  • Android ConstraintLayout详解(from jianshu)

    摘要:添加找到并拖到内。在右侧,面板可以改变已选择的各种属性。我们的目标是在容器以及之间创建约束。使用面板来修改最右边的为以及左侧改为将一个和一个放到中。并自动创建约束。Android ConstraintLayout详解 https://www.jianshu.com/p/a8b49ff64cd3 1. 概述 在本篇文章中,你会学习到有关ConstraintLayout -- ...

    番茄西红柿 评论0 收藏0

发表评论

0条评论

fyber

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<