Qt widget显示曲线

Qt通过widget显示曲线,需要下载charts插件。然后在pro文件进行引用。

cpp 复制代码
QT += charts

一般在开始安装的时候,我们就要选择charts组件安装,否则,我们在引用的时候就会报错。

接下来我们开始画出曲线新建一个chart对象,创建QLineSeries对象

cpp 复制代码
QChart *chart = new QChart();

        // 创建一个QLineSeries对象,用于绘制线性图
    QLineSeries *series1 = new QLineSeries();
    QLineSeries *series2 = new QLineSeries();
cpp 复制代码
series1->append(QPointF(1, 2));

series添加点,

cpp 复制代码
chart->addSeries(series1);
        chart->addSeries(series2);

        series1->setName("电压曲线");
        series2->setName("电流曲线");
        chart->createDefaultAxes();
        //chart->axes(Qt::Horizontal)[0]->setRange(0, 10); // 设置X轴范围
        //chart->axes(Qt::Vertical)[0]->setRange(0, 10);   // 设置Y轴范围
        chart->setAxisX(new QValueAxis());
        chart->setAxisY(new QValueAxis());
        //chart->setAxisX(new QValueAxis(),series2);
        //chart->setAxisY(new QValueAxis(),series2);
        series1->attachAxis(chart->axes(Qt::Horizontal)[0]);
        series2->attachAxis(chart->axes(Qt::Horizontal)[0]);
        series1->attachAxis(chart->axes(Qt::Vertical)[0]);
        series2->attachAxis(chart->axes(Qt::Vertical)[0]);
        chart->axisY()->setTitleText("Y轴标签");
        chart->axisX()->setTitleText("X轴标签");
QChartView* chartView = new QChartView(chart);
        //ui->widget->layout()->removeWidget(chartView);
        chartView->setRenderHint(QPainter::Antialiasing);

        // 将QChartView设置为QWidget的子部件

        ui->widget_2->setLayout(layout);
        ui->widget_2->layout()->addWidget(chartView);

这样我们就画出曲线图了,演示界面如下:

为了实现每次点击按钮都是最新的图像,所以我们需要清空widget。

实现代码如下:

cpp 复制代码
QList<QWidget *> children = ui->widget_2->findChildren<QWidget *>();

        // 删除所有子控件
        foreach (QWidget *child, children) {
            // 不包括自己
            if (child != ui->widget_2) {
                child->deleteLater();
            }
        }

这样我们就实现了每次点击按钮,都可以实现当下的图像。

相关推荐
徒步僧1 小时前
ThingsBoard规则链节点:RPC Call Reply节点详解
qt·microsoft·rpc
可峰科技2 小时前
斗破QT编程入门系列之一:认识Qt:初步使用(四星斗师)
开发语言·qt
我喜欢就喜欢3 小时前
基于qt vs下的视频播放
开发语言·qt·音视频
CP-DD3 小时前
Qt的架构设计
qt
阿_旭4 小时前
基于YOLO11/v10/v8/v5深度学习的维修工具检测识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
人工智能·python·深度学习·qt·ai
Bruce小鬼8 小时前
QT创建按钮篇
开发语言·qt
martian6659 小时前
QT开发:掌握现代UI动画技术:深入解析QML和Qt Quick中的动画效果
开发语言·c++·qt·ui
墨染新瑞12 小时前
两个有趣的小东西(qt和类型转换)
开发语言·网络·qt
Bruce小鬼12 小时前
解决MAC安装QT启动项目不显示窗口问题
开发语言·qt·macos
云雨歇16 小时前
Qt学习笔记(三)网络编程
笔记·qt·学习