服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - Qt图形图像开发曲线图表模块QChart库基本用法、各个类之间的关系说明

Qt图形图像开发曲线图表模块QChart库基本用法、各个类之间的关系说明

2021-08-23 15:51qq_610642 C/C++

这篇文章主要介绍了Qt图形图像开发曲线图表模块QChart库基本用法、各个类之间的关系说明,需要的朋友可以参考下

如何编译安装QChart请查看下面文章

Qt图形图像开发之曲线图表库QtChart编译安装详细方法与使用实例

使用Qt曲线图表模块Chart库首先要注意3点:

(1)在.pro文件中添加:QT += charts

(2)用到QChart的文件中添加:QT_CHARTS_USE_NAMESPACE,或者:using namespace QtCharts;

在ui界面中拖入一个graphicsView控件,然后右击提升为QChartView类,写提升为的类:QtCharts::QChartView,头文件写:qchartview.h

(3)别忘了在用到QChartView的文件中添加#include <QChartView>

如果编译报错,请依次执行:清除->执行qmake->构建

QChart的两种显示方法:(本质上就是同一种方法)

(1)QChart必须显示在widget上,更确切地说,是必须把它显示在QGraphicView控件中,众所周知,QT的ui控件都可以作为独立窗口直接显示,所以这就是方法1。

(2)把QChart显示在ui界面的QGraphicView控件中。

PS:把QChart显示在QGraphicView控件中,程序略显繁琐,QT早就为我们封装好了一个ui控件类QtCharts::QChartView,它继承了QGraphicView。这就是上文提到的把QGraphicView提升成了QChartView。用QChartView来显示QChart还是很方便的。

用QGraphicView来显示QChart较为繁琐,下面来对比一下,分别用QGraphicView和QChartView来显示QChart,代码量的区别:

(1)用QGraphicView来显示,需要借助QGraphicsScene类。具体地说就是,QGraphicView在最底层,QGraphicsScene在中间,QChart在最外层。

  1. QGraphicsScene scene;//场景(中间层)
  2. QGraphicsView view(&scene);//视图(最底层)
  3. view.setRenderHint(QPainter::Antialiasing);//设置视图抗锯齿
  4. view.setSceneRect(0, 0, 630, 280);//设置视图大小
  5.  
  6. QLineSeries *lineseries = new QLineSeries();//图表的数据集
  7. lineseries->append(0, 5);//append和<<功能差不多
  8. *lineseries << QPointF(13, 5) << QPointF(17, 6) << QPointF(20, 2);
  9.  
  10. QChart *lineChart = new QChart();//图表(最顶层)
  11. lineChart->addSeries(lineseries); // 将 数据集 添加至图表中
  12.  
  13. scene.addItem(lineChart);//把图标添加到场景中(一个场景中允许添加多个图表)
  14. view.show();//视图显示

(2)用QChartView来显示QChart较为方便

  1. QLineSeries *lineseries = new QLineSeries();//图表的数据集
  2. lineseries->append(0, 5);//append和<<功能差不多
  3. *lineseries << QPointF(13, 5) << QPointF(17, 6) << QPointF(20, 2);
  4.  
  5. QChart *lineChart = new QChart();//图表(最顶层)
  6. lineChart->addSeries(lineseries); // 将 数据集 添加至图表中
  7.  
  8. QChartView *chartView = new QChartView(chart);//QChartView 可以一步到位直接显示QChart
  9. chartView->setRenderHint(QPainter::Antialiasing);//继承来的抗锯齿方法
  10. chartView->resize(400, 300);
  11. chartView->show();//本示例代码,把该控件作为窗口直接显示出来。
  12. //其实,也可以把QChartView的父控件设置为主UI,这样就能把QChartView显示在主窗体中了

最后再来捋一下各个类之间的层次关系。下图中,大括号“{”代表左边实体包含右边实体,下箭头↓↓↓↓代表继承关系

Qt图形图像开发曲线图表模块QChart库基本用法、各个类之间的关系说明

本文先简单介绍了Qt曲线图表模块QChart库基本用法、各个类之间的关系说明,详细介绍就查看下面的相关链接

原文链接:https://blog.csdn.net/qq_31073871/article/details/82987524

延伸 · 阅读

精彩推荐