QT QGraphicsView 提升到 QChartView报错 解决方案

QT QGraphicsView 提升到 QChartView报错 解决方案

本文主要描述,

  1. 使用QT提供的QChartView来绘制图表,提升QGraphicsView控件
  2. 继承QChartView后,然后将QGraphicsView提升到我们自己写的类,怎么才能确保提升后编译不报错.

[问题描述] 使用QGraphicsView显示图表的时候,我们需要将它提升为QChartView.但提升后再此运行一般会发生编译报错,错误发生在自动生成的UI头文件中.如下图:

在这里插入图片描述

使用QT提供的QChartView,提升QGraphicsView后遇到的问题解决方案

[解决方案]

  1. 临时方案(主要是修改ui_xxxx.h文件)
  2. 终极解决方案(针对网上好多方案都是修改ui_xxx.h文件,然后重新编译后又报错,又要修改)

[问题分析]

我们来分析一下这个问题:

  • 错误提示说 QChartView does not name a type.
    • 疑问一: 为什么说 不能命名成一个类型呢?
    • 疑问二: ui_mainwindow.h文件中已经有qchartview.h头文件了,不认识QChartView?
      在这里插入图片描述
      带着疑问,我们去看下qchartview.h的源代码:
      在这里插入图片描述
      大概理解或者猜一下,开始一个命名空间?
      点击进去我们再看看这个QT_CHARTS_BEGIN_NAMESPACE是个什么?
      在这里插入图片描述
      看到这个的话,应该都比较清楚了,这是给QChartView 加了一个命名空间.
      所以我们在使用的时候要把命名空间带上.
      清楚这个了,我们开始看怎么解决这个问题.

[方案描述]

既然ui_xxx.h文件报错,那么我们先修改一下这个文件,让他不报这个错,看看是否能解决问题.
第一种: 将 QtCharts这个命名空间加到我们的代码上.
修改前

#include <QtCore/QVariant>
#include <QtWidgets/QApplication>
#include <QtWidgets/QMainWindow>
#include <QtWidgets/QMenuBar>
#include <QtWidgets/QStatusBar>
#include <QtWidgets/QWidget>
#include <qchartview.h>

QT_BEGIN_NAMESPACE

