热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MaterialDesign着色(tint)和图像萃取突出颜色(Palette)

1Tint(着色)1.1Tint简介在Android5.0后,View引入了一个叫tint的属性,意思叫“着色”。当我们用用tint属性给view

1 Tint(着色)


1.1Tint简介

在Android 5.0后,View引入了一个叫tint的属性,意思叫“着色”。

当我们用用tint属性给view添加着色后,新添加的颜色会和原来view的颜色进行“交融”(汉语博大精深,一定有更合适的词来形容),当然“交融”的模式有好几种(后面介绍),不同的“交融”模式会展示不同的效果。


1.2 Tint的使用

与tint有关的属性有4个:
这里写图片描述

tint用起来非常简单,只需要在xml中添加属性就行:

<ImageView
android:layout_width&#61;"100dp"android:layout_height&#61;"100dp"android:src&#61;"&#64;drawable/aa"android:tint&#61;"&#64;color/red"android:tintMode&#61;"src_in"/>

在着色的时&#xff0c;tintMode来决定原来颜色和着色颜色如何交融。下面我们就给出不同模式下的交融效果&#xff1a;
这里写图片描述
下面我们来介绍一下android:tintMode


1.3 tintMode讲解

上面我们讲说了&#xff1a;不同的tintMode&#xff0c;颜色“交融”效果是不一样的。之所以不一样是因为它们的交融的原理不一样&#xff08;具体原理请看这位大神写的文章&#xff09;。请看这张图&#xff0c;它说明了交融的原理&#xff1a;
这里写图片描述

在第二张src图片中我们可以看出&#xff1a;Src是原来的颜色&#xff08;即View的颜色&#xff09;Dst是tint的颜色。后面的图片是二种颜色根据不同的模式“交融”后的效果。下面我们来看一下tintMode的6模式&#xff1a;

1、add
2、screen
3、src_over
4、src_in (默认模式)
5、multiply
6、src_atop

1.4 backgroundTint &#xff08;着背景色&#xff09;

backgroundTint 是着背景色&#xff0c;用法和tint一样&#xff0c;但是有一点需要注意&#xff1a;

要想使backgroundTint有效果&#xff0c;必须给View设置background.

代码如下&#xff1a;

<Button
android:layout_width&#61;"match_parent"android:layout_height&#61;"wrap_content"android:backgroundTint&#61;"&#64;color/red"android:background&#61;"#ffffff" />

效果图如下&#xff1a;
这里写图片描述


1.5 Tint兼容性

上述效果均是在Android 5.0以上的平台上才支持。不过&#xff0c;如果我们想支持5.0以下的&#xff0c;我们可以使用support-v7包下的AppCompat**** 控件&#xff0c;只能通过代码设置&#xff0c;而不能通过xml.代码如下&#xff1a;

ColorStateList lists &#61; getResources().getColorStateList(R.color.red);
ViewCompat.setSupportBackgroundTintList(ColorStateList tint);
ViewCompat.setSupportBackgroundTintMode(PorterDuff.Mode tintMode);

2 Palette&#xff08;图像提取突出颜色&#xff09;

Palette 可以从一张图片中提取颜色&#xff0c;我们可以把提取的颜色融入到App UI中&#xff0c;可以使UI风格更加美观融洽。比如&#xff0c;我们可以从图片中提取颜色设置给ActionBar做背景颜色&#xff0c;这样ActionBar的颜色就会随着显示图片的变化而变化。


2.1 Palette可以提取的颜色

我们来看一下palette可以提取的颜色&#xff1a;

Palette可以提取的颜色如下:Vibrant &#xff08;有活力的&#xff09;
Vibrant dark&#xff08;有活力的 暗色&#xff09;
Vibrant light&#xff08;有活力的 亮色&#xff09;
Muted &#xff08;柔和的&#xff09;
Muted dark&#xff08;柔和的 暗色&#xff09;
Muted light&#xff08;柔和的 亮色&#xff09;

