qt绘制曲线

#pragma once

#include <QWidget>

#include <QPainter>

#include <QPainterPath>

#include <QMouseEvent>

#include <QVector>

class CurveWidget : public QWidget {

Q_OBJECT

public:

CurveWidget(QWidget* parent = nullptr) : QWidget(parent), lastPoint(QPointF()) {}

protected:

void mousePressEvent(QMouseEvent* event) override {

if (event->button() == Qt::LeftButton) {

lastPoint = event->pos();

points.clear();

points.append(lastPoint);

update();

}

}

void mouseMoveEvent(QMouseEvent* event) override {

if (event->buttons() & Qt::LeftButton) {

QPointF newPoint = event->pos();

if ((newPoint - lastPoint).manhattanLength() > 0) { // 避免绘制过于密集的点

points.append(newPoint);

lastPoint = newPoint;

update();

}

}

}

void paintEvent(QPaintEvent* event) override {

QPainter painter(this);

painter.setRenderHint(QPainter::Antialiasing);

QPainterPath path;

if (!points.isEmpty()) {

path.moveTo(points.first());

for (int i = 1; i < points.size(); ++i) {

// 这里我们仍然使用lineTo来连接点,但为了视觉效果,你可以在最终渲染时应用平滑算法

path.lineTo(points[i]);

// 绘制点

painter.setPen(Qt::NoPen);

painter.setBrush(Qt::red);

painter.drawEllipse(points[i], 3, 3); // 绘制以点为中心,半径为3的小圆

}

// 如果需要绘制平滑曲线,这里应该使用cubicTo或quadTo,并计算控制点

painter.setPen(QPen(Qt::blue, 2));

painter.setBrush(Qt::transparent);

painter.drawPath(path);

}

}

private:

QVector<QPointF> points;

QPointF lastPoint;

};

// 使用方法同前

// CurveWidget *widget = new CurveWidget();

// widget->show();

相关推荐
小短腿的代码世界1 小时前
QCefView深度解析:Qt应用中嵌入Chromium浏览器的终极方案
开发语言·qt
小短腿的代码世界5 小时前
VLC-Qt深度解析:Qt应用中的专业视频播放方案
开发语言·qt
rrr26 小时前
【前端开发】|GUI 基本概念和框架基础
前端·qt
Z文的博客6 小时前
【避坑实录】Qt 4.8.6 + Paho MQTT C客户端 + OpenSSL静态链接的血泪史
c语言·开发语言·qt·嵌入式linux
(Charon)6 小时前
【C++/Qt】Qt 实现 TCP Client:从功能构思到消息收发与日志保存
qt·网络协议·tcp/ip
qq_283720056 小时前
Qt5.12.8 QML Canvas ctx.setLineDash 失效终极解决方案
开发语言·qt
Z文的博客6 小时前
嵌入式LINUX QT 开发 .gitignore 文件编写指南
linux·git·qt·elasticsearch·嵌入式
掘根7 小时前
【微服务即时通讯】客户端数据中心
qt·微服务·架构
西门吹牛7 小时前
Pycharm编译器中部署了pyqt5,Qtdesigner无法打开了,解决方案
ide·qt·pycharm
buhuizhiyuci7 小时前
[QT]QT入门的项目创建和项目代码的介绍
开发语言·qt