DrawableCompat给图片动态着色

前几天项目上遇到了一个需求,客户需要动态配置一个活动,活动的图标是服务器配置的,app负责展示,由于设计师在展示的地方有自己的背景颜色,而图标颜色也是不一样的很可能就会产生接近或者一样的颜色,这样体验就不好了,如果能给图片动态着色那问题就迎刃而解了。一番搜索后还真有下面来总结一下。

为什么要使用DrawableCompat呢?因为从名字上看就知道他是一个Drawable的兼容包并且对低版本的手机有很好的兼容效果。
这是官方的原话:
Helper for accessing features in Drawable introduced after API level 4 in a backwards compatible fashion.
要想给图片着色需要用到下面这个及API
wrap(Drawable drawable)
setTint(Drawable drawable, int tint)
setTintList(Drawable drawable, ColorStateList tint)

  • 先来看看wrap(Drawable drawable)方法

Potentially wrap drawable so that it may be used for tinting across the different API levels, via the tinting methods in this class.
简单的说通过这个方法获取的Drawable对象,在使用DrawableCompat类中的染色一类的方法,可以在不同的API级别上应用着色。
因此想要着色就先把原先的Drawable对象wrap一下后回去到新的Drawable对象。
后面两个方法就是染色的方法了。我们先来看看一个代码片段

<ImageView
        android:id="@+id/iv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/img_history_sport_kll"/>

默认效果如果

初始效果

使用API着色以后

ImageView iv= (ImageView) findViewById(R.id.iv);
//获取ImageView的Drawable
Drawable orig=iv.getDrawable();
//使用wrap函数获取新的Drawable
Drawable wrap=DrawableCompat.wrap(orig).mutate();
//将变换后的Drawable重新染色
DrawableCompat.setTint(wrap,ContextCompat.getColor(MainActivity.this,android.R.color.holo_red_dark));
//将染好色的Drawable设置给ImageView
iv.setImageDrawable(wrap);
着色之后
  • mutate()方法

细心的同学应该发现在wrap后面多了一个函数,可以按住Ctrl键用鼠标点进去看看官方的解释;
Make this drawable mutable. This operation cannot be reversed. A mutable
drawable is guaranteed to not share its state with any other drawable.
This is especially useful when you need to modify properties of drawables
loaded from resources. By default, all drawables instances loaded from
the same resource share a common state; if you modify the state of one
instance, all the other instances will receive the same modification.

Calling this method on a mutable Drawable will have no effect.
大致的意思就是,使用这个方法,可以让一个应用中使用同样的片的地方不受影响,因为默认情况下,相同的图片资源是被共享同一种状态的。如果修改了一个实例的状态,那么其他使用这个实例的地方都会被修改。因此这个方法的作用就是让其他地方不受影响。

举个例子,比如我一个界面上有多个地方要显示同样的图片,

着色前

此时我给其中的一种图片着色且不使用mutate()反方法,你会发现另一种也跟着一起变了


着色后

这证明两个ImageView共享了同样的资源。mutae()这个时候就派上作用了。使用它就可以让另一个不受影响。

  • 使用着色实现点击效果。

在点击一个控件的时候为了友好交互通常会伴有相应的点击效果。一般的做法就是改变一下原有控件的颜色。如果控件是一个纯色控件那很简单,但如果是一张图片呢?这个时候就setTintList(Drawable drawable, ColorStateList tint)方法就派上作用了直接上代码:

Drawable orig=iv1.getDrawable();
iv1.setImageDrawable(null);
Drawable wrap=DrawableCompat.wrap(orig).mutate();
DrawableCompat.setTintList(wrap,ContextCompat.getColorStateList(this,R.color.stat));
iv1.setImageDrawable(wrap);

R.color.stat如下:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:color="#FF00ff" android:state_pressed="true"/>
    <item android:color="#000000" android:state_pressed="false"/>
    <item android:color="#000000"/>
</selector>

这样你的图片就会有点击变色效果了。

欢迎共同探讨更多安卓,java,c/c++相关技术QQ群:392154157

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,123评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,031评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,723评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,357评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,412评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,760评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,904评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,672评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,118评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,456评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,599评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,264评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,857评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,731评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,956评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,286评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,465评论 2 348

推荐阅读更多精彩内容