Numpy:矩形框四个顶点顺时针排序

问题说明

一个矩形有四个顶点,设计一个函数将其进行顺时针排序,并返回。

代码

主要的思路就是先对矩形的四个点,按x方向进行一次排序后分为两组顶点,前两个为一组Left,后两个为一组Right。然后对Left进行排序,确保y值大的在前面;对RIght进行排序,确保y值小的在前面。拼接Left与Right即满足要求。

返回顺序左下、左上、右上、右下

def order_points(pts):
    ''' sort rectangle points by clockwise '''
    sort_x = pts[np.argsort(pts[:, 0]), :]
    
    Left = sort_x[:2, :]
    Right = sort_x[2:, :]
    # Left sort
    Left = Left[np.argsort(Left[:,1])[::-1], :]
    # Right sort
    Right = Right[np.argsort(Right[:,1]), :]
    
    return np.concatenate((Left, Right), axis=0)

测试

img = np.zeros((512, 512, 3), dtype=np.uint8)
pts = np.array([[128,128],[256,256],[256,100],[128,256]], dtype=np.int32)
pts = order_points(pts)
print(pts)

结果

[[128 256]
 [128 128]
 [256 100]
 [256 256]]

另一思路

如果非矩形,但是为凸四边形的话,可以使用这个思路进行设计。选择[x,y]值最小的点(左上角的点),将其与剩余三个点连线,连线后。如果存在一个点在线上方,一个点在线下方。那么线上的点为右上,线下的点为左下,连接点为右下。即可得到正确顺序。

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值