欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

程序员文章站 2022-03-18 15:45:33
在使用了 RTKLIB开源包自带的 rtkplot.exe后,知道了它所具有的功能,就想着如何模仿它做出一个 demo。一开始看的是之前下载的 2.4.2版本的 RTKLIB,里面是使用 Delphi开发的。由于我现在对 Qt比较熟悉,所以想着使用 Qt框架来开发这个 demo。在看源码的过程中,阴 ......

   在使用了 RTKLIB开源包自带的 rtkplot.exe后,知道了它所具有的功能,就想着如何模仿它做出一个 demo。一开始看的是之前下载的 2.4.2版本的 RTKLIB,里面是使用 Delphi开发的。由于我现在对 Qt比较熟悉,所以想着使用 Qt框架来开发这个 demo。在看源码的过程中,阴差阳错之间又去官网上重新下载了一次源码包,结果发现最新的 2.4.3版本里面就带有相关 App程序的 Qt实现。这样的话,就可以直接阅读现成的 Qt源码了。不过首先需要解决的问题是,要尝试将所给的源代码编译成功。

1.直接在 Qt creator中打开 rtkplot_qt.pro文件,配置项目属性,进入正常的工作界面。直接进行调试,则会报出如下错误。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 1

一开始以为是 VS2015在安装时出了问题,网上找的解决方案也都是说配置环境变量。其实不然,上图中已经说明是什么问题了,是 src\debug目录下缺失 libRTKLib.a文件

2. .a文件是 Linux系统下的静态库文件,类似于 Windows系统下的 .lib文件;同样的,Linux系统下的 .so文件是动态链接库文件,相当于 Windos系统下的 .dll文件。另外,之前在阅读 rtkplot_qt的源码时就发现,其实里面很多数据和算法的代码都是使用 src下的相应代码,所以这些可视化程序是需要调用 src库中的代码的。而调用方式就是通过将 src中的源码编译成静态链接库,供这些可视化程序使用。这一点在 rtkplot_qt.pro文件中是有所体现的,如下图所示。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 2

3.既然知道了问题是 src\debug目录下缺失 libRTKLib.a文件,那就想办法去找到 libRTKLib.a文件并放置到该目录下即可。打开文件夹,发现 src目录下根本就没有 debug文件夹,所以我们就先新建一个 debug文件夹。接着在整个 RTKLIB源码包中搜索 libRTKLib.a文件,结果是都没有找到。既然没有现成的,那就可能需要我们自己制作一个 libRTKLib.a文件了。

4.前面说了,libRTKLib.a文件就是将 src源码编译成的静态链接库文件,而 src文件夹下正好有一个 src.pro文件。打开该文件,发现如下图所示代码

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 3

上图中的代码就是说本次 Qt项目的目的是生成一个名为 RTKLib的静态链接库文件。不过需要注意的是,windows系统下生成的是 .lib文件!直接调试该项目,报出如下错误

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 4

再查看如下图所示的编译信息后,发现问题应该是编译参数“-Wno-unused-but-set-variable” 无效导致的。百度之后,该编译参数的原意是为了忽略掉那些设置了而没有使用到的参数,但是如下图所示的写法似乎有问题,应该改成图 7所示的写法。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 5 编译参数“-Wno-unused-but-set-variable” 所导致的的错误

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 6 编译参数“-Wno-unused-but-set-variable” 原本的书写方式

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 7 编译参数“-Wno-unused-but-set-variable” 修改之后正确的书写方式

5.清除原项目后执行 qmake,再重新调试一次,即可成功运行,弹出如下所示的对话框。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 8

一开始我也很懵逼,咋会弹出这个界面。我知道这个界面就是相当于 C++控制台程序可以通过命令行给主函数 main传递参数,但是 src文件夹下根本就没有 main函数,里面都是函数的源码,并没有调用这些源码的函数。百度之后发现,这是因为该项目本身就是为了编译静态库文件,项目中没有可执行的主函数,所以才会弹出这个界面来选择可执行程序并输入参数。至于所需要的静态链接库文件 libRTKLib.lib,已经生成在了build-src-Desktop_Qt_5_8_0_MSVC2015_64bit-Debug\debug目录下。将该文件拷贝到 src\debug目录下,在重新编译 rtkplot_qt项目之前,需要将图 2中的代码改成下图所示。这是因为现在生成的静态库是 .lib文件,而源码的环境可能是 Linux系统,所以用的是 .a文件。需要对代码稍作修改。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 9

清除后执行 qmake,再重新调试,又会报出如下错误

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 10

6.对于前两个错误,直接在 plotcmn.cpp文件中使用该函数报错的地方,再添加第三个参数 ndec就可以了。而第三个错误,则要将字符串指针数组 name重新定义成 常量字符串指针数组(const char*)。修改之后再次编译,又会报出如下错误。

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 11

这个问题初看很奇怪,因为报“无法解析的外部符号”一般都是链接库出了问题,而我们之前已经添加了链接库文件 libRTKLib.lib。一开始我不知道要自己编译  libRTKLib.lib文件时,曾经把图 2中的代码直接注释掉,想试一下程序能不能运行,结果报了一大堆“无法解析的外部符号”的问题。而现在在添加了链接库之后还报了这个问题,不过只报了这两个“无法解析的外部符号”。难道是  libRTKLib.lib里的确没有包含 input_tersus和 input_tersusf这两个函数?查找之后发现这两个函数是在 src/rcv/tersus.c文件中的,打开 src.pro文件,发现其 SOURCES中真的还就只缺失了 tersus.c这个文件。在 SOURCES中添加完该文件后,重新编译 src项目的静态库文件。再将第二次得到的 libRTKLib.lib替换掉 src/debug目录下的相应文件。

7.重新运行 rtkplot_qt项目,就可以成功运行啦。运行结果如下图所示

Windows环境下的RTKPlot_Qt版本编译时遇到的问题和解决方法

图 12 rtkplot_qt成功运行后的主界面

Bingo!