def draw_distribute_chart(root_path):
_, avg_Hlist, avg_Slist ,avg_Vlsit = compute_dir_HSV(root_path)
sns.set_style("darkgrid")
chart_avg_H = avg_Hlist
chart_avg_S = avg_Slist
chart_avg_V = avg_Vlsit
sns.distplot(chart_avg_H, color='g',label='avg_H')
sns.distplot(chart_avg_S, color='r',label='avg_S')
sns.distplot(chart_avg_V, color='y',label='avg_V')
plt.legend()
plt.show()
单个图片文件夹下图片的色相、饱和度、明度分布图![在这里插入图片描述](https://img-blog.csdnimg.cn/e9cd975cd92b4d599d94c805579d2976.png#pic_center)
(https://imgblog.csdnimg.cn/c129240dbd7048f99daa19c565e68d59.png#pic_center)
计算单个图片文件夹下所有图片的饱和度、色相、明度并绘制三种属性的分布图单个图片文件夹下图片的色相、饱和度、明度分布图(https://imgblog.csdnimg.cn/c129240dbd7048f99daa19c565e68d59.png#pic_center)
Photoshop 的色相/饱和度调整,可以对全图、红、黄、绿、青、蓝、洋红六个通道进行设置。每个通道可设置: 色相(hue), 饱和度(satuation), 明度(Lightness)三个调整值。
另包含 多个颜色空间转换函数
饱和度调整算法说明(完整python代码在文末):
本算法主要是利用HSL颜色空间进行饱和度S的上下限控制,对RGB空间进行补丁式调整。调整过程在RGB空间进行,其原理简单地说就是判断每个像素的R、G、B值是否大于或小于平均值,大于加上调整值,小于则减去调整值,如何计算各个像素点的调整系数是关键。本算法主体思想就是利用HSL来计算各点的调整系数。
算法过程如下:
(参考CSDN博客:http...
获取蓝色在图片中所占百分比思路代码运行结果测试图片
由于每种颜色都有一个阈值,单纯的计算RGB百分比的效果并不好,对于这点,网上已经有很多结论。于是,我想到采用hsv空间下每个像素点分量,获取某种颜色所占百分比(我这里采用的是蓝色)。因为,在hsv空间下,相近颜色都会被归于一个范围。所以,我们可以比较相近颜色,在图片中,所占百分比。
#include<iostream>
#include<opencv2/opencv.hpp>
#include<iomanip>
Opencv 中图片像素操作的应用实例——计算图片某一种颜色区域大小所占比
From: https://www.cnblogs.com/changxiang/p/7533294.html
对图片进行处理,其中图片像素的处理是基本的过程,包括对图片像素的遍历,对每一个像素的RGB三个通道的灰度值的获取等。
以下是基于opencv 的一个应用实例,即计算图片中黄色区域大小占整个图片大小的比...
可以使用MATLAB中的rgb2hsv函数来提取出图片的色调,明度和饱和度。该函数将RGB颜色空间转换为HSV颜色空间,其中H表示色调,S表示饱和度,V表示明度。以下是示例代码:
img = imread('image.jpg');
hsv_img = rgb2hsv(img);
hue = hsv_img(:,:,1);
saturation = hsv_img(:,:,2);
value = hsv_img(:,:,3);
这将提取出图片的色调,明度和饱和度,并将它们存储在hue,saturation和value变量中。