OpenCV图像相似度检测

# OpenCV图像相似度检测matchTemplate,Python实现
import cv2 as cv

if __name__ == "__main__":
    # 先把图片灰度处理。
    img = cv.imread('test.jpg')
    img_gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)

    template = cv.imread('obj.jpg')
    template_gray = cv.cvtColor(template, cv.COLOR_BGR2GRAY)
    h, w = template.shape[:2]

    # 匹配
    result = cv.matchTemplate(img_gray, template_gray, cv.TM_CCOEFF_NORMED)

    min_val, max_val, min_loc, max_loc = cv.minMaxLoc(result)
    print(max_val)
    print(min_val)

    # max_loc为左上角
    # 右下角
    right_bottom = (max_loc[0] + w, max_loc[1] + h)

    # 画矩形,红色的线框出来。
    cv.rectangle(img=img, pt1=max_loc, pt2=right_bottom, color=(0, 0, 255), thickness=3)

    cv.imshow('result', img)
    cv.waitKey(0)
    cv.destroyAllWindows()

注意 小图要在原图上截取 保持像素一致

第二种:

猜你喜欢

转载自blog.csdn.net/xkx_07_10/article/details/109038812
今日推荐