1

我在屏幕上绘制了 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 转换为基础坐标?或者有没有更简单的方法来解决这个问题?

4

1 回答 1

3

如果你想获得 QPolygonF 的顶点,那么你只需要迭代它,因为它是一个 QVector。

from PyQt5.QtCore import QPointF
from PyQt5.QtGui import QPolygonF


def main():
    poly = QPolygonF([QPointF(1, 1), QPointF(0, 10), QPointF(10, 10), QPointF(10, 0)])

    points = [poly[i] for i in range(poly.size())]
    print(points)


if __name__ == "__main__":
    main()

输出:

[PyQt5.QtCore.QPointF(1.0, 1.0), PyQt5.QtCore.QPointF(0.0, 10.0), PyQt5.QtCore.QPointF(10.0, 10.0), PyQt5.QtCore.QPointF(10.0, 0.0)]

更新:

您无法获得多边形的所有点,因为它们是无限的,但您可以映射其中一些,为此您可以使用 QPainterPath:

from PyQt5.QtCore import QPointF
from PyQt5.QtGui import QPolygonF, QPainterPath


def map_n_points_of_polygon(polygon, n):
    path = QPainterPath()
    path.addPolygon(polygon)
    return [path.pointAtPercent(i / (n - 1)) for i in range(n)]


def main():
    poly = QPolygonF([QPointF(1, 1), QPointF(0, 10), QPointF(10, 10), QPointF(10, 0)])

    points = map_n_points_of_polygon(poly, 100)
    print(points)


if __name__ == "__main__":
    main()
于 2021-08-01T17:15:54.000 回答