opencv绘制灰度图的直方图
时间: 2023-06-21 07:24:52 浏览: 99
你可以使用OpenCV中的`calcHist`函数来绘制灰度图的直方图。以下是一个示例代码:
```python
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('image.jpg', 0) # 读取灰度图像
hist = cv2.calcHist([img], [0], None, [256], [0, 256]) # 计算直方图
plt.hist(img.ravel(), 256, [0, 256])
plt.show()
```
在这个示例代码中,我们首先使用`cv2.imread`函数读取一张灰度图像,然后使用`cv2.calcHist`函数计算图像的直方图。`cv2.calcHist`函数的第一个参数是图像,第二个参数是通道索引,这里我们只有一个通道,所以为0。第三个参数是掩码,这里我们没有使用,所以为`None`。第四个参数是直方图的大小,这里我们使用256个bin。最后一个参数是像素值的范围,这里为[0,256]。最后,我们使用`plt.hist`函数绘制直方图并显示出来。
希望这个示例代码可以帮助你绘制灰度图的直方图。
相关问题
opencv绘制灰度直方图c++
OpenCV提供了calcHist()函数来统计图像的直方图,但是需要我们自己进行绘制。calcHist()函数的原型如下所示:
```
void cv::calcHist(const Mat * images, int nimages, const int * channels, InputArray mask, OutputArray hist, int dims, const int * histSize, const float ** ranges, bool uniform = true, bool accumulate = false)
```
在绘制直方图时,可以使用Rectangle函数绘制矩形。通过遍历每个灰度级的像素个数,可以得到矩形的位置和大小。具体的步骤如下:
1. 准备一个全黑背景图作为直方图画布。
2. 遍历每个灰度级的像素个数,并计算矩形的坐标。
3. 使用Rectangle函数绘制矩形,并设置为填充矩形。
以下是一个主函数的调用示例:
```cpp
int main(int argc, char *argv[]) {
Mat src, gray, hist;
src = imread("2.jpg");
cvtColor(src, gray, CV_BGR2GRAY);
GetHist(gray, hist);
ShowHist(hist);
namedWindow("gray");
imshow("gray", gray);
waitKey(0);
return 0;
}
```
请注意,此示例中的函数GetHist和ShowHist是自定义的函数,用于计算和显示直方图。您可以根据需要自行实现这些函数。
python绘制灰度图片直方图-opencv+python 统计及绘制直方图
好的,下面是回答:
要绘制灰度图片的直方图,可以使用OpenCV和Python来进行统计和绘制。
首先,需要读取灰度图像,并使用OpenCV的calcHist函数来计算直方图。代码如下:
```
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('image.jpg', 0)
hist = cv2.calcHist([img],[0],None,[256],[0,256])
```
这里使用了calcHist函数来计算输入图像img的灰度直方图,其中[0]表示只统计一个通道,None表示没有使用掩码,[256]表示直方图的bin数量,[0,256]表示像素值范围。
得到直方图后,可以使用matplotlib的plot函数来绘制直方图。代码如下:
```
plt.hist(img.ravel(),256,[0,256])
plt.show()
```
其中img.ravel()是将灰度图像展平成一维数组,256表示bin数量,[0,256]表示像素值范围。
最终的代码如下:
```
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('image.jpg', 0)
# calculate histogram
hist = cv2.calcHist([img],[0],None,[256],[0,256])
# plot histogram
plt.hist(img.ravel(),256,[0,256])
plt.show()
```
通过这个代码,可以绘制出输入灰度图像的直方图。
阅读全文