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

news/2024/7/8 5:10:53

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

日常夜拍

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代替矢量图使用,我觉得这是最佳的办法。

例如:

  <Button
        style="@style/SettingItemTheme"
        android:layout_width="match_parent"
        android:layout_height="@dimen/setting_item_height"
        android:text="@string/my_setting"
        android:id="@+id/my_btn_setting"
        android:drawableStart="@drawable/selector_setting"
        android:drawableEnd="@drawable/selector_right"/>

selector_setting.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/ic_my_setting"/>
</selector>

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

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

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

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

最常见的设置界面:

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

例如:

    <Button
        style="@style/SettingItemTheme"
        android:layout_width="match_parent"
        android:layout_height="@dimen/setting_item_height"
        android:text="@string/my_vehicle_manage"
        android:id="@+id/my_btn_vehicle_manage"
        android:drawableStart="@drawable/selector_vehicle_manage"
        android:drawableEnd="@drawable/selector_right"/>

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

转载于:https://my.oschina.net/newtrek/blog/3010985


http://www.niftyadmin.cn/n/2745916.html

相关文章

tomcat怎么运行java_如何在tomcat启动的时候运行一个Java类

设置个Listener就好了&#xff0c;在web.xml中指定描述。web.xml其实就是tomcat启动的时候会读取的一个描述文件&#xff0c;比如访问服务器的时候首页等都可以在里面指定&#xff0c;有相应的tag。这里有解释&#xff1a;http://blog.chinaunix.net/uid-20399471-id-1687965.h…

038:自定义过滤器实战

自定义时间计算过滤器&#xff1a; 有时候经常会在朋友圈、微博中可以看到一条信息发表的时间&#xff0c;并不是具体的时间&#xff0c;而是距离现在多久。比如 刚刚 &#xff0c; 1分钟前 等。这个功能 DTL 是没有内置这样的过滤器的&#xff0c;因此我们可以自定义一个这样的…

【Linux】进程信号之信号的产生

进程信号 一 一、信号入门1、信号的一些特性2、信号的处理方式信号捕捉初识 3、Linux下的信号 二、信号的产生1、通过终端按键产生信号2、调用系统函数向进程发信号a、kill函数b、raise函数c、abort函数 3. 由软件条件产生信号4、硬件异常产生信号 结语 一、信号入门 什么是信号…

python axis client_Python Matplotlib.axis.Axis.get_majorticklocs()用法及代码示例

Matplotlib是Python中的一个库&#xff0c;它是数字的-NumPy库的数学扩展。它是Python中令人惊叹的可视化库&#xff0c;用于数组的2D图&#xff0c;并用于与更广泛的SciPy堆栈配合使用。matplotlib.axis.Axis.get_majorticklocs()功能matplotlib库的轴模块中的Axis.get_majort…

jsp页面报错,报红叉 javax.servlet.http.HttpServlet was not found

完整错误信息&#xff1a; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOTLIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESSFOR A PARTICULAR PURPOSE…

SQL学习笔记 初识SQL

SQL 是用于访问和处理数据库的标准的计算机语言。 SQL(结构化查询语言&#xff0c; 使我们有能力访问数据库&#xff0c; 是一种 ANSI 的标准计算机语言&#xff0c; ) 可分为六个部分&#xff1a;数据查询语言&#xff08;DQL&#xff09;、数据操作语言…

python中confusion matrix_python confusion matrix 混淆矩阵

示例&#xff1a;程序摘自【4】。from sklearn.metrics import confusion_matriximport matplotlib.pyplot as pltimport numpy as npdef plot_confusion_matrix(cm, labels, titleConfusion Matrix):plt.imshow(cm, interpolationnearest, cmapBlues)plt.title(title)plt.colo…

python爬虫入门必备正则_Python爬虫入门七之正则表达式

在前面我们已经搞定了怎样获取页面的内容&#xff0c;不过还差一步&#xff0c;这么多杂乱的代码夹杂文字我们怎样把它提取出来整理呢&#xff1f;下面就开始介绍一个十分强大的工具&#xff0c;正则表达式&#xff01;1.了解正则表达式正则表达式是对字符串操作的一种逻辑公式…