如何使用QCustomPlot在Qt中绘制几行图形

时间:2017-08-13 04:18:10

标签: c++ qt qt5 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]);
    }
  }

用很多线条画出这张图。

enter image description here

但我的任务是转移到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数据 在这张图片中看到我的dinamic数组wht[j][i]正在工作并装入QVector yy[ii]

enter image description here enter image description here

我认为循环中的问题。

在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];
        }
    }
} 

1 个答案:

答案 0 :(得分:3)

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

  • 如果我们观察到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>,因为函数{{ 3}}接受此类数据作为输入。对于函数setData(),您必须传递2个相同大小的向量,但是您传递了NtNt*Nt的2个向量,这会产生警告:
ui->widget_2->addGraph()->setData(x, wht[j]);
  • setData()将范围从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();

}

输出:

setRange()

注意:对于测试wht[i][j] = i*j

在您的情况下,whtdouble**类型的变量,也假定为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);
  • calculatedifnet(1,.5,.5,0.9,12,12,3;

输出:

enter image description here