QT5 使用QCustomplot绘制频谱瀑布图并封快速傅里叶变换fft类

QT5 使用QCustomplot绘制频谱瀑布图并封快速傅里叶变换fft类近期想要做个上位机显示SDR设备的信号频谱,频谱瀑布图展示最为直观,经过多方评估比较最后选择了QCustomsplot图形库,相比于其他选择比如修改RGB像素刷新图片来说这种方式要简单的多,先做了个demo出来试试效果,话不多说先上动图。下面介绍方方法:第一步,QT没有自带QCustomplot库需要自行下载,实际上就是一个qcustomplot.h和qcustomplot.cpp文件,添加进工程就可以了,不想下载的后面我会上传de…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

         近期想要做个上位机显示SDR设备的信号频谱,频谱瀑布图展示最为直观,经过多方评估比较最后选择了QCustomsplot图形库,相比于其他选择比如修改RGB像素刷新图片来说这种方式要简单的多,先做了个demo出来试试效果,话不多说先上动图。

          QT5 使用QCustomplot绘制频谱瀑布图并封快速傅里叶变换fft类  

下面介绍方方法:

第一步,QT没有自带QCustomplot库需要自行下载,实际上就是一个qcustomplot.h和qcustomplot.cpp文件,添加进工程就可以了,不想下载的后面我会上传demo工程里面就包含有这连个文件。

第二步,绘制最上边瀑布图界面分三步

                1,.ui中拖入QWidget控件  2,控件提升为qcustomplot类,3,编写初始化以及显示代码

                初始化及刷新代码如下:其中F_domain_init()为初始化窗口,F_Show()为刷新窗口

void MainWindow::F_domain_init()
{
    fp3 = ui->widget; //创建一个画图指针
    fp3->setInteractions(QCP::iRangeDrag|QCP::iRangeZoom);//可拖拽+可滚轮缩放
    m_pColorMap = new QCPColorMap(fp3->xAxis,fp3->yAxis);
    m_pColorMap->data()->setSize(xlength+1,51);//设置整个图(x,y)点数
    m_pColorMap->data()->setRange(QCPRange(0,xlength),QCPRange(0,100));//setRange是设置X轴以及Y轴的范围
    m_pColorMap->setGradient(QCPColorGradient::gpJet);//设置默认渐进色变化(可在QCPColorGradient中查看)
    m_pColorMap->rescaleDataRange(true);
   // 立即刷新图像
    fp3->rescaleAxes();//自适应大小
   // ui->widget->replot();
}
void MainWindow::F_show(QVector<double> data)   //显示lofar瀑布图
{
    if(value_lofar.size()>49)
    {
        value_lofar.removeLast();  //当lofar累积到了50个,删除最后面的数据,防止绘图溢出绘图区域
    }
    value_lofar.prepend(data);//新来的数据一直往前面累加
    for (int i=0;i<value_lofar.size();i++)
    {
        for(int j=0;j<xlength;j++)
        {
            m_pColorMap->data()->setCell(j,i,value_lofar[i][j]);
        }
    }
    m_pColorMap->rescaleDataRange(true);
    fp3->rescaleAxes();//自适应大小
    ui->widget->replot();
}

第三步,绘制中间柱状离谱界面也有三步

                1,.ui中再拖入QWidget控件  2,控件提升为qcustomplot类,3,编写初始化以及显示代码

                初始化及刷新代码如下:其中Bars_domain_init()为初始化窗口,Bars_Show()为刷新窗口

void MainWindow::Bars_domain_init()
{
    QCPAxis *keyAxis = ui->widget_QCPBars->xAxis;
    QCPAxis *valueAxis = ui->widget_QCPBars->yAxis;
    fossil = new QCPBars(keyAxis, valueAxis);  // 使用xAxis作为柱状图的key轴,yAxis作为value轴

    fossil->setAntialiased(false); // 为了更好的边框效果,关闭抗齿锯
    fossil->setName("Fossil fuels"); // 设置柱状图的名字,可在图例中显示
    fossil->setPen(QPen(QColor(0, 168, 140).lighter(130))); // 设置柱状图的边框颜色
    fossil->setBrush(QColor(0, 168, 140));  // 设置柱状图的画刷颜色


    keyAxis->setRange(0, xlength);               // 设置范围
    keyAxis->setUpperEnding(QCPLineEnding::esSpikeArrow);
    valueAxis->setRange(0, 100);
}
void MainWindow::Bars_show(QVector<double> fossilData)
{
    QVector<double> ticks;
    for(int i=1;i<=xlength;i++)
    {
        ticks <<  i;
    }
    fossil->setData(ticks,fossilData);
    ui->widget_QCPBars->replot();
}

