我正在尝试OpenCV的ROI功能。以此,我试图裁剪出我加载的图像的一部分。之后,我尝试保存图像并显示它。显示它不是什么大问题,但是保存它就可以了。图像被存储为一个大的黑色矩形,而不是实际的裁剪图像。这是我的代码:
import cv2
import numpy as np
from skimage.transform import rescale, resize
if __name__ == '__main__' :
# Read image
im = cv2.imread("/Path/to/Image.jpg")
img = resize(im, (400,400), mode='reflect')
# Select ROI
r = cv2.selectROI(img)
# Crop image
imCrop = img[int(r[1]):int(r[1]+r[3]), int(r[0]):int(r[0]+r[2])]
# Save first, then Display cropped image
cv2.imwrite("../../Desktop/Image.jpg", imCrop) # This is where there seems to be a problem
cv2.imshow("im", imCrop)
cv2.waitKey(0)
有人可以帮忙吗?
最佳答案
cv2.selectROI
返回类似于(x,y,w,h)
的矩形的cv2.boundingRect()
值。我的猜测是,将边界框坐标转换为int
类型时,保存的黑色矩形是由于取整问题引起的。因此,只需直接解压缩(x,y,w,h)
坐标,然后使用Numpy切片即可提取ROI。这是提取和保存ROI的最小工作示例:
输入图像->
程序以提取ROI ->
保存的ROI
代码
import cv2
image = cv2.imread('1.jpg')
(x,y,w,h) = cv2.selectROI(image)
ROI = image[y:y+h, x:x+w]
cv2.imshow("ROI", ROI)
cv2.imwrite("ROI.png", ROI)
cv2.waitKey()
关于python - 如何正确使用cv2.imwrite使用cv2.selectROI将图像保存在openCV中,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45946873/