如何使用 QCustomPlot 在 Qt 中绘制多条图形线

How to draw several lines of the graph in Qt using QCustomPlot

例如Visual Studio中有tChart及其Series属性,负责绘制图形的线条。这是此代码的示例

for (int j = 1; j < Nt - 1; j++)
  {
   for (int i = 1; i < Nt - 1; i++)
    {
       chart2->Series["" + (j + 1).ToString()]->Points->AddXY(i, wht[j][i]);
    }
  }

并用很多线画出这张图。

但是我的任务是在Qt Creator转学(因为在Qt Creator可能会创造很多机会) 此代码

void MainWindow::drawdifnet(int Nt)
{
    int N=Nt;
    int N1=pow(N,2);
    QVector<double> x22(N), y22(N1); 
    int ii=0,jj=0;
    for (int j = 0; j < Nt ; j++)
            {
                for (int i = 0; i < Nt ; i++)
                {          
                    x22[jj]=i;
                    y22[ii]=wht[j][i];
                    ui->widget_2->addGraph();
                    ui->widget_2->graph(0)->setData(x22,y22);
                  ii++;
                }
                jj++;
    }
    ui->widget_2->xAxis->setLabel("OsX");
    ui->widget_2->yAxis->setLabel("OsY");
    ui->widget_2->xAxis->setRange(30,30);
    ui->widget_2->replot();
}

无法正常工作。 结果是空的小部件

首先我用帮助调试器检查 QVectors 数据 在这张图片中看到我的动态数组 wht[j][i] 正在工作并加载到 QVector yy[ii]

我觉得是循环的问题

在 QtCustomPlot 教程中解决此问题的代码

ui->widget_2->graph(0)->setData(x,y);
ui->widget_2->graph(1)->setData(x11,y11);
ui->widget_2->graph(2)->setData(x22,y22);

但在我的情况下,当程序运行时,行数是已知的。

我如何创建和分配数组

void created(int Nt, int Nx) ///This function creating my dynamic array
{
    wht = new double *[Nt];
    for (int i = 0; i < Nt; i++)
        wht[i] = new double[Nx];
}

inline double fn(int T, double x) ///these 4 functions for my mathematical part(works good)
{
    if (x >= 0)
        return T;
    return 0;
}

inline double u0(int T, double x)
{
    return fn(T, x);
}

inline double u1(int T, double a, int xmin, double t)
{
    return fn(T, xmin - a * t);
}

inline double u2(int T, double a, int xmax, double t)
{
    return fn(T, xmax - a * t);
}


void calculatedifnet(int xmin, double hx, double ht, double a, int Nx, int Nt, int T)
//These main function.We have the empty array and in this function we fill array. Then we solve in the main loop and the fill the first indexes wht[j]
{
    for (int i = 0; i < Nt; i++)
    {
        wht[0][i] = u0(T, xmin + i*hx);//fill the second indexeswht[null][i]
    }

    for (int j = 0; j < Nt - 1; j++)//the calculated code(works right).The result writing in wht[j]
    {
        wht[j + 1][0] = u1(T, a, xmin, j*ht);
        for (int i = 1; i < Nt; i++)
        {
            double dudx = (wht[j][i] - wht[j][i - 1]) / hx;
            wht[j + 1][i] = -a * dudx * ht + wht[j][i];
        }
    }
} 

您的代码中存在以下错误:

  • 如果我们观察到 x 是一个从 0Nt-1 的常数向量,那么我们只需要创建它一次:

QVector<double> x(Nt);
for (int i = 0; i < Nt ; i++)
    x[i]=i;//0 to Nt-1
  • addGraph() 添加一个图表并将其放在最后一个位置,如果你想图表你必须通过最后一个索引访问,而不是通过索引 0:

ui->widget_2->addGraph()->setData(xx, yy);
  • 假设 wht 的类型为 QVector<QVector<double>>,大小为 NtxNt,则不必访问每个元素,我们可以访问每个 QVector<double>,因为函数setData() accepts as input this type of data. To the function setData() 您必须传递 2 个相同大小的向量,但您传递的是 NtNt*Nt 的 2 个向量,这会产生警告:

ui->widget_2->addGraph()->setData(x, wht[j]);
  • setRange() 将范围从 a 到 b,但如果它们相同,QCustomPlot 将永远不会适合该范围,对于我的测试,我将其设置如下:

ui->widget_2->xAxis->setRange(0,Nt);
ui->widget_2->yAxis->setRange(0,Nt*Nt);

简而言之,代码如下:

void MainWindow::drawdifnet(int Nt){

    QVector<double> x(Nt);
    for (int i = 0; i < Nt ; i++)
        x[i]=i;//0 to Nt-1

    for (int j = 0; j < Nt ; j++)
        ui->widget_2->addGraph()->setData(x, wht[j]);

    /* if c++11
    for (auto& row: wht)
        ui->widget_2->addGraph()->setData(x, row);
    */

    ui->widget_2->xAxis->setLabel("OsX");
    ui->widget_2->yAxis->setLabel("OsY");
    ui->widget_2->xAxis->setRange(0,Nt);
    ui->widget_2->yAxis->setRange(0,Nt*Nt);
    ui->widget_2->replot();

}

输出:

注:为测试wht[i][j] = i*j

在你的例子中 wht 是一个 double** 类型的变量,还假设 Nx>=Nt,为此你必须使用以下代码:

void MainWindow::drawdifnet(int Nt)
{
    QVector<double> x(Nt);
    for (int i = 0; i < Nt ; i++){
        x[i]=i;//0 to Nt-1
    }

    QVector<double> y(Nt);
    for(int i=0; i<Nt; i++){
        for(int j=0; j<Nt; j++){
            y[j] = wht[i][j];
        }
        ui->widget_2->addGraph()->setData(x, y);
    }

    ui->widget_2->xAxis->setLabel("OsX");
    ui->widget_2->yAxis->setLabel("OsY");
    ui->widget_2->xAxis->setRange(0,12);
    ui->widget_2->yAxis->setRange(0,3.5);
    ui->widget_2->replot();
}

输入:

  • 已创建(12, 12);
  • 计算的 ifnet(1, .5, .5, 0.9, 12, 12, 3);

输出: