你的位置:首页 > 操作系统

[操作系统]解决Linux下Qt编译出现cannot find


在Linux系统下安装好Qt5,打开Qt Creator新建一个最简单的工程,编译却出现"cannot find -lGL"错误。



在网上搜索解决方法,找到的方案基本上是安装libgl1-mesa-dev,如通过apt-get install libgl1-mesa-dev安装,但是在我自己的系统上尝试这条命令,无论怎么安装都会出现一大堆依赖错误,按照缺少的依赖一个个尝试安装,结果只会出现越来越多的依赖错误。在Ubuntu软件中心下载libgl1-mesa-dev的deb包也是无法安装的,同样是一大堆依赖错误。

如果使用aptitude命令尝试安装libgl1-mesa-dev,则aptitude给出的解决依赖错误的方案竟然是将ubuntu-desktop和xorg等软件删除!这样在libgl1-mesa-dev以后,你的Linux系统将会无法再开机!我因为安装libgl1-mesa-dev使我的Linux系统崩溃了数次。


后来找到的另外一个方法是,搜索系统中已经存在的libgl1-mesa-dev相关文件。libgl1-mesa-dev是有关OpenGL的库。

使用locate libGL命令或find /usr -name libGL*命令搜索。

搜索结果中发现/usr/lib/i386-linux-gnu/mesa/libGL.so.1文件(这个文件也可能在另一个目录中)。

然后使用ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/libGL.so命令给已存在的库文件创建一个链接到/usr/lib目录。



然后在Qt Creator中再次编译工程,错误消失。




但是如果在代码中加入其他Qt模块,如include <QtGui> <QtWidgets>等,将会出现新问题:找不到GL/gl.h文件。




通过追踪错误来源,发现在QtGui模块的头文件中有包含GL/gl.h的部分,此时在include <QtGui> <QtWidgets>等命令前加上#define QT_NO_OPENGL,则可解决问题。



最后分析,一开始Qt找不到的库文件是OpenGL的库,而Qt默认包含了OpenGL库,因此在没有安装OpenGL库时编译Qt程序,则会出现错误。而无法安装libgl1-mesa-dev,有可能与系统中已经存在的OpenGL相关文件冲突有关。此问题出现在虚拟机Ubuntu中,在真机上的Linux系统暂时没有遇到。个人猜测有可能与Vmware tools有关,因为我遇到的另一个gtk的lib依赖错误也似乎与它有关,Vmware tools程序中包含一些与显示有关的驱动,不知道这是不是造成冲突的原因。如果需要同时开发Qt和OpenGL的,又遇到了这个问题的话,建议重新安装一次Linux系统,并在安装Vmware tools之前谨慎考虑,再尝试安装Qt和libgl1-mesa-dev。