Python 之Opencv的Numpy函数:矩形框四个顶点顺时针排序

学习目标

       图像处理可以简单理解为对数据处理的过程,针对图像中一个矩形区域给出的4个顶点坐标,按照固定顺序对4个顶点坐标进行顺时针排序。坐标的这种排序方式是进行透视变换、匹配对象角点、计算距离等操作的基础。

函数条件

       定义order_points(pts)这个函数主要目的是按照顺时针顺序排列(左下、左上、右上、右下)与矩形边界框相关联的(x,y)坐标。

       关于函数的输入pts:只需要一个参数——我们想要排序的点列表。

函数详解

       1. np.argsort()是将X中的元素从小到大排序后,提取对应的索引index,然后输出到ypts[:, 0]第一维度的第0行至最后一行;

sort_x = pts[np.argsort(pts[:, 0]), :]

以一维数组为例:

>>>x=np.array([1,3,2,-1,6,9])
>>>x.argsort()的结果:
>>>array([3,0,2,1,4,5)]

axis=0按列排序,axis=1按行排序。以二维数组为例:

>>> x = np.array([[0, 3], [2, 2]])
>>> np.argsort(x, axis=0)
    array([[0, 1],
         [1, 0]])
>>> np.argsort(x, axis=1)
    array([[0, 1],
    [0, 1]])

np.argsort (x)按升序排列,np.argsort(-x) #按降序。排列通过索引值排序后的数组:

>>>x = np.array([3, 1, 2])
>>> x[np.argsort(x)]
    array([1, 2, 3])
>>>x[np.argsort(-x)]
   array([3, 2, 1])

      2. np.concatenate()函数能够一次完成多个数组的拼接,后面的axis=0指的是沿垂直方向拼接,axsi=1指的是按水平方向拼接;

np.concatenate((Left, Right), axis=0)

对于一维数组拼接,axis的值不影响最后的结果。以一维数组为例:

>>> a=np.array([5,7,3])
>>> b=np.array([101,2,133])
>>> c=np.array([56,12,39])
>>> np.concatenate((a,b,c),axis=0)的结果:
array([ 5,7,3,101,2,133,56,12,39])

对于二维数组拼接,axis=0表示沿着数组垂直方向进行拼接,axis=1表示沿着数组水平方向进行拼接,以二维数组为例:

>>> a=np.array([[5,7,3],[ 101,2,133]])
>>> b=np.array([[56,12,39],[27,108,99]])
>>> np.concatenate((a,b),axis=0)
array([[ 5,7,3],
       [ 101,2,133],
       [56,12,39],
       [ 27,108,99]])
>>> np.concatenate((a,b),axis=1)
array([[ 5,7,3, 101,2,133],
       [ 56,12,39, 27,108,99]])

具体代码

def order_points(pts):
    #  根据x坐标对进行从小到大的排序
    sort_x = pts[np.argsort(pts[:, 0]), :]
    #  根据点x的坐标排序分别获取所有点中,位于最左侧和最右侧的点
    Left = sort_x[:2, :]
    Right = sort_x[2:, :]
    # 根据y坐标对左侧的坐标点进行从小到大排序,这样就能够获得左下角坐标点与左上角坐标点
    Left = Left[np.argsort(Left[:, 1])[::-1], :]
    # 根据y坐标对右侧的坐标点进行从小到大排序,这样就能够获得右上角坐标点与右下角坐标点
    Right = Right[np.argsort(Right[:, 1]), :]
        return np.concatenate((Left, Right), axis=0)

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 OpenCV 中的 `warpAffine()` 函数来根据最小外接矩形的四个顶点划分一个 ROI 区域。 具体步骤如下: 1. 根据最小外接矩形的四个顶点,计算出旋转矩阵和变换矩阵。 ```python import cv2 import numpy as np # 假设四个点的坐标为 rect rect = np.array([(x0, y0), (x1, y1), (x2, y2), (x3, y3)], dtype=np.float32) # 计算最小外接矩形的中心点和大小 rect_center, rect_size, rect_angle = cv2.minAreaRect(rect) # 计算旋转矩阵和变换矩阵 M = cv2.getRotationMatrix2D(rect_center, rect_angle, 1) ``` 2. 将 ROI 区域的四个顶点坐标进行仿射变换,得到变换后的坐标。 ```python # 定义 ROI 区域的四个顶点坐标 roi_rect = np.array([(x0, y0), (x1, y1), (x2, y2), (x3, y3)], dtype=np.float32) # 进行仿射变换 roi_rect_transformed = cv2.transform(np.array([roi_rect]), M)[0] ``` 3. 根据变换后的坐标,计算出 ROI 区域的左上角坐标和大小。 ```python # 计算变换后的坐标的最大值和最小值 x_min, y_min = roi_rect_transformed.min(axis=0) x_max, y_max = roi_rect_transformed.max(axis=0) # 计算 ROI 区域的左上角坐标和大小 roi_x, roi_y = int(x_min), int(y_min) roi_w, roi_h = int(x_max - x_min), int(y_max - y_min) ``` 4. 利用 `warpAffine()` 函数进行 ROI 区域的截取。 ```python # 读取原图像 img = cv2.imread('your_image_path') # 利用 warpAffine() 函数进行变换 roi_img = cv2.warpAffine(img, M, (img.shape[1], img.shape[0])) # 截取 ROI 区域 roi = roi_img[roi_y:roi_y+roi_h, roi_x:roi_x+roi_w] ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值