我有一个坐标列表,但是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:
基本上,我需要为每个偶数“点”都做一个宽度点
答案 0 :(得分:1)
您知道这些点是作为x, y
值顺序存储在列表中的。因此,您知道所有x
都处于偶数位置。一个班轮可能是:
inverted_triangle = [width-coord if i % 2 == 0 else coord for i, coord in enumerate(triangle)]
答案 1 :(得分:0)
您可以使用my_list
,zip
与其自身进行迭代,以将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]