opencv学习笔记 ----绘制直方图

  • 什么是直方图?

图像的直方图是每个点像素值的个数在一个图中展现,每个通道的像素有多少。

直方图是图像一个重要的性质(分析图片的手段)。

  • 计算直方图

​​​​​​​opencv中直接计算直方图的函数,在matplotlib

def han_plt(image):
    plt.hist(image.ravel(), 256,  [0, 256])
    plt.show()

 如图,使用函数后。横坐标是像素的值,纵坐标是个数。

若想要分开颜色

函数的参数cv.calcHist(images,channels,mask,histSize,ranges,hist=None,accumulate=None)

images:它是uint8类型或float32的源图像。它应该用方括号括起来,也就是”[img]”。 
channels:它也用方括号括起来。它是我们计算直方图的信道的索引。例如,如果输入是灰度图像,它的值是0。对于颜色图像,您可以通过0、1或2来分别计算蓝色、绿色或红色通道的直方图。 
mask:遮罩图。为了找到完整图像的直方图,它被指定为“None”。但如果你想找到图像的特定区域的直方图,你必须为它创建一个遮罩图,并将其作为遮罩。 
histSize:这代表了我们的BINS数。需要用方括号来表示。在整个范围内,我们通过了256。 
ranges:强度值范围,通常是 [ 0,256 ]

 plt.plot()函数,矩阵上那些点,第二个参数是设置颜色

plt.xlim()函数,设置x轴长度从0到256,对应plt.ylim().

具体还有很多Matplotlib函数

def hist_image(image):
    color = ("blue", "green", "red")
    for i, color in enumerate(color):
        hist = cv.calcHist([image], [i], None, [256], [0, 256])
        plt.plot(hist, color=color)
        plt.xlim([0, 256])
    plt.show()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wym_king

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值