class Ui_MainWindow
{
public:
    QWidget *centralwidget;
    QChartView *graphicsView; // 修改前
    ...
    void setupUi(QMainWindow *MainWindow)
    {
        if (MainWindow->objectName().isEmpty())
            MainWindow->setObjectName(QString::fromUtf8("MainWindow"));
        MainWindow->resize(800, 600);
        centralwidget = new QWidget(MainWindow); 
        centralwidget->setObjectName(QString::fromUtf8("centralwidget"));
        graphicsView = new QChartView(centralwidget);// 修改前
        ...
    }

修改后

#include <QtCore/QVariant>
#include <QtWidgets/QApplication>
#include <QtWidgets/QMainWindow>
#include <QtWidgets/QMenuBar>
#include <QtWidgets/QStatusBar>
#include <QtWidgets/QWidget>
#include <qchartview.h>

QT_BEGIN_NAMESPACE

class Ui_MainWindow
{
public:
    QWidget *centralwidget;
    QtCharts::QChartView *graphicsView; //修改后
    ...
    void setupUi(QMainWindow *MainWindow)
    {
        if (MainWindow->objectName().isEmpty())
            MainWindow->setObjectName(QString::fromUtf8("MainWindow"));
        MainWindow->resize(800, 600);
        centralwidget = new QWidget(MainWindow);
        centralwidget->setObjectName(QString::fromUtf8("centralwidget"));
        graphicsView = new QtCharts::QChartView(centralwidget); // 修改后
        ...

修改后,代码编译通过,运行结果如下:
在这里插入图片描述
第二种: 在ui_xxx.h文件中把命名空间加上:using namespace QtCharts; 或者直接使用 QT已经定义好的:QT_CHARTS_USE_NAMESPACE
在这里插入图片描述

#include <QtWidgets/QStatusBar>
#include <QtWidgets/QWidget>
#include <qchartview.h>

//using namespace  QtCharts;
QT_CHARTS_USE_NAMESPACE

QT_BEGIN_NAMESPACE

编译运行,也能正常运行.
继续思考:
这个ui_xxx.h文件是自动生成的,如果重新编译的话,我们的修改都被覆盖掉了,我们难道再去修改? 显然不是最佳方案.

注意到ui_xxx.h的文件注释: WARNING! All changes made in this file will be lost when recompiling UI file!

/********************************************************************************
** Form generated from reading UI file ‘mainwindow.ui’
**
** Created by: Qt User Interface Compiler version 5.15.2
**
** WARNING! All changes made in this file will be lost when recompiling UI file!
********************************************************************************/

所以: 修改ui_xxx.h文件显然不合适.
那么我们需要将这个命名空间在ui_xxx.h使用QChartView之前先using.

  1. 将QT_CHARTS_USE_NAMESPACE 直接添加到 mianwindow.h文件里面.如下:
    在这里插入图片描述
    编译通过,运行得到我们想要的结果
  2. 将 QT_CHARTS_USE_NAMESPACE 放到mainwindow.cpp里面.
    同样的错误又出现了
    在这里插入图片描述
    难道不能放到 mainwidow.cpp里面?
    既然这个namespace是在ui_xxx.h文件中用呢,那我把这定义到前面不就可以吗?
    修改后,再一次编译运行: 成功,如下图:
    在这里插入图片描述
    至于命名空间,大家根据自己习惯和情况放到合适的地方就行.

继承QChartView, 提升QGraphicsView控件

先看问题: 如下图,我们编译会报错,但报错的提示信息和之前的是不一样的.
在这里插入图片描述

提示信息:ui_mainwindow.h:18: error: ctqchartview.h: No such file or directory

提示是说找不到这个文件或文件夹. 怎么理解呢?
意思就是这个头文件的路径不对了.
看下我们的代码,ctqchartview是在CtChartView这个目录下的. 那我们在ui_xxx.h文件中修改下路径
修改路径后,成功编译运行如下:
在这里插入图片描述
修改后,是可以编译运行了,但我们还是会遇到之前的问题,重新编译后,这块还是会报错,我们还要修改再编译运行.

那么有没有 一个修改一次后面就不用再改的方案呢?
答案是肯定的.

方案一:

思考一下,我们ui_xxx.h文件中的 <ctqchartview.h> 是从那来的?
是不是我们在点击提升的时候,我们自己填的呢?
如下图: 这个 头文件不就是这个吗?
在这里插入图片描述
所以ui_xxx.h文件中会生成一个 #include “ctqchartview.h” 这句代码.
但引入进去后会提示找不到, 那我们把路径加上去,不就可以了吗? 如下图,点击添加
在这里插入图片描述
直接编译运行: 成功,如下图:
在这里插入图片描述

方案二:

我们的CtQChartView是继承QChartView的, 那我们能不能
在提升的时候,类写CtQChartView, 头文件 qchartview.h 呢?
如下图:
在这里插入图片描述
这样提升后,我们编译试试: 报错,看提示应该是没找到这个类.
在这里插入图片描述
解决: 在mainwindow.h文件中我们引入#include “CtChartView/ctqchartview.h” 这个头文件,再此编译运行.
结果如下图:
在这里插入图片描述
接着继续, 看ui_xxx.h文件,发现声明: CtQChartView *graphicsView;
定义:graphicsView = new CtQChartView(centralwidget);
都没用qchartview.h文件呀, 那把这个头文件删除掉,能编译成功吗?
在这里插入图片描述
一样可以成功,那这代表什么呢?
猜想一下,那我们提升的时候,只写一个类,然后在mainwindow.h文件中include的这个类的头文件,是不是也可以呢?
如下图:如果不填头文件的话,不让添加.
在这里插入图片描述
再思考下,那我给这个头文件写一个ui_xxx.h中已经存在的头文件,可行吗? 或者我把这个头文件写成QObject可行吗?
例如我填一个 QtWidgets/QMenuBar. 编译运行.可成功.
在这里插入图片描述
基于以上,我们是不是可以思考一下结论:

  1. 提升QGraphicsView 的类,只要在 ui_xxx.h 头文件前引用就可以.
  2. 在xxx.ui文件中提升QGraphicsView的时候,只要正确填写我们希望提升的类名就可以了. 当然头文件也需要填写一个正确的.
  • 20
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
### 回答1: 关于Qt QGraphicsView绘制折线的问题,以下是解答: Qt QGraphicsView是一个高级的2D图形控件,是基于MVC架构设计的。QGraphicsView可以用来展示绘制出来的图形,包括图像、文本、图表等等。 要在Qt QGraphicsView中绘制折线,可以使用QGraphicsScene和QGraphicsLineItem等相关类。具体操作可以分为几个步骤: 1.创建QGraphicsScene对象,用来存放绘制的图元。 2.根据需要创建QGraphicsLineItem对象,用来绘制折线。 3.将QGraphicsLineItem对象添加到QGraphicsScene中。 4.创建QGraphicsView对象,将QGraphicsScene设置为其场景。 5.将QGraphicsView对象添加到需要展示的窗口中。 以上就是在Qt QGraphicsView中绘制折线的基本步骤,具体实现可以参考Qt官方文档和示例代码。 ### 回答2: Qt是一个高效、跨平台的C++图形界面开发框架,支持多种绘图和绘制工具,其中包括了QT QGraphicsView。在QT QGraphicsView中,绘制折线可以通过以下步骤实现: 1.创建一个QGraphicsScene对象,该对象将显示在QGraphicsView中 2.在QGraphicsScene中添加一个折线 3.使用QGraphicsView来显示QGraphicsScene中的折线 下面我们将详细说明如何通过步骤来实现。 1.创建QGraphicsScene 在Qt中创建QGraphicsScene对象可使用以下代码: ``` QGraphicsScene *scene = new QGraphicsScene(this); ``` 这个代码创建了一个新的QGraphicsScene对象,应用程序中视图的大小将用于Scene的大小,this指针表示这个画布和QTUI相关。 2.添加折线 接下来,我们将在上一步中创建的画布中添加一条折线。 创建一个QGraphicsLineItem对象 ``` QGraphicsLineItem *line = new QGraphicsLineItem(x1, y1, x2, y2); ``` x1和y1是折线的起点,x2和y2是折线的终点。 将创建的QGraphicsLineItem对象添加到QGraphicsScene中 ``` scene->addItem(line); ``` 3.创建QGraphicsView 创建QGraphicsView对象是将折线显示在屏幕上。以下代码创建了QGraphicsView对象: ``` QGraphicsView *view = new QGraphicsView(scene); ``` scene是指先前创建的QGraphicsScene对象。 完整示例代码: ``` //创建QGraphicsScene对象 QGraphicsScene *scene = new QGraphicsScene(this); //创建折线 QGraphicsLineItem *line = new QGraphicsLineItem(x1, y1, x2, y2); //将折线添加到QGraphicsScene scene->addItem(line); //创建QGraphicsView QGraphicsView *view = new QGraphicsView(scene); //将QGraphicsView视图添加到QtUI界面中 ui->widget->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding); ui->widget->setScene(scene); ``` 通过上面的步骤,可以轻松在Qt中绘制折线,为了更好的用户交互体验,可以增加一些代码来设置折线颜色、线宽度等等。到这里绘制折线已经完成了,现在用户可以在QGraphicsView中与折线进行交互,并进行一些操作,例如缩放、拖拽等等。 ### 回答3: Qt QGraphicsView 是一个强大的图形视图框架,提供了绘制各种图形的方法,包括绘制折线。下面我将介绍如何使用 QGraphicsView 进行折线绘制。 首先,我们需要创建一个 QGraphicsView 对象和一个 QGraphicsScene 对象,并将 QGraphicsScene 对象设置为 QGraphicsView 的场景。接下来,我们需要创建一个 QGraphicsLineItem 对象来表示折线。代码如下: ```cpp QGraphicsView *view = new QGraphicsView(this); QGraphicsScene *scene = new QGraphicsScene(this); view->setScene(scene); QGraphicsLineItem *lineItem = new QGraphicsLineItem(); ``` 然后,我们需要设置线条的起始点和结束点,以及线条的样式。这可以通过 QGraphicsLineItem 的 setLine() 方法来实现。我们还可以通过 QGraphicsLineItem 的 setPen() 方法设置线条的颜色和宽度。示例代码如下: ```cpp lineItem->setLine(0, 0, 100, 100); // 设置起始点和结束点 QPen pen(Qt::red); // 创建颜色为红色的笔 pen.setWidth(2); // 设置线条宽度为 2 lineItem->setPen(pen); // 设置线条样式 ``` 最后,我们需要将 QGraphicsLineItem 对象添加到 QGraphicsScene 中,以便它能够在 QGraphicsView 中进行显示。示例代码如下: ```cpp scene->addItem(lineItem); ``` 综上所述,以上代码展示了如何使用 QGraphicsView 绘制折线。当然,还有很多其他的绘制方法和属性可以应用于 QGraphicsView 和 QGraphicsLineItem 对象,根据实际需求进行选择和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值