寻找轮廓之前需使用阈值或者canny边缘检测
找到轮廓
python
contours, hierarchy = cv.findContours(thresh, cv.RETR_TREE, cv.CHAIN_APPROX_SIMPLE)
绘制轮廓
第三个参数是轮廓的索引
python
cv.drawContours(img, contours, -1, (0,255,0), 3)
data:image/s3,"s3://crabby-images/feb3c/feb3cff4dbef8333107e3a54d102b0a9d2b65112" alt=""
轮廓面积
python
area = cv.contourArea(cnt)
轮廓周长(弧长)
python
perimeter = cv.arcLength(cnt,True)
轮廓的外接矩形
(1)直角矩形
python
x,y,w,h = cv.boundingRect(cnt)
cv.rectangle(img,(x,y),(x+w,y+h),(0,255,0),2)
(2)旋转矩形
data:image/s3,"s3://crabby-images/bf3b9/bf3b99ddd550608d1dd10bec41763a6527081e81" alt=""
data:image/s3,"s3://crabby-images/64749/64749b7eea991e94dc0d86d7c8d6b44e12abeb25" alt=""
轮廓形状匹配
data:image/s3,"s3://crabby-images/46122/46122dc4794c0cc1629c6fabf8fab4455c4d48eb" alt=""