第四步,绘制最下边时域界面还是三步

                1,.ui中再拖入QWidget控件  2,控件提升为qcustomplot类,3,编写初始化以及显示代码

                初始化及刷新代码如下:其中T_domain_init()为初始化窗口,T_Show()为刷新窗口

void MainWindow::T_domain_init()
{
    CustomPlot->addGraph();
    CustomPlot->graph(0)->setPen(QPen(Qt::red));

    //CustomPlot->xAxis->setLabel("t");
    //CustomPlot->yAxis->setLabel("mV");

    CustomPlot->xAxis->setRange(0,xlength);
    CustomPlot->yAxis->setRange(0,100);
    CustomPlot->replot();
}
void MainWindow::T_Show(QVector<double> data)
{
    QVector<double> xx;
    for(int i=0;i<xlength;i++)
    {
        xx <<i;
    }
    CustomPlot->graph(0)->setData(xx,data);
    CustomPlot->replot();
}

完成以上四步后 三个显示画面就已经有了,怎样显示数据呢,且听下回分解。。。。。哈哈哈哈

第五步,定时刷新显示数据

          起个定时器就三行代码我就不写了,直接写刷新函数updata()

void MainWindow::update()
{
    QVector<double> data;
     static double f = qrand()%100;
    f = f +2;
    for(int i=0;i<xlength;i++)
    {
        data << 50+50*sin(2*3.14159*f*i/128);
    }
    fft.fft_data.clear();
    fft.fft_calculate(data);
    F_show(fft.fft_data);
    Bars_show(fft.fft_data);
    T_Show(data);

}

这个函数里边的内容我略微介绍下,首先产生要刷新的data数据,数据类型QVector<double>,长度xlength。我的应用是要计算fft所以我封装了FFT类计算频谱,不需要的直接将data传递给 F_show(); Bars_show();T_Show()这兄弟三个就可以,忽略fft_calculate()函数。

OK,以上就是完成开头动图展示的有需要的代码片段,需要完整工程的留邮箱,有CSDN积分的支持下:点击这里下载demo ,没有积分的话github自行下载吧:Github链接

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181390.html原文链接:https://javaforall.net

(1)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 剖析RT-Thread中console与finsh组件实现(2)[通俗易懂]

    剖析RT-Thread中console与finsh组件实现(2)[通俗易懂]接上一章剖析RT-Thread中finsh组件实现(1),rt_device具体定义如下:其中内核基类定义如下:所以刚才串口1初始化后名称被初始化为了“usart1”,与刚才设置终端时入参刚好可以匹配。而这个标志是类型标志,串口类型即为RT_Object_Class_Device,同时也是一个静态类,所以会或上0x80其实rt_device中最重要的是传入了设备回调与操作函数指针,这些指针此时指向的是串口1的一系列操作函数。这些函数被初始化在串口1初始化的rt_hw_serial

    2022年5月12日
    36
  • js 全局变量优点和缺点

    js 全局变量优点和缺点全局变量的优点:可以减少变量的个数,减少由于实际参数和形式参数的数据传递带来的时间消耗。全局变量的缺点:(1)全局变量保存在静态存贮区,程序开始运行时为其分配内存,程序结束释放该内存。与局部变量的动态分配、动态释放相比,生存期比较长,因此过多的全局变量会占用较多的内存单元。(2)全局变量破坏了函数的封装性能。函数象一个黑匣子,一般是通过函数参数和返回值进行输入输出,函数内部实现相对独立

    2022年6月9日
    63
  • python中的缩进规则_什么叫代码缩进

    python中的缩进规则_什么叫代码缩进引言python对缩进是敏感的,而大多教程对缩进规则,往往就几句话带过,对于没有其他语言基础的初学者,十分不友好,本文就把python常见的缩进问题做了一些整理。一、Python缩进长度及缩进字符常看到一些Python缩进错误的解读,“tab符和空格做为缩进不能混用”、“缩进一定是4个空格”。实际上并没有这些限制,例如图中的示例就可以正常运行。a=1ifa==1:print(a)else:print(1)k=1;whilek<5:

    2022年10月11日
    0
  • QQ第三方登录报错error=-1

    QQ第三方登录报错error=-1

    2021年10月25日
    52
  • 使用Gson将Object转String出现\u003d 的原因「建议收藏」

    使用Gson将Object转String出现\u003d 的原因「建议收藏」在使用Gson将Object转json字符串,或者将实体类例如:User转为json的过程中,最终的结果会在值中出现\u003d出现这个的原因是Gsongson=newGson()造成的这个时候需要使用Gsongson=newGsonBuilder().disableHtmlEscaping().create();实例化一个gsongson.toJson(…

    2022年5月29日
    379
  • 在Ubuntu中安装pycharm社区版[通俗易懂]

    在Ubuntu中安装pycharm社区版[通俗易懂]版本Ubuntu20LTS

    2022年8月30日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号