使用Palette获取图片的主调色

2023-10-08 19:59

本文主要是介绍使用Palette获取图片的主调色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用Palette获取图片的主调色

  • Palette
    • 1.Palette主要方法
    • 2.基本使用
      • 1.导入依赖包
      • 2.Palette 创建并传入bitmap
      • 3.拿到提取到的颜色值
      • 4.简单的实现效果
      • 5.主要代码
        • 5.1 PaletteUitls类
        • 5.2 调用
        • 5.3 利用获取到的主题色做渐变背景(Update:2022.3.31)

Palette

Palette:翻译过来就是调色板的意思,会根据传入的bitmap,提取出主体颜色(分六种特性可选)。我们可以调用 Palette 从一张图片中提取出某种特性颜色并将颜色融入到UI中。比如,我们可以设置给ActionBar、布局做背景颜色,这样ActionBar和布局的颜色就会随着显示图片的变化而变化,这样可以使整个App看起来风格统一一点。

1.Palette主要方法

方法介绍
Palette.Builder生成器类,生成 Palette 实例
Palette.PaletteAsyncListener异步加载监听
from(Bitmap bitmap)通过返回 Palette.Builder 实例来构建 Palette
palette.getMutedColor(Color.BLUE)获取图片中一个最柔和的颜色(若无法取到相对应特性的颜色值,则返回默认值Color.BLUE)
palette.getDarkMutedColor(Color.BLUE)获取到柔和的深色的颜色(同上)
palette.getDarkVibrantColor(Color.BLUE)获取到活跃的深色的颜色(同上)
palette.getVibrantColor(Color.BLUE)获取图片中最活跃的颜色(也可以说整个图片出现最多的颜色)(同上)
palette.getLightMutedColor(Color.BLUE)获取到柔和的明亮的颜色(同上)
palette.getLightVibrantColor(Color.BLUE)获取到活跃的明亮的颜色(同上)

2.基本使用

1.导入依赖包

    implementation 'androidx.palette:palette:1.0.0'

2.Palette 创建并传入bitmap

Palette提供了四个方法来生成对象:

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

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

3.拿到提取到的颜色值

  • Palette.getVibrantSwatch()
  • Palette.getDarkVibrantSwatch()
  • Palette.getLightVibrantSwatch()
  • Palette.getMutedSwatch()
  • Palette.getDarkMutedSwatch()
  • Palette.getLightMutedSwatch()

4.简单的实现效果

效果图.jpg

5.主要代码

