我正在测试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.boundingRect()
的矩形的(x,y,w,h)
值。我的猜测是,保存的黑色矩形是由于将边界框坐标转换为int
类型时出现舍入问题。所以直接解压(x,y,w,h)
坐标,然后使用Numpy切片提取ROI。以下是提取和保存ROI的最低工作示例:输入图像
->
程序提取ROI->
保存的ROI代码
相关问题 更多 >
编程相关推荐