2.2 Palette使用步骤

1.添加依赖
compile ‘com.android.support:palette-v7:24.2.1’
2.通过一个Bitmap对象来生成一个对应的Palette对象。
Palette 提供了四个静态方法用来生成对象&#xff1a;

Palette generate(Bitmap bitmap)
Palette generate(Bitmap bitmap, int numColors)
generateAsync(Bitmap bitmap, PaletteAsyncListener listener)
generateAsync(Bitmap bitmap, int numColors, final PaletteAsyncListener listener)

不难看出&#xff0c;生成方法分为generate(同步)和generateAsync(异步)两种&#xff0c;如果图片过大使用generate方法&#xff0c;可能会阻塞主线程&#xff0c;我们更倾向于使用generateAsync的方法&#xff0c;其实内部就是创建了一个AsyncTask。generateAsync方法需要一个PaletteAsyncListener对象用于监听生成完毕的回调。除了必须的Bitmap参数外&#xff0c;还可以传入一个numColors参数指定颜色数&#xff0c;默认是 16。
3.通过Palette对象拿到提取到的颜色值

// 有活力的颜色Palette.Swatch vibrant &#61; palette.getVibrantSwatch();
// 有活力的暗色
Palette.Swatch darkVibrant &#61; palette.getDarkVibrantSwatch();
// 有活力的亮色
Palette.Swatch lightVibrant &#61; palette.getLightVibrantSwatch();
// 柔和的颜色
Palette.Swatch muted &#61; palette.getMutedSwatch();
// 柔和的暗色
Palette.Swatch darkMuted &#61; palette.getDarkMutedSwatch();
// 柔和的亮色
Palette.Swatch lightMuted &#61; palette.getLightMutedSwatch();

4.使用颜色
上面get方法中返回的是一个 Swatch 样本对象&#xff0c;这个样本对象是Palette的一个内部类&#xff0c;它提供了一些获取最终颜色的方法。

getPopulation(): 样本中的像素数量
getRgb(): 颜色的RBG值
getHsl(): 颜色的HSL值
getBodyTextColor(): 主体文字的颜色值
getTitleTextColor(): 标题文字的颜色值

2.3 实例代码

final Bitmap bitmap&#61; BitmapFactory.decodeResource(getResources(),R.drawable.timg);
Palette palette &#61; Palette.generate(bitmap);
// 异步提取Bitmap颜色
Palette.generateAsync(bitmap, new Palette.PaletteAsyncListener() {&#64;Overridepublic void onGenerated(Palette palette) {// 提取完毕// 有活力的颜色Palette.Swatch vibrant &#61; palette.getVibrantSwatch(); // 有活力的暗色Palette.Swatch darkVibrant &#61; palette.getDarkVibrantSwatch(); // 有活力的亮色Palette.Swatch lightVibrant &#61; palette.getLightVibrantSwatch(); // 柔和的颜色Palette.Swatch muted &#61; palette.getMutedSwatch(); // 柔和的暗色Palette.Swatch darkMuted &#61; palette.getDarkMutedSwatch(); // 柔和的亮色Palette.Swatch lightMuted &#61; palette.getLightMutedSwatch(); // 使用颜色// 修改Actionbar背景颜色getActionBar().setBackgroundDrawable(new ColorDrawable(vibrant.getRgb()));// 修改文字的颜色mTextView.setTextColor(vibrant.getTitleTextColor());...// 根据需求选择不同效果的颜色应用});

3结尾

好了就讲到这里吧&#xff0c;希望对大家有所帮助。
在技术上我依旧是个小渣渣&#xff0c;加油&#xff01;勉励自己&#xff01;


4 参考文档

【1】使用Material Design Tint和视图详解这里写链接内容
【2】Android 颜色渲染(九) PorterDuff及Xfermode详解这里写链接内容
【3】5.0学习计划–Palette详解
【4】Android Lollipop 新特性 - Palette


推荐阅读
author-avatar
Wei-Micro_788
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有