传统目标检测方法步骤记录
import cv2
import math
import numpy as np
def Img_Outline(input_dir):
original_img = cv2.imread(input_dir)
gray_img = cv2.cvtColor(original_img, cv2.COLOR_BGR2GRAY)
blurred = cv2.GaussianBlur(gray_img, (5, 5), 0)
_, RedThresh = cv2.threshold(blurred, 50, 255, 0)
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))
closed = cv2.morphologyEx(RedThresh, cv2.MORPH_CLOSE, kernel)
opened = cv2.morphologyEx(closed, cv2.MORPH_OPEN, kernel)
return original_img, gray_img, RedThresh, closed, opened
def findContours_img(original_img, opened):
contours, hierarchy = cv2.findContours(opened, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
c = sorted(contours, key=cv2.contourArea, reverse=True)[1]
rect = cv2.minAreaRect(c)
box = np.int0(cv2.boxPoints(rect))
draw_img = cv2.drawContours(original_img.copy(), [box], -1, (0, 0, 255), 50)
print("box[0]:", box[0])
print("box[1]:", box[1])
print("box[2]:", box[2])
print("box[3]:", box[3])
return box,draw_img
def Perspective_transform(box,original_img):
orignal_W = math.ceil(np.sqrt((box[3][1] - box[2][1])**2 + (box[3][0] - box[2][0])**2))
orignal_H= math.ceil(np.sqrt((box[3][1] - box[0][1])**2 + (box[3][0] - box[0][0])**2))
pts1 = np.float32([box[0], box[1], box[2], box[3]])
pts2 = np.float32([[int(orignal_W+1),int(orignal_H+1)], [0, int(orignal_H+1)], [0, 0], [int(orignal_W+1), 0]])
M = cv2.getPerspectiveTransform(pts1, pts2)
result_img = cv2.warpPerspective(original_img, M, (int(orignal_W+3),int(orignal_H+1)))
return result_img
if __name__=="__main__":
input_dir = "./ori/11.png"
original_img, gray_img, RedThresh, closed, opened = Img_Outline(input_dir)
box, draw_img = findContours_img(original_img,opened)
result_img = Perspective_transform(box,original_img)
name_im = '_11'
cv2.imwrite('result_img'+name_im+'.png', result_img)
cv2.imwrite('draw_img'+name_im+'.png', draw_img)
cv2.imwrite('gray'+name_im+'.png', gray_img)
cv2.imwrite('closed'+name_im+'.png', closed)
cv2.imwrite('opened'+name_im+'.png', opened)
cv2.namedWindow('original',cv2.WINDOW_NORMAL)
cv2.namedWindow('gray',cv2.WINDOW_NORMAL)
cv2.namedWindow('closed',cv2.WINDOW_NORMAL)
cv2.namedWindow('opened',cv2.WINDOW_NORMAL)
cv2.namedWindow('draw_img',cv2.WINDOW_NORMAL)
cv2.namedWindow('result_img',cv2.WINDOW_NORMAL)
cv2.imshow("original", original_img)
cv2.imshow("gray", gray_img)
cv2.imshow("closed", closed)
cv2.imshow("opened", opened)
cv2.imshow("draw_img", draw_img)
cv2.imshow("result_img", result_img)
cv2.waitKey(0)
cv2.destroyAllWindows()