我提取圖像的輪廓,你可以在這裏看到: OpenCV中如何平滑的輪廓線,降低噪音
然而,它有一些噪音。 如何平滑噪音?我做了一個特寫,以更清楚我想要的意思,我用
代碼:
rMaskgray = cv2.imread('redmask.jpg', cv2.CV_LOAD_IMAGE_GRAYSCALE)
(thresh, binRed) = cv2.threshold(rMaskgray, 50, 255, cv2.THRESH_BINARY)
Rcontours, hier_r = cv2.findContours(binRed,cv2.RETR_CCOMP,cv2.CHAIN_APPROX_SIMPLE)
r_areas = [cv2.contourArea(c) for c in Rcontours]
max_rarea = np.max(r_areas)
CntExternalMask = np.ones(binRed.shape[:2], dtype="uint8") * 255
for c in Rcontours:
if((cv2.contourArea(c) > max_rarea * 0.70) and (cv2.contourArea(c)< max_rarea)):
cv2.drawContours(CntExternalMask,[c],-1,0,1)
cv2.imwrite('contour1.jpg', CntExternalMask)
你能發佈用於創建此代碼? –
@MartinEvans編輯! – marco
如果用cv2.CHAIN_APPROX_NONE替換cv2.CHAIN_APPROX_SIMPLE,會發生什麼情況? – tfv