gpt4 book ai didi

Python沿着三角形的每条边反射图像

转载 作者:行者123 更新时间:2023-12-01 04:37:54 26 4
gpt4 key购买 nike

我创建了一个位于屏幕中心的三角形。

enter image description here

from PIL import Image, ImageDraw
GRAY = (190, 190, 190)
im = Image.new('RGBA', (400, 400), WHITE)
points = (250, 250), (100, 250), (250, 100)
draw = ImageDraw.Draw(im)
draw.polygon(points, GRAY)

如何复制此图像并在不同的随机点沿着三角形的每条边反射它。例如...

enter image description here

最佳答案

计划:首先在大三角形的边缘找到一个随机点来放置较小的三角形,然后旋转它,使其正确贴合边缘。

假设我们可以用这样的方法访问三角形的点

triangle.edges[0].x, 
triangle.edges[0].y,
triangle.edges[1].x,
etc

然后,我们可以通过首先选择一条边来找到任意点,然后“步行到下一条边的随机距离”:

r = randInt(3) # random integer between 0 and 2
first_edge = triangle.edges[r]
second_edge = r == 2 ? triangle.edges[0] : triangle.edges[r + 1]

## The next lines is kind of pseudo-code
r = randFloat(1)
random_point = (second_edge - first_edge)*r + first_edge

我们的下一个问题是如何旋转三角形。如果您学过一些代数,您可能会认识到这一点:

def rotatePointAroundOrigin(point, angle):
new_point = Point()
new_point.x = cos(angle)*point.x - sin(angle)*point.y
new_point.y = sin(angle).point.x + cos(angle)*point.y
return new_point

(参见 https://en.wikipedia.org/wiki/Rotation_matrix )

除此之外,您还需要确定三角形的旋转程度,然后将上面的函数应用于所有点。

关于Python沿着三角形的每条边反射图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31408797/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com