问题描述:
如何识别图片中形状中的轮廓,并绘制出所有轮廓。
问题解答:
第一种方法:
import numpy as np
import cv2
# 读取图像
img = cv2.imread('luokuoxian.png')
# 转换为灰度图
imgray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 二值化
ret, thresh = cv2.threshold(imgray, 127, 255, 0)
# 查找轮廓
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
# 绘制轮廓
img = cv2.drawContours(img, contours, -1, (0, 255, 0), 3)
# 显示绘制出的轮廓线
cv2.imshow('Contours', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
第二种方法:
import numpy as np
import cv2
# 读取图像
img = cv2.imread('luokuoxian.png')
# 转换为灰度图
imgray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 二值化
ret, thresh = cv2.threshold(imgray, 127, 255, 0)
# 查找轮廓
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
# 绘制所有轮廓
for i in range(len(contours)):
img = cv2.drawContours(img, contours, i, (0, 255, 0), 2)
# 显示绘制出的轮廓线
cv2.imshow('Contours', img)
cv2.waitKey(0)
cv2.destroyAllWindows()