Python之根据四个坐标确定其位于左上下右上下

python

1、导入模块

import numpy as np

2、存储所需要确定位置的四个坐标点

# 所需要确定位置的四个坐标

coordinate = [[2570, 1948], [2391, 1919], [2411, 1792], [2591, 1821]] # 常规矩形坐标

# coordinate = [[0, 1], [1, 0], [1, 2], [2, 1]] # 非常规(菱形)矩形坐标,用以验证代码

coordinate = np.array(coordinate)

3、求出中心坐标点

center = coordinate[0]

for _ in range(1, 4):

center = center + coordinate[_]

center = center / 4

4、找出x轴小于中心坐标点的点 left_coordinate

coordinate_temp = coordinate.copy() # 复制一份坐标,避免原坐标被破坏

left_coordinate = [] # 存储x轴小于中心坐标点的点

delete_index = []

# 将 x轴小于中心坐标点的点 存储进left_coordinate

for _ in range(4):

if(coordinate[_][0] < center[0]):

left_coordinate.append(coordinate[_])

delete_index.append(_)

# 将存储进 left_coordinate 的元素从coordinate_temp中删除

coordinate_temp = np.delete(coordinate_temp, delete_index, axis=0)

5、确定四个坐标所处位置 "left_top", "right_top", "right_bottom", "left_bottom"

思路:
若 len(left_coordinate) == 2:
比较left_coordinate中的坐标,其y轴小于中心坐标点的,确定为 左下,另一个确定为左上
比较coordinate_temp中的坐标,其y轴小于中心坐标点的,确定为 右下,另一个确定为右上
若 len(left_coordinate) == 1:
确定该点为左下
比较coordinate_temp中的坐标,找出其x轴大于中心坐标点的,确定为右上,并删除该点,
比较剩下两点的y轴,大的确定为左上,小的确定为右下

left_coordinate_temp = left_coordinate.copy() # 避免程序过程因为left_coordinate的变动而导致最初的条件判断错误

if(len(left_coordinate_temp) == 2):

delete_index = []

for _ in range(2):

if(left_coordinate[_][1] < center[1]):

left_bottom = left_coordinate[_]

delete_index.append(_)

break

left_coordinate = np.delete(left_coordinate, delete_index, axis=0)

left_top = left_coordinate[0]

for _ in range(2):

if(coordinate_temp[_][1] < center[1]):

right_bottom = coordinate_temp[_]

coordinate_temp = np.delete(coordinate_temp, [_], axis=0)

break

right_top = coordinate_temp[0]

elif(len(left_coordinate_temp) == 1):

left_bottom = left_coordinate[0]

delete_index = []

for _ in range(3):

if(coordinate_temp[_][0] == center[0] and coordinate_temp[_][1] > center[1]):

left_top = coordinate_temp[_]

delete_index.append(_)

if(coordinate_temp[_][0] == center[0] and coordinate_temp[_][1] < center[1]):

right_bottom = coordinate_temp[_]

delete_index.append(_)

coordinate_temp = np.delete(coordinate_temp, delete_index, axis=0)

right_top = coordinate_temp[0]

6、检验定位效果

print(left_top, right_top)

print(left_bottom, right_bottom)

运行结果:

以上是 Python之根据四个坐标确定其位于左上下右上下 的全部内容, 来源链接: utcz.com/z/529871.html

回到顶部