当前位置: 首页 > news >正文

Qt+线段拖曳示例代码

Qt线段拖曳示例代码,功能见下图。

代码如下:

canvaswidget.h

#ifndef CANVASWIDGET_H
#define CANVASWIDGET_H#include <QWidget>
#include <QPainter>
#include <QMouseEvent>
#include <QVector>class CanvasWidget : public QWidget
{Q_OBJECT
public:explicit CanvasWidget(QWidget *parent = nullptr);protected:void paintEvent(QPaintEvent* event)override;void mousePressEvent(QMouseEvent* event)override;void mouseMoveEvent(QMouseEvent* event)override;void mouseReleaseEvent(QMouseEvent* event)override;
private:bool isPointValid(QPoint point)const;QPoint constrainPoint(QPoint point)const;
signals:
private:QVector<QPoint> points;int selectedPointIndex = -1;
};#endif // CANVASWIDGET_H

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>class CanvasWidget;class MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();private:CanvasWidget* canvas;
};
#endif // MAINWINDOW_H

canvas.widget.cpp

#include "canvaswidget.h"
#include <QLinearGradient>
#include <QDebug>CanvasWidget::CanvasWidget(QWidget *parent): QWidget{parent}
{points << QPoint(50,50)<<QPoint(200,200);setMouseTracking(true);setStyleSheet("background-color:#e6f7ff;");
}void CanvasWidget::paintEvent(QPaintEvent *event)
{Q_UNUSED(event);QPainter painter(this);painter.setRenderHint(QPainter::Antialiasing);QLinearGradient gradient(0, 0, width(), height());gradient.setColorAt(0, QColor(230, 247, 255));gradient.setColorAt(1, QColor(210, 235, 255));painter.fillRect(rect(), gradient);QPen linePen(QColor(75,175,240), 3, Qt::SolidLine,Qt::RoundCap, Qt::RoundJoin);// painter.drawLines(points);for(int i=1, c=points.size(); i<c; i++){painter.drawLine(points[i-1], points[i]);}QBrush pointBrush(QColor(255, 153, 153));painter.setBrush(pointBrush);for(const auto& point: points){painter.drawEllipse(point, 7, 7);}}void CanvasWidget::mousePressEvent(QMouseEvent *event)
{if(event->button() == Qt::RightButton){points << QPoint(event->pos());update();}else if(event->button() == Qt::LeftButton){for(int i=0; i<points.size(); i++){const auto& point = points[i];if((event->pos() - point).manhattanLength()<15){selectedPointIndex = i;break;}}}}void CanvasWidget::mouseMoveEvent(QMouseEvent *event)
{if(selectedPointIndex != -1){points[selectedPointIndex] = constrainPoint(event->pos());update();}
}void CanvasWidget::mouseReleaseEvent(QMouseEvent *event)
{Q_UNUSED(event);selectedPointIndex = -1;qDebug() << "pos:" << event->pos();
}bool CanvasWidget::isPointValid(QPoint p) const
{return p.x()>=0 && p.y() >=0 && p.x()<width() && p.y()<height();
}QPoint CanvasWidget::constrainPoint(QPoint p) const
{int x = p.x(), y = p.y();x = fmin(x, width());x = fmax(x, 0);y = fmin(y, height());y = fmax(y, 0);return QPoint(x, y);
}

mainwindow.cpp

#include "mainwindow.h"
#include "canvaswidget.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent)
{setFixedSize(600, 400);setStyleSheet("background-color:#ffffff;");setWindowTitle("drag_line");canvas = new CanvasWidget(this);canvas->setGeometry(50, 50, 500, 300);
}MainWindow::~MainWindow()
{}

main.cpp

#include "mainwindow.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);MainWindow w;w.show();return a.exec();
}

相关文章:

  • Qt功能区:Ribbon控件
  • 在 Qt 中实现动态切换主题(明亮和暗黑)
  • Dify的大语言模型(LLM) AI 应用开发平台-本地部署
  • 基于Qt的app开发第十天
  • 微软 Build 2025:开启 AI 智能体时代的产业革命
  • QT中信号和事件的区别
  • 精益制造数字化转型智能工厂三年规划建设方案
  • 《算法笔记》11.8小节——动态规划专题->总结 问题 G: 点菜问题
  • 工具环境与系统部署
  • React中使用 Ant Design Charts 图表
  • 【人工智能发展史】从黎明到曙光01
  • 精益数据分析(75/126):用户反馈的科学解读与试验驱动迭代——Rally的双向验证方法论
  • react中运行 npm run dev 报错,提示vite.config.js出现错误 @esbuild/win32-x64
  • PHP伪随机数
  • Java Collection(集合) 接口
  • windows powershell 判断 进程号是否存在
  • OS进程调度
  • LeetCode 3355.零数组变换 I:差分数组
  • Java课堂笔记7
  • php://filter的trick
  • 网站代运营性价比高/网站建设的重要性
  • java做网站访问量并发/app推广引流方法
  • 政府单位建设网站的申请报告/推广方案策略怎么写
  • 做黄金的人喜欢逛那些网站/如何优化网络连接
  • 衡水注册公司流程和费用/独立站seo
  • 如何做网站的教程视频/收录入口在线提交