打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
VS2017中使用QT Chart图表

有关QtChart的介绍在这就不详谈了,想要具体了解的百度就可以,官网和网站大多数都是介绍如何在QtCreator中使用QtChart,而本文主要介绍如何在vs中使用。

使用工具:VS2017+Qt5.13.2

准备工作

首先,安装以下软件:

  1. VS2017.下载安装教程

  2. Qt开发包,最好是qt5.9以上的版本,本篇教程以Qt5.13.2为例讲解

  3. Qt VS Tools插件。

  4. 将上述软件安装完成后,需要在

    VS2017中配置QtVSTools插件,具体过程如下:

    5.添加环境变量:

创建过程:

1、新建一个Qt的gui工程,一路next

2、打开ui文件,在designer中拖动一个widget,并提升窗口部件为QChartView

3、接下来先不要编译,因为我们还没有把QtChart的库文件包含进来,首先打开项目的属性,注意在添加包含目录的时候,要把QtCharts那个路径添加进去,这样ui文件中提升的那个头文件就不会报错

VC++目录->包含目录->添加:

D:\softsetup\qt5.13.2\5.13.2\msvc2017_64\include\QtCharts

D:\softsetup\qt5.13.2\5.13.2\msvc2017_64\include

库目录:

D:\softsetup\qt5.13.2\5.13.2\msvc2017_64\lib

下面添加附加依赖库:

连接器->输入->添加依赖项:Qt5Chartsd.lib

设置完了之后就可以点击确定,并进行编译,此时编译之后会出现错误,这是因为没有写命名空间:

4、那么我们在添加命名空间的时候不要在ui_xxx.h文件里面进行添加,因为这是自动生成的文件,每一次添加新的控件并编译的时候就把你添加的信息给删除掉,这时我们可以添加到刚开始新建的文件中去,见下图;

如果图中的命名空间不能用,(试过在头文件中不能用),则可以换另外一个:using namespace QtCharts;

此时,再进行编译就不会出现错误

5、然后,我们在这个cpp文件下面,写上简单的函数进行编译运行验证,见图:

自此,构建成功,谢谢!

我踩过的坑,希望大家不要再踩一遍,仔细按照上面的进行,运行不了你找我!

后续探索,有时间写...

全部代码:chartview.cpp

#include "chartview.h"
chartView::chartView(QWidget *parent) : QMainWindow(parent){ ui.setupUi(this); }void chartView::on_pushButton1_clicked(){ chartDispaly();}void chartView::on_pushButton2_clicked(){ initChartView();}void chartView::chartDispaly(){ QSplineSeries *series = new QSplineSeries(); for (float i = 0; i < 100; i++) { series->append(i, sin(0.5*i)); } QChart *chart = new QChart(); chart->addSeries(series); chart->legend()->hide(); chart->createDefaultAxes(); chart->setTheme(QChart::ChartThemeDark); //方法1 ui.widget->setChart(chart); //方法2 //QChartView *chartView = new QChartView(chart); //chartView->setRenderHint(QPainter::Antialiasing); //this->setCentralWidget(chartView);}
void chartView::initChartView(){ QChart *chart2 = new QChart(); QLineSeries *series = new QLineSeries(); *series << QPointF(1.0, 1.0) << QPointF(2.0, 73.0) << QPointF(3.0, 268.0) << QPointF(4.0, 17.0) << QPointF(5.0, 4325.0) << QPointF(6.0, 723.0); chart2->addSeries(series); chart2->legend()->hide();//隐藏图例 chart2->setTitle("Logarithmic axis example");//设置图标标题 QValueAxis *axisX = new QValueAxis(); axisX->setTitleText("Data point"); axisX->setLabelFormat("%im"); axisX->setTickCount(series->count()); chart2->addAxis(axisX, Qt::AlignBottom); series->attachAxis(axisX); QLogValueAxis *axisY = new QLogValueAxis(); axisY->setTitleText("Values"); axisY->setLabelFormat("%gkg"); axisY->setBase(8); //axisY->setMinorTickCount(-1); chart2->addAxis(axisY, Qt::AlignLeft); series->attachAxis(axisY); QChartView *chartView = new QChartView(chart2); chartView->setRenderHint(QPainter::Antialiasing); //connect(series, &QLineSeries::hovered, this, &QtGuiApplication1::showValue); this->setCentralWidget(chartView);}

chartview.h

#pragma once
#include <QtWidgets/QMainWindow>#include <QtCharts>#include "ui_chartview.h"
class chartView : public QMainWindow{ Q_OBJECT
public: chartView(QWidget *parent = Q_NULLPTR);
private: Ui::chartViewClass ui; void chartDispaly(); void initChartView();private slots: void on_pushButton1_clicked(); void on_pushButton2_clicked();};

github源码地址:https://github.com/zyr365/chartView

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Qt QChart,利用QChart绘制动态曲线
实战PyQt5: 154
.NET MSChart应用的一个简单例子
Qt5.9开发指南笔记
Pyside6应该如何准确嵌入可视化数据图表?
Mschart绘制图表之X轴为时间的设置方式
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服