cv2.calcHist() 是 OpenCV 中用于计算直方图的函数。它可以计算一维或多维直方图,用于分析图像中像素值的分布。
基本的语法如下:
hist = cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])
参数说明:
images: 输入图像,可以是单通道或多通道图像。在计算多通道图像的直方图时,要将通道分别传递给channels参数。channels: 要考虑的通道的索引,对于灰度图像,通常是[0],对于彩色图像,可以指定[0]、[1]、[2]分别对应蓝色、绿色、红色通道。mask: 可选参数,用于指定计算直方图的区域。如果不指定,整个图像将被考虑。histSize: 表示每个通道的直方图槽(bin)的数量,对于灰度图像通常是[256],对于彩色图像可以设置不同通道的槽的数量。ranges: 表示像素值的范围,通常为[0, 256]。hist: 输出的直方图,如果不提供,则函数会创建一个。accumulate: 可选参数,如果设置为True,则直方图在多次计算时不会被清零,而是累积起来。
以下是一个简单的示例,演示如何计算一幅灰度图像的直方图:
import cv2
import matplotlib.pyplot as plt
# 读取灰度图像
img = cv2.imread( r"C:\Users\mzd\Desktop\opencv\2.jpg", cv2.IMREAD_GRAYSCALE)
# 计算直方图
hist = cv2.calcHist([img], [0], None, [256], [0, 256])
# 绘制直方图
plt.plot(hist)
plt.title('Histogram')
plt.xlabel('Pixel Value')
plt.ylabel('Frequency')
plt.show()
# 显示原始图像
cv2.imshow('Image', img)
# 等待用户按下任意键
cv2.waitKey(0)
cv2.destroyAllWindows()


在这个示例中,cv2.calcHist() 函数计算了一幅灰度图像的直方图,然后使用 Matplotlib 绘制了直方图。










