Python 3阵列,反转多边形点

时间:2018-10-22 10:31:19

标签: python arrays coordinates points

我有一个坐标列表,但是x,y坐标不在一个元组中:

width,height = 100
#my_list = (x1, y1, x2, y2, ...)
#my_list = (0, 50, 50, 0, 50, 100)
my_list = (0, height/2, width/2, 0, width/2, height)

这些点可以创建多边形。在我的情况下,三角形填充了100x100区域的一半,并指向左侧。

我正试图反转(水平)三角形,以使其指向右侧,因此解决方案是:

my_list = (width, height/2, width/2, 0, width/2, height)

但是我在考虑应该如何制作一个能够水平反转任何多边形的函数?像这样:

my_list = (0, height/2, width/2, 0, width/2, height)
invert_horizontally(my_list, width, height)
>>> (100, 50, 50, 0, 50, 100)

我认为,要反转点,我必须做这样的事情:

for point in my_list:
    if this point is x:
        new_x = width - point
    else:
        pass

这是我的问题:如何确定关键点是X。还要如何用此代码创建单线?

编辑:

到目前为止,我的代码:

new_list = [ @@@-point for point in my_list ]

现在@@@必须根据点是x还是y进行更改。

编辑#2:

基本上,我需要为每个偶数“点”都做一个宽度点

2 个答案:

答案 0 :(得分:1)

您知道这些点是作为x, y值顺序存储在列表中的。因此,您知道所有x都处于偶数位置。一个班轮可能是:

inverted_triangle = [width-coord if i % 2 == 0 else coord for i, coord in enumerate(triangle)]

答案 1 :(得分:0)

您可以使用my_listzip与其自身进行迭代,以将x和y坐标配对,并分别使用x和y的计算来获得反坐标:

def invert_horizontally(my_list, width, height):
    i = iter(my_list)
    return [coord for x, y in zip(i, i) for coord in (width - x, y)]

以使您可以输入示例,

invert_horizontally(my_list, width, height)

返回:

[100, 50, 50, 0, 50, 100]