我在屏幕上绘制了 3 个 QPolygonF,我需要计算一个 QPolygon 的长度在另一个 QPolygon 中的长度。为了说明,黑色多边形内的红色或蓝色多边形的百分比长度:黑色多边形内的紫色线的百分比。
由于我没有紫色线本身,我相信我应该通过在它通过的每个 Y 坐标上取红色和蓝色多边形的值来计算它,并取两者的中点。
但是我不确定这样做的最佳方法是什么:我想将 QPolygonF 本身转换为一系列坐标,然后按照此答案中的说明使用 Shapely Geometry 来计算线条:Python - 返回 y 坐标给定 x 的多边形路径
编辑:值得一提的是,我需要拥有这些多边形的所有外部坐标,而不仅仅是定义它们的角点(红线上的所有点)
多边形被添加为
drawn_polygon = {}
all_polygon_corner_coords = {}
all_polygon_corner_coords["polygon1"] = [QPointF(x,y), ... , QPointF(xn,yn)]
drawn_polygon["polygon1"] = self.ImageDisplayQgraphicsView.scene().QPolygonF(all_polygon_corner_coords.get("polygon1")]
PyQt5 中是否有任何函数可以让我将 QPolygonF 转换为基础坐标?或者有没有更简单的方法来解决这个问题?