1 最小外接圆
函数 cv2.minEnclosingCircle() 可以帮我们找到一个对象的外切圆。 它是所有能够包括对象的圆中面积最小的一个
代码语言:javascript复制(x,y),radius = cv2.minEnclosingCircle(cnt)
center = (int(x),int(y))
radius = int(radius)
img = cv2.circle(img,center,radius,(0,255,0),2)
2 椭圆拟合
使用的函数为 cv2.ellipse(),返回值其实就是旋转边界矩形的内切圆(椭圆)
代码语言:javascript复制ellipse = cv2.fitEllipse(cnt)
im = cv2.ellipse(im,ellipse,(0,255,0),2)
3 直线拟合
我们可以根据一组点拟合出一条直线,同样我们也可以为图像中的白色点 拟合出一条直线
代码语言:javascript复制rows,cols = img.shape[:2]
[vx,vy,x,y] = cv2.fitLine(cnt, cv2.DIST_L2,0,0.01,0.01)
lefty = int((-x*vy/vx) y)
righty = int(((cols-x)*vy/vx) y)
img = cv2.line(img,(cols-1,righty),(0,lefty),(0,255,0),2)