Android Lollipop 新特性 - Palette

转载自:http://baoyz.com/android/2014/10/21/android-palette-use/

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

Palette可以提取的颜色如下

  • Vibrant (有活力的)
  • Vibrant dark(有活力的 暗色)
  • Vibrant light(有活力的 亮色)
  • Muted (柔和的)
  • Muted dark(柔和的 暗色)
  • Muted light(柔和的 亮色)

使用方法

我们要想使用Palette,需要导入Palette的兼容库,Gradle 中添加下面依赖。


  
  
  1. compile 'com.android.support:palette-v7:21.0.0'

第一步,我们需要通过一个Bitmap对象来生成一个对应的Palette对象。

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的方法,其实内部就是创建了一个AsyncTaskgenerateAsync方法需要一个PaletteAsyncListener对象用于监听生成完毕的回调。除了必须的Bitmap参数外,还可以传入一个numColors参数指定颜色数,默认是 16。

第二步,得到Palette对象后,就可以拿到提取到的颜色值

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

第三步,使用颜色,上面get方法中返回的是一个 Swatch 样本对象,这个样本对象是Palette的一个内部类,它提供了一些获取最终颜色的方法。

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

通过 getRgb() 可以得到最终的颜色值并应用到UI中。getBodyTextColor() 和getTitleTextColor() 可以得到此颜色下文字适合的颜色,这样很方便我们设置文字的颜色,使文字看起来更加舒服。

实例代码


  
  
  1. // 此方法可能会阻塞主线程,建议使用异步方法
  2. Palette palette = Palette.generate(bitmap);
  3. // 异步提取Bitmap颜色
  4. Palette.generateAsync(bitmap, new Palette.PaletteAsyncListener() {
  5. @Override
  6. public void onGenerated(Palette palette) {
  7. // 提取完毕
  8. // 有活力的颜色
  9. Palette.Swatch vibrant = palette.getVibrantSwatch();
  10. // 有活力的暗色
  11. Palette.Swatch darkVibrant = palette.getDarkVibrantSwatch();
  12. // 有活力的亮色
  13. Palette.Swatch lightVibrant = palette.getLightVibrantSwatch();
  14. // 柔和的颜色
  15. Palette.Swatch muted = palette.getMutedSwatch();
  16. // 柔和的暗色
  17. Palette.Swatch darkMuted = palette.getDarkMutedSwatch();
  18. // 柔和的亮色
  19. Palette.Swatch lightMuted = palette.getLightMutedSwatch();
  20.  
  21. // 使用颜色
  22. // 修改Actionbar背景颜色
  23. getActionBar().setBackgroundDrawable(new ColorDrawable(vibrant.getRgb()));
  24. // 修改文字的颜色
  25. mTextView.setTextColor(vibrant.getTitleTextColor());
  26. ...
  27. // 根据需求选择不同效果的颜色应用
  28. });

效果

screenshot

代码下载

https://github.com/baoyongzhang/android-lollipop-samples 中的 palette-sample

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值