日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

使用Palette类提取图片的颜色信息

發布時間:2025/4/16 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用Palette类提取图片的颜色信息 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文出處:http://qichaochen.github.io/2014/11/16/105-Android-5.0-Palette-01/

在Material Design設計中很重要的一部分內容是應用中圖片顏色和文字顏色需要和主題相匹配,比如下面在這個應用:

文本的顏色根據不同圖片動態進行對應適配(也許你會說,如果全部用白色文本多省事,何必這么麻煩呢?額…可以腦補一下高富帥和矮矬窮的區別)

那么在應用程序中如何提取圖片的顏色信息呢?可以提取多少種顏色信息呢? 在最新的Support Library v21提供了Palette類可以很方便的實現這個需求。

下面看一下提取圖片顏色信息的步驟和注意事項:

1、首先需要添加Palette的依賴

在build.gralde的dependencies添加appcomat v7和palette-v7依賴

dependencies {//...其他依賴compile 'com.android.support:appcompat-v7:21.0.0'compile 'com.android.support:palette-v7:21.+' }

添加完成后需要同步一下Gradle,同步成功后就可以使用Palette類了。

2、創建Palette對象

官方提供了四種根據Bitmap對象來創建Palette對象的方法,具體分別如下:

兩種同步方法:

// 最好在加載圖片線程中使用 // 默認調色板大小(16). Palette p = Palette.generate(bitmap); //設置調色板大小(24) Palette p = Palette.generate(bitmap, 24);

兩種異步方法:

// 簡單快速的實現方法,內部使用AsyncTask // 但是可能不是最優的方法(因為有線程的切換) // 默認調色板大小(16). Palette.generateAsync(bitmap, new Palette.PaletteAsyncListener() {@Overridepublic void onGenerated(Palette palette) {// palette為生成的調色板} }); // 設置調色板大小(24) Palette.generateAsync(bitmap, 24, new Palette.PaletteAsyncListener() {@Overridepublic void onGenerated(Palette palette) {// palette為生成的調色板} });

調色板的大小值越大,生成的調色板的時間越長,數值越小,得到的顏色信息也越少,調色板的大小最好根據圖片類型來決定,比如:

  • 聯系人頭像:最優值24~32
  • 風景圖:8-16
  • 當然默認是16,大多數情況下都可以取得很好的效果。

3、使用Palette對象

生成了Palette對象后就可以嘗試獲取六種不同的色板,具體如下:

Palette.Swatch s1 = Palette.getVibrantSwatch(); //充滿活力的色板 Palette.Swatch s2 = Palette.getDarkVibrantSwatch(); //充滿活力的暗色類型色板 Palette.Swatch s3 = Palette.getLightVibrantSwatch(); //充滿活力的亮色類型色板 Palette.Swatch s4 = Palette.getMutedSwatch(); //黯淡的色板 Palette.Swatch s5 = Palette.getDarkMutedSwatch(); //黯淡的暗色類型色板 Palette.Swatch s6 = Palette.getLightMutedSwatch(); //黯淡的亮色類型色板

可以根據需求自由選擇色板類型(充滿活力和或充滿活力暗色類型色板應該是大部分開發經常使用的),有了色板就可以根據色板來獲取具體顏色信息,在Swatch色板中提供了五種顏色信息,分別如下:

方法說明
getPopulation()the number of pixels represented by this swatch
getRgb()the RGB value of this color
getHsl()the HSL value of this color
getBodyTextColor()the RGB value of a text color which can be displayed on top of this color
getTitleTextColor()the RGB value of a text color which can be displayed on top of this color

 
示例代碼如下:

Palette.Swatch swatch = palette.getVibrantSwatch(); TextView titleView = ...; if (swatch != null) {titleView.setBackgroundColor(swatch.getRgb());titleView.setTextColor(swatch.getTitleTextColor()); //設置文本顏色

請注意必須對swatch進行是否為null判斷,因為如果面板無法找到相匹配的標準色,那么然后將返回null,不進行判斷將會出現空指針異常。

最后附上三個測試效果圖和完整代碼。

完整代碼

public class MainActivity extends ActionBarActivity {private ImageView image, iv1, iv2, iv3, iv4, iv5, iv6;private Palette palette;private Palette.Swatch s1,s2,s3,s4,s5,s6;private int index = 0;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);iv1 = (ImageView) findViewById(R.id.iv1);iv2 = (ImageView) findViewById(R.id.iv2);iv3 = (ImageView) findViewById(R.id.iv3);iv4 = (ImageView) findViewById(R.id.iv4);iv5 = (ImageView) findViewById(R.id.iv5);iv6 = (ImageView) findViewById(R.id.iv6);image = (ImageView) findViewById(R.id.image);GetPalette(R.drawable.a11);}private void GetPalette(int imageId) {image.setImageResource(imageId);//使用默認的調色板大小(16)Palette.generateAsync(BitmapFactory.decodeResource(getResources(), imageId), new Palette.PaletteAsyncListener() {@Overridepublic void onGenerated(Palette palette) {s1 = palette.getVibrantSwatch();s2 = palette.getDarkVibrantSwatch();s3 = palette.getLightVibrantSwatch();s4 = palette.getMutedSwatch();s5 = palette.getDarkMutedSwatch();s6 = palette.getLightMutedSwatch();if (s1 != null) {iv1.setBackgroundColor(s1.getRgb());s1.getPopulation();}if (s2 != null) {iv2.setBackgroundColor(s2.getRgb());}if (s3 != null) {iv3.setBackgroundColor(s3.getRgb());}if (s4 != null) {iv4.setBackgroundColor(s4.getRgb());}if (s5 != null) {iv5.setBackgroundColor(s5.getRgb());}if (s6 != null) {iv6.setBackgroundColor(s6.getRgb());}}});}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {getMenuInflater().inflate(R.menu.menu_main,menu);return true;}@Overridepublic boolean onOptionsItemSelected(MenuItem item) {if (item.getItemId() == R.id.action_settings){index++;if (index%3 == 0){GetPalette(R.drawable.a11);} else if (index % 3 == 1){GetPalette(R.drawable.a12);} else if (index % 3 == 2){GetPalette(R.drawable.a13);}}return true;} }

參考

Chris Banes:《Palette v21》
Chris Banes:《Palette preview》
Palette Reference

總結

以上是生活随笔為你收集整理的使用Palette类提取图片的颜色信息的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 色呦呦视频 | 毛片网站在线免费观看 | 欧美另类高清 | av首页在线 | 夜夜超碰| 国产精品亚洲一区二区三区 | 女人久久久 | 精品久久一二三区 | 精产国品一区二区三区 | 自拍偷拍激情小说 | 求免费黄色网址 | 久久激情免费视频 | 伊人www22综合色 | 色呦呦麻豆 | 久久久国产高清 | 久久久精品网 | 久久人人爽人人爽人人av | 欧美经典一区二区三区 | 亚洲色图一区二区三区 | 插久久| 手机在线看片你懂的 | 777理伦三级做爰 | 97久久久久久久久久 | a级片在线免费看 | 久久精品一本 | 国产精品天天av精麻传媒 | 国产大奶在线观看 | 美丽的姑娘在线观看 | 一级二级在线观看 | 精品三级av| 欧美色图国产精品 | 婷婷五月精品中文字幕 | 精品在线免费播放 | 韩国av三级 | 97自拍视频 | 免费视频a| 欧美日韩精品综合 | 男人添女人下部高潮视频 | 你懂的网址在线 | 日本高清视频一区二区 | 综合精品一区 | 少妇av一区 | 在线免费黄 | 桃色激情网 | 国产xxxx做受性欧美88 | 国产一区二区在线免费观看视频 | 色老汉视频 | 精品成人中文无码专区 | 美丽的姑娘在线观看免费 | 日本成人高清 | 亚洲不卡在线视频 | 亚洲天堂影视 | 国产福利小视频在线观看 | 精品性久久 | 91影院在线| 日本打屁股网站 | 亚洲特黄视频 | 欧美激情在线播放 | 中文字幕一区二区三区乱码在线 | 国产ts人妖调教重口男 | 全部免费毛片在线播放一个 | 国产一级精品毛片 | 成人在线观看国产 | 男女网站在线观看 | 黄瓜视频在线观看污 | 欧美性bbw| 久久五十路 | 国产av日韩一区二区三区精品 | av色噜噜| 夜夜夜久久久 | 日本成人激情 | 国产爽爽爽 | 久久精品中文闷骚内射 | 成人性视频网站 | 天天天天操 | 天天做夜夜做 | 国产精品久久久久9999爆乳 | 精品少妇人妻av免费久久久 | 日韩在线一二三区 | 娇妻之欲海泛舟无弹窗笔趣阁 | 午夜在线观看视频 | 国产精品情侣呻吟对白视频 | 日本老妇性生活 | 日韩二区在线 | 欧美亚洲大片 | 亚洲男人的天堂在线视频 | 国产大学生自拍视频 | 日本亚洲色大成网站www久久 | 欧美日韩在线观看一区二区三区 | 日本一区二区三区电影在线观看 | 欧美日韩在线综合 | 无码 制服 丝袜 国产 另类 | 大屁股白浆一区二区三区 | 中文字幕国产精品 | 国产做爰免费视频观看 | 韩国三色电费2024免费吗怎么看 | 久久欧| 少妇又色又爽又高潮极品 | 视频一区二区三区在线观看 |