我只是想知道是否可以从 rgb 图像开始使用 opencv 保存灰色 1 channel 图像。
import cv2
bgr_img = cv2.imread('anyrgbimage.jpg')
print(bgr_img.shape) #(x,y,3)
gray_img = cv2.cvtColor(bgr_img,cv2.COLOR_BGR2GRAY)
cv2.imwrite('hopefully_gray_image.jpg',gray_img)
#cv2.imwrite('hopefully_gray_image.jpg',gray_img,[int(cv2.COLOR_BGR2GRAY)])
buh_img = cv2.imread('hopefully_gray_image.jpg')
print(buh_img.shape) #(x,y,3)
我知道我可以在 cv2.imwrite 中添加一些参数,但我不知道是什么。
最佳答案
是的。让我详细说明@Miki's comment你的回答。如果您查看 imread(filename[, flags])
的文档,您将看到默认标志为 cv2.IMREAD_COLOR
,即默认情况下,OpenCV 将加载具有 3 个 channel 的图像(即使它有 1 个或 4 个 channel )。如果您想使用相同的 imread(...)
要加载三 channel 和单 channel 图像,您应该使用标志 cv2.IMREAD_UNCHANGED
.在实践中,这是如何工作的?
import cv2
import numpy as np
img = (np.random.random((300, 300, 3)) * 255.).astype(np.uint8)
# let's save 4 images (color/gray, png/jpg)
cv2.imwrite('img-png-color.png', img) # output size: 270KB
cv2.imwrite('img-png-gray.png', img[:, :, 1]) # output size: 90KB
cv2.imwrite('img-jpg-color.jpg', img) # output size: 109KB
cv2.imwrite('img-jpg-gray.jpg', img[:, :, 1]) # output size: 93KB
有两点需要注意:
现在,如果您使用默认标志读取这些图像中的任何一个,它们将加载为 (300, 300, 3) 的形状。但是,如果您按照@Miki 告诉您的那样继续:
cv2.imread('img-png-color.png', cv2.IMREAD_UNCHANGED).shape # (300, 300, 3)
cv2.imread('img-png-gray.png', cv2.IMREAD_UNCHANGED).shape # (300, 300)
cv2.imread('img-jpg-color.jpg', cv2.IMREAD_UNCHANGED).shape # (300, 300, 3)
cv2.imread('img-jpg-gray.jpg', cv2.IMREAD_UNCHANGED).shape # (300, 300)
因此,实际上,灰度图像被“保存”为单 channel 。
关于python - 如何用opencv为python编写灰色(1 channel )图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54639394/