错误:(-215:声明失败)函数'cv :: resize'OpenCV中的!ssize.empty()

时间:2020-05-06 09:32:50

标签: opencv

我有这个旧代码,该代码以前曾在Python 2.7中运行良好。我刚刚更新了在python 3.8中运行的代码,但是当我尝试在python 3.8和OpenCV 3.4中执行代码时,出现调整大小错误和警告(如下)!

这是运行此代码所需的两个tif图像的link。 值得注意的是,两个tif图像都与Python代码位于同一文件夹中

import cv2
import matplotlib.pyplot as plt
import numpy as np


## Code for C_preferred Mask and C_images##

## There are three outputs to this code:
#"Block_order_C.PNG"
#"Out_img.PNG" 
#"Output_C.txt"

## Change the image name here

filename_image = '2.tif'
filename_mask = '1.tif'

## OpenCV verison Checking
#print 'OpenCV version used', cv2.__version__
filename = open("Output_C.txt","w")
filename.write("Processing Image : " + str(filename_image) + '\n\n')

## Function to sort the contours : Parameters that you can tune : tolerance_factor and size 0f the image.Here, I have used a fix size of
## (800,800) 

def get_contour_precedence(contour, cols):
    tolerance_factor = 10
    origin = cv2.boundingRect(contour)
    return ((origin[1] // tolerance_factor) * tolerance_factor) * cols + origin[0]

## Loading the colored mask, resizing it to (800,800) and converting it from RGB to HSV space, so that the color values are emphasized
p_mask_c = cv2.cvtColor(cv2.resize(cv2.imread(filename_mask),(800,800)),cv2.COLOR_RGB2HSV);
# Loading the original Image
b_image_1 = cv2.resize(cv2.imread(filename_image),(800,800));

cv2.imshow("c_mask_preferred",p_mask_c)
cv2.waitKey();

# convert the target color to HSV, As our target mask portion to be considered is green. So I have chosen target color to be green
b = 0;
g = 255;
r = 0;

# Converting target color to HSV space

target_color = np.uint8([[[b, g, r]]])
target_color_hsv = cv2.cvtColor(target_color, cv2.COLOR_BGR2HSV)

# boundaries for Hue define the proper color boundaries, saturation and values can vary a lot
target_color_h = target_color_hsv[0,0,0]
tolerance = 20
lower_hsv = np.array([max(0, target_color_h - tolerance), 10, 10])
upper_hsv = np.array([min(179, target_color_h + tolerance), 250, 250])


# apply threshold on hsv image
mask = cv2.inRange(p_mask_c, lower_hsv, upper_hsv)
cv2.imshow("mask",mask)
cv2.waitKey()

# Eroding the binary mask, such that every white portion (grids) are seperated from each other, to avoid overlapping and mixing of
# adjacent grids
b_mask = mask;
kernel = np.ones((5,5))
#kernel = cv2.getStructuringElement(cv2.MORPH_CROSS,(3,3))
sharp = cv2.erode(b_mask,kernel, iterations=2)

# Finding all the grids (from binary image)
contours, hierarchy = cv2.findContours(sharp,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
print (' Number of contours', len(contours))

# Sorting contours
contours.sort(key=lambda x:get_contour_precedence(x, np.shape(b_mask)[0]))
#cv2.drawContours(b_image_1, contours, -1, (0,255,0), 1)

# Label variable for each grid/panel
label = 1;

b_image = b_image_1.copy();
temp =np.zeros(np.shape(b_image_1),np.uint8)
print (' size of temp',np.shape(temp), np.shape(b_image))
out_img = b_image_1.copy()
# Processing in each contour/label one by one
for cnt in contours:
    cv2.drawContours(b_image_1,[cnt],0,(255,255,0), 1)
    ## Just to draw labels in the center of each grid
    ((x, y), r) = cv2.minEnclosingCircle(cnt)
    x = int(x)
    y = int(y)
    r = int(r)    
    cv2.putText(b_image_1, "#{}".format(label), (int(x) - 10, int(y)),cv2.FONT_HERSHEY_SIMPLEX, 0.6, (0, 0, 255), 2)
    ## 
    cv2.drawContours(temp,[cnt],0,(255,255,255), -1)
    #crop_img = np.bitwise_and(b_image,temp)
    r = cv2.boundingRect(cnt)
    crop_img = b_image[r[1]:r[1]+r[3], r[0]:r[0]+r[2]]
    mean = cv2.mean(crop_img);
    mean = np.array(mean).reshape(-1,1)
    print (' Mean color', mean, np.shape(mean))
    if mean[1] < 50:
        cv2.putText(out_img, "M", (int(x) - 10, int(y)),cv2.FONT_HERSHEY_SIMPLEX, 0.6, (255, 0, 255), 1)
        filename.write("Block number #"+ str(label)+ ' is : ' + 'Magenta'+'\n'); 
    else:
        cv2.putText(out_img, "G", (int(x) - 10, int(y)),cv2.FONT_HERSHEY_SIMPLEX, 0.6, (255, 0, 255), 1)
        filename.write("Block number #"+ str(label)+  ' is : ' +'Gray'+'\n'); 
    label = label+1;    


cv2.imwrite("Block_order_C.PNG",b_image_1)
cv2.imwrite("Out_img.PNG",out_img)   
filename.close()   
cv2.imshow("preferred",b_image_1)
cv2.waitKey()

错误

[WARN:0]全局C:\ projects \ opencv-python \ opencv \ modules \ imgcodecs \ src \ grfmt_tiff.cpp(449)cv :: TiffDecoder :: readData OpenCV TIFF:TIFFRGBAImageOK:对不起,无法处理图像与IEEE浮点样本 追溯(最近一次通话): 文件“ Processing_C_preferred.py”,第32行,在 p_mask_c = cv2.cvtColor(cv2.resize(cv2.imread(filename_mask),(800,800)),cv2.COLOR_RGB2HSV); cv2.error:OpenCV(4.2.0)C:\ projects \ opencv-python \ opencv \ modules \ imgproc \ src \ resize.cpp:4045:error:(-215:Assertion failed)!ssize.empty()在函数中'cv :: resize'

1 个答案:

答案 0 :(得分:1)

当您读入图像时,将cv::IMREAD_ANYDEPTH = 2参数作为cv2.imread()中的第二个参数。

将行更改为

p_mask_c = cv2.cvtColor(cv2.resize(cv2.imread(filename_mask, 2),(800,800)),cv2.COLOR_RGB2HSV);

b_image_1 = cv2.resize(cv2.imread(filename_image, 2),(800,800));

消除您看到的调整大小错误。

但是更改颜色时会遇到另一个错误,因为您的TIFF图像显然只有一个通道,所以cv2.COLOR_RGB2HSV无法正常工作。.

您还可以使用多个标志,例如cv::IMREAD_COLOR = 1

p_mask_c = cv2.cvtColor(cv2.resize(cv2.imread(filename_mask, 2 | 1),(800,800)),cv2.COLOR_BGR2HSV);

读取彩色图像。但是,您会得到另一个错误。也许您比我更了解此图像,并且可以从现在开始解决问题。