您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:python四个坐标点对图片区域最小外接矩形进行裁剪

51自学网 2021-10-30 22:31:13
  python
这篇教程python四个坐标点对图片区域最小外接矩形进行裁剪写得很实用,希望能帮到您。

在图像裁剪操作中,opencv和pillow两个库都具有相应的函数,但是这两个库中的函数仅仅能对与图片平行的矩形进行裁剪操作,如果想要对目标的最小外接矩形进行裁剪该如何操作呢?如下所示:

具体处理该问题的思路如下:

  • 计算最小外接矩形的四个点的坐标,旋转角度
  • 将原图像进行旋转,旋转角度为最小外接矩形的角度
  • 将四个点的坐标进行映射,求出被旋转后图像的四个点的坐标
  • 利用这四个点对图像进行裁剪

图像原图如下:

1 求出该区域的最小外接矩形,并且得到外接矩形的四个点的坐标和旋转角度。

rect = cv2.minAreaRect(self.contours[0])#rect为[(旋转中心x坐标,旋转中心y坐标),(矩形长,矩形宽),旋转角度]box_origin = cv2.boxPoints(rect)#box_origin为[(x0,y0),(x1,y1),(x2,y2),(x3,y3)]

2 将原图像进行旋转,旋转角度为最小外接矩形的角度,由于防止旋转后目标区域在图像外面,所以我将图像大小扩大为原来的2倍。

M = cv2.getRotationMatrix2D(rect[0],rect[2],1)dst = cv2.warpAffine(rotateimg,M,(2*rotateimg.shape[0],2*rotateimg.shape[1]))

3 将原四个点的坐标做映射,映射到旋转后的区域,得到新的四个点的坐标。

#逆时针旋转def Nrotate(angle,valuex,valuey,pointx,pointy):      angle = (angle/180)*math.pi      valuex = np.array(valuex)      valuey = np.array(valuey)      nRotatex = (valuex-pointx)*math.cos(angle) - (valuey-pointy)*math.sin(angle) + pointx      nRotatey = (valuex-pointx)*math.sin(angle) + (valuey-pointy)*math.cos(angle) + pointy      return (nRotatex, nRotatey)#顺时针旋转def Srotate(angle,valuex,valuey,pointx,pointy):      angle = (angle/180)*math.pi      valuex = np.array(valuex)      valuey = np.array(valuey)      sRotatex = (valuex-pointx)*math.cos(angle) + (valuey-pointy)*math.sin(angle) + pointx      sRotatey = (valuey-pointy)*math.cos(angle) - (valuex-pointx)*math.sin(angle) + pointy      return (sRotatex,sRotatey)#将四个点做映射def rotatecordiate(angle,rectboxs,pointx,pointy):      output = []      for rectbox in rectboxs:        if angle>0:          output.append(Srotate(angle,rectbox[0],rectbox[1],pointx,pointy))        else:          output.append(Nrotate(-angle,rectbox[0],rectbox[1],pointx,pointy))      return outputbox = rotatecordiate(rect[2],box_origin,rect[0][0],rect[0][1])

4 利用四个点坐标进行裁剪,如2中图所示,图像经过旋转后已经变为和图片没有旋转角的图像,经过实验观察旋转后的坐标还是有细微差别,但误差已经在千分点甚至万分点左右,对我们裁剪造成的影响可以忽略不计。

def imagecrop(image,box):      xs = [x[1] for x in box]      ys = [x[0] for x in box]      print(xs)      print(min(xs),max(xs),min(ys),max(ys))      cropimage = image[min(xs):max(xs),min(ys):max(ys)]      print(cropimage.shape)      cv2.imwrite('cropimage.png',cropimage)      return cropimageimagecrop(dst,np.int0(box))

到此,利用4个坐标点对图像进行裁剪操作已经完成。

到此这篇关于python四个坐标点对图片区域最小外接矩形进行裁剪的文章就介绍到这了,更多相关python 图片坐标裁剪内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


Python OpenCV 图像平移的实现示例
拒绝盗图!教你怎么用python给图片加水印
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。