如何正确使用cv2.imwrite在openCV中保存图像

时间:2017-08-29 19:22:56

标签: python opencv numpy scikit-image cv2

我正在尝试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)

有人可以帮忙吗?

1 个答案:

答案 0 :(得分:0)

cv2.selectROI返回类似于(x,y,w,h)的矩形的cv2.boundingRect()值。我的猜测是,将边界框坐标转换为int类型时,保存的黑色矩形是由于取整问题引起的。因此,只需直接解压缩(x,y,w,h)坐标并使用Numpy切片即可提取ROI。这是提取和保存ROI的最小工作示例:

输入图像->提取ROI ->已保存ROI的程序

enter image description here enter image description here enter image description here

代码

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()