Qt鼠标拖动线条组成的多边形移动

2024-07-21 1058阅读

实现在鼠标按下线条时可以拖动整个图形的功能,可以按照以下步骤进行:

Qt鼠标拖动线条组成的多边形移动
(图片来源网络,侵删)
  1. 记录顶点:定义一个顶点列表,存储多边形的每个顶点。

  2. 检测鼠标按下:在mousePressEvent中,检测鼠标是否在多边形的任意一条边上。

  3. 记录按下的顶点:如果鼠标在线上,记录下被按下的顶点的索引。

  4. 计算偏移量:在鼠标按下时,计算鼠标位置和被按下顶点之间的偏移量。

  5. 移动顶点:在mouseMoveEvent中,如果鼠标按钮保持按下状态,则根据鼠标的当前位置和之前计算的偏移量更新顶点的位置。

  6. 重绘图形:在顶点移动后,调用update方法来请求重绘控件。

  7. 结束拖动:在mouseReleaseEvent中,结束拖动操作。

    #include 
    #include 
    #include 
    #include 
    #include 
    #include 
    class MovablePolygon : public QWidget {
        Q_OBJECT
    public:
        MovablePolygon(QWidget *parent = nullptr) : QWidget(parent),
            dragging(false), currentPointIndex(-1), dragOffset(0, 0) {
            // 初始化多边形顶点
            points pos() - points[0];
                }
            }
        }
        void mouseMoveEvent(QMouseEvent *event) override {
            if (dragging && event->buttons() & Qt::LeftButton) {
                if (currentPointIndex != -1) {
                    points[currentPointIndex] = event->pos() - dragOffset;
                } else {
                    // 移动整个多边形
                    for (int i = 0; i pos() - dragOffset;
                    }
                }
                update(); // 重绘控件
            }
        }
        void mouseReleaseEvent(QMouseEvent *event) override {
            if (event->button() == Qt::LeftButton) {
                dragging = false;
                currentPointIndex = -1;
            }
        }
    private:
        bool dragging;
        int currentPointIndex;
        QPoint dragOffset;
        QVector points;
        bool isPointOnLine(const QPointF &point, const QPointF &lineStart, const QPointF &lineEnd, double tolerance) {
            double dist = qAbs((lineEnd.y() - lineStart.y()) * point.x()
                                - (lineEnd.x() - lineStart.x()) * point.y()
                                + lineEnd.x() * lineStart.y()
                                - lineEnd.y() * lineStart.x());
            double lineLength = QLineF(lineStart, lineEnd).length();
            return dist = qAbs(point.x() - lineStart.x());
        }
    };
    #include "MovablePolygon.moc" // 确保包含moc文件

    在这个示例中,MovablePolygon类是一个自定义的QWidget,它包含一个多边形顶点列表points。我们重写了paintEvent来绘制多边形,重写了鼠标事件来处理拖动逻辑。isPointOnLine函数用于检测鼠标点击是否在多边形的边上,如果检测到鼠标在线上,就记录下顶点索引和偏移量,并在鼠标移动时更新顶点位置。

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]