5.1 PaletteUitls类
public class PaletteUtils {/*** Vibrant (有活力的)* Vibrant dark(有活力的 暗色)* Vibrant light(有活力的 亮色)* Muted (柔和的)* Muted dark(柔和的 暗色)* Muted light(柔和的 亮色)**/public static Target vibrant = Target.VIBRANT;public static Target vibrantDark = Target.DARK_VIBRANT;public static Target vibrantLight = Target.LIGHT_VIBRANT;public static Target muted = Target.MUTED;public static Target mutedDark = Target.DARK_MUTED;public static Target mutedLight = Target.LIGHT_MUTED;//结果颜色值private int resultColor = -1;private static PaletteUtils instance;private PaletteUtils(){};public static PaletteUtils getInstance(){if (instance == null) {instance = new PaletteUtils();}return instance;}private Bitmap mBitmapCover;public void generateAsync(final View main_view, Context context, String string, final Target target){//Glide通过uri获取drawable,再转换为bitmap   Glide.with(context).load(string).error(R.mipmap.fun_bg) //获取失败.placeholder(R.mipmap.fun_bg) //占位.into(new SimpleTarget<Drawable>() {@Overridepublic void onResourceReady(@NonNull Drawable resource, @Nullable Transition<? super Drawable> transition) {Log.e("lee", "onResourceReady: " + (resource == null));mBitmapCover = DrawableToBitmap(resource);if (null != mBitmapCover){startPalette(mBitmapCover,main_view,target);}}});}private void startPalette(Bitmap mBitmapCover,View main_view,Target target) {resultColor = -1;Palette.from(mBitmapCover).generate(new Palette.PaletteAsyncListener() {//异步回调@Overridepublic void onGenerated(@Nullable Palette palette) {if (vibrant.equals(target)) {resultColor = palette.getVibrantColor(Color.BLUE);Log.e("lee", "onGenerated: getVibrantColor" + resultColor);} else if (vibrantDark.equals(target)) {resultColor = palette.getDarkVibrantColor(Color.BLUE);Log.e("lee", "onGenerated: getDarkVibrantColor" + resultColor);} else if (vibrantLight.equals(target)) {resultColor = palette.getLightVibrantColor(Color.BLUE);Log.e("lee", "onGenerated: getLightVibrantColor" + resultColor);} else if (muted.equals(target)) {resultColor = palette.getMutedColor(Color.BLUE);Log.e("lee", "onGenerated: getMutedColor" + resultColor);} else if (mutedDark.equals(target)) {resultColor = palette.getDarkMutedColor(Color.BLUE);Log.e("lee", "onGenerated: getDarkMutedColor" + resultColor);} else if (mutedLight.equals(target)) {resultColor = palette.getLightMutedColor(Color.BLUE);Log.e("lee", "onGenerated: getLightMutedColor" + resultColor);}else{resultColor = palette.getVibrantColor(Color.BLUE);Log.e("lee", "onGenerated: getVibrantColor" + resultColor);}//获取到了颜色if (resultColor != -1 && resultColor != Color.BLUE) {main_view.setBackgroundColor(resultColor);} else {main_view.setBackgroundResource(R.mipmap.fun_bg);}}});}//drawable->bitmap转换public static Bitmap DrawableToBitmap(Drawable drawable) {// 获取 drawable 长宽int width = drawable.getIntrinsicWidth();int heigh = drawable.getIntrinsicHeight();drawable.setBounds(0, 0, width, heigh);// 获取drawable的颜色格式Bitmap.Config config = drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888: Bitmap.Config.RGB_565;// 创建bitmapBitmap bitmap = Bitmap.createBitmap(width, heigh, config);// 创建bitmap画布Canvas canvas = new Canvas(bitmap);// 将drawable 内容画到画布中drawable.draw(canvas);return bitmap;}
}
5.2 调用
/**第一个参数:需要改变颜色的控件view
* 第二个 参数:context
* 第三个参数:uri
* 第四个参数:Palette获取颜色特性target
*/
PaletteUtils.getInstance().generateAsync(activity_search,SearchActivity.this,contentInfo.poster,PaletteUtils.mutedDark)
5.3 利用获取到的主题色做渐变背景(Update:2022.3.31)

通常开发中需要通过网络加载图片,因此可以用Glide处理,添加RequestListener,在资源加载完成之后再做接下来的处理。
在这里插入图片描述

Glide.with(context).load(item.getPoster()).listener(new RequestListener<Drawable>() {@Overridepublic boolean onLoadFailed(@Nullable GlideException e, Object model, Target<Drawable> target, boolean isFirstResource) {return false;}@Overridepublic boolean onResourceReady(Drawable resource, Object model, Target<Drawable> target, DataSource dataSource, boolean isFirstResource) {Bitmap bitmap =((BitmapDrawable)resource).getBitmap();Palette.from(bitmap).generate(new Palette.PaletteAsyncListener() {@Overridepublic void onGenerated(Palette palette) {Palette.Swatch swatch = palette.getDarkVibrantSwatch();
//  					  swatch.getRgb() => 得到获取到的主题色的rbg值if (swatch != null) {int[] colors = new int[]{swatch.getRgb() & 0x00FFFFFF, // 与一个全透明白色,做startColorswatch.getRgb() & 0xD1FFFFFF, // 与一个 82% 不透明的白色,做centerColorswatch.getRgb()};//GradientDrawable  支持渐变色的drawableGradientDrawable drawable = new GradientDrawable();drawable.setGradientType(GradientDrawable.LINEAR_GRADIENT); //设置线性渐变drawable.setOrientation(GradientDrawable.Orientation.TOP_BOTTOM); //方向从上往下drawable.setColors(colors);// 设置颜色数组(类似 startColor, centerColor, endColor)shadowView.setBackgroundDrawable(drawable); // 设置drawable}}});return false;}}).error(R.drawable.placeholder_1372x560).into(poster);

这篇关于使用Palette获取图片的主调色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/167661

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完