在Linux操作系统中,Qt作为一种跨平台的C++图形用户界面(GUI)框架,被广泛应用于开发桌面、嵌入式和移动应用程序,对于开发者或用户而言,掌握如何在Linux环境下打开Qt界面(包括开发环境和运行Qt程序)是基础且重要的技能,本文将从Qt开发环境的搭建、Qt程序的运行方式、常见问题解决等方面进行详细说明,帮助读者顺利在Linux中使用Qt。

Qt开发环境的安装与配置
在Linux中打开Qt界面,首先需要安装Qt开发工具链,主要包括Qt库、Qt Creator(官方IDE)以及编译工具(如GCC、GDB等),根据Linux发行版的不同,安装方式略有差异,以下是主流发行版的安装步骤:
基于Debian/Ubuntu系统的安装
Debian/Ubuntu及其衍生版(如Linux Mint)通常使用apt包管理器,首先更新软件包列表,然后安装Qt5或Qt6的开发环境,以Qt5为例:
sudo apt update sudo apt install qt5-default qtcreator qtbase5-dev qtdeclarative5-dev libqt5svg5-dev
qt5-default包含默认的Qt模块和编译工具,qtcreator是官方IDE,qtbase5-dev提供核心开发库,qtdeclarative5-dev支持QML开发,libqt5svg5-dev用于SVG图形支持,若需Qt6,可将包名中的5替换为6(如qt6-default),但需确保系统已安装支持C++17的编译器(如GCC 9+或Clang 10+)。
基于RHEL/CentOS/Fedora系统的安装
RHEL/CentOS 7/8及Fedora使用yum或dnf包管理器,以Fedora为例:
sudo dnf install qt5-qtcreator qt5-qtbase-devel qt5-qtdeclarative-devel qt5-qtsvg-devel
CentOS 7可通过EPEL源安装,CentOS 8则需要启用PowerTools仓库,对于Qt6,同样替换包名中的5为6,并确保编译器版本符合要求。
源码编译安装(适用于定制需求)
若需使用特定版本的Qt或开启/关闭特定模块,可从Qt官网(https://download.qt.io/official_releases/qt/)下载源码编译安装,以Qt 5.15为例:
# 下载源码 wget https://download.qt.io/official_releases/qt/5.15/5.15.2/single/qt-everywhere-src-5.15.2.tar.xz tar -xf qt-everywhere-src-5.15.2.tar.xz cd qt-everywhere-src-5.15.2 # 配置编译选项(指定安装路径、模块等) ./configure -prefix /opt/qt5 -opensource -confirm-license -qt-xcb -shared -nomake examples -nomake tests # 编译与安装 make -j$(nproc) sudo make install
编译完成后,需将Qt的bin目录添加到系统PATH环境变量,例如在~/.bashrc中添加:

export PATH=/opt/qt5/bin:$PATH source ~/.bashrc
Qt Creator的启动与配置
安装完成后,可通过命令行或桌面菜单启动Qt Creator:
qtcreator # 命令行启动
首次启动时,Qt Creator会提示选择Kit(开发套件),包括编译器(GCC/G++)、Qt版本(如Qt 5.15.2)、调试器(GDB)等,若未自动检测到Qt版本,可通过工具→选项→Kits手动添加,指定Qt安装路径和编译器路径。
Qt界面的打开方式
通过Qt Creator创建并运行Qt项目
Qt Creator是Qt开发的官方IDE,支持创建多种类型的项目(如Widgets、QML、Console Application等),以下是创建简单Qt Widgets项目的步骤:
- 启动Qt Creator后,选择
文件→新建项目→应用程序→Qt Widgets Application,点击选择。 - 设置项目名称(如
HelloQt)、选择存储路径,点击下一步。 - 选择Qt版本(如Qt 5.15.2)和构建套件(默认GCC 64-bit),点击
下一步。 - 选择基类(如
QMainWindow)、类名(如MainWindow),点击下一步。 - 确认项目信息后点击
完成,Qt Creator会自动生成项目文件(.pro)和基础代码(mainwindow.h、mainwindow.cpp、mainwindow.ui)。 - 双击
mainwindow.ui打开Qt Designer界面,可通过拖拽控件(如按钮、标签)设计UI界面,设计完成后,点击构建→构建项目(或按Ctrl+B)编译代码,再点击运行→运行(或Ctrl+R)启动程序,即可看到Qt界面。
通过命令行运行已编译的Qt程序
对于已编译的Qt程序(如通过qmake或CMake构建的可执行文件),可通过命令行直接运行,假设项目名称为HelloQt,构建目录为build-HelloQt-Desktop-Debug,则:
cd build-HelloQt-Desktop-Debug ./HelloQt # 运行程序
若程序依赖Qt动态库(如libQt5Widgets.so.5),且系统未找到该库,可通过ldd检查依赖:
ldd HelloQt
若提示库文件缺失,可通过以下方式解决:
- 安装对应的Qt运行时库(如Ubuntu下
sudo apt install libqt5widgets5)。 - 设置
LD_LIBRARY_PATH环境变量,指向Qt库的路径(如export LD_LIBRARY_PATH=/opt/qt5/lib:$LD_LIBRARY_PATH)。
通过桌面环境启动Qt程序
若Qt程序已打包为.deb、.rpm或AppImage,或生成了.desktop桌面文件,可通过桌面环境直接启动:

- .desktop文件:将
.desktop文件(通常位于/usr/share/applications/或~/.local/share/applications/)复制到桌面,或通过alacritty等终端运行xdg-open HelloQt.desktop。 - AppImage:下载后赋予执行权限(
chmod +x HelloQt-x86_64.AppImage),双击运行或在终端执行./HelloQt-x86_64.AppImage。 - 软件中心:部分Qt程序已提交到Linux发行版的软件中心(如Ubuntu Software),可直接搜索安装并启动。
远程开发与虚拟机环境下的Qt界面
若在远程服务器或虚拟机中开发Qt程序,可通过X11转发显示图形界面,以SSH远程连接为例:
- 在本地Linux终端中,通过
ssh -X username@remote_host连接远程服务器(需启用X11转发,服务器配置文件/etc/ssh/sshd_config中设置X11 yes)。 - 远程服务器中运行Qt程序时,图形界面会自动显示在本地桌面。
ssh -X user@remote_server cd /path/to/Qt/project ./HelloQt
不同Linux发行版的Qt安装命令对比
| 发行版 | 包管理器 | 安装Qt5命令示例 | 安装Qt6命令示例 | 备注 |
|---|---|---|---|---|
| Ubuntu 20.04+ | apt | sudo apt install qt5-default qtcreator |
sudo apt install qt6-base-dev qt6-qtcreator |
需添加Qt官方源获取最新版本 |
| Debian 11+ | apt | sudo apt install qt5-default qtcreator |
sudo apt install qt6-base-dev qt6-qtcreator |
Debian默认源可能无Qt6,需添加Backports源 |
| Fedora 36+ | dnf | sudo dnf install qt5-qtcreator qt5-qtbase-devel |
sudo dnf install qt6-qtcreator qt6-qtbase-devel |
Fedora默认源提供Qt5和Qt6 |
| CentOS 8 | dnf | sudo dnf install qt5-qtcreator qt5-qtbase-devel --enablerepo=PowerTools |
需EPEL源或编译安装 | CentOS 8默认源Qt5版本较低 |
| Arch Linux | pacman | sudo pacman -S qt5-tools qtcreator |
sudo pacman -S qt6-tools qtcreator |
Arch仓库提供Qt5和Qt6,版本较新 |
常见问题解决
-
启动Qt Creator时提示“无法找到Qt版本”
原因:未正确配置Qt路径或Kit。
解决:进入工具→选项→Kits,点击添加,选择Qt Version,点击添加,浏览Qt安装路径(如/opt/qt5),检测Qt版本后保存,再在Kits中选择对应的Qt版本和编译器,完成配置。 -
运行Qt程序时提示“无法连接到X服务器”
原因:无图形界面环境或X11权限问题。
解决:- 确保系统安装了图形界面(如Ubuntu的
ubuntu-desktop)。 - 若在SSH远程连接中,使用
ssh -X或ssh -Y(启用信任X11转发)。 - 检查本地X11权限(如
xhost +,但存在安全风险,建议使用xhost +local:username限制)。
- 确保系统安装了图形界面(如Ubuntu的
FAQs
Q1:Linux下运行Qt程序时提示“libXXX.so.1: cannot open shared object file: No such file or directory”,如何解决?
A:这是由于缺少Qt运行时库导致的,可通过以下方式解决:
- 安装对应的库文件(如Ubuntu下
sudo apt install libqt5widgets5)。 - 若为自定义编译的Qt,设置
LD_LIBRARY_PATH环境变量,指向Qt库路径(如export LD_LIBRARY_PATH=/path/to/qt/lib:$LD_LIBRARY_PATH)。 - 使用
ldd命令检查程序依赖,确保所有动态库路径正确。
Q2:如何在Linux下卸载Qt或Qt Creator?
A:根据安装方式选择不同的卸载方法:
- 包管理器安装:使用对应的卸载命令(如Ubuntu:
sudo apt remove --purge qt5-default qtcreator;Fedora:sudo dnf remove qt5-qtcreator qt5-qtbase-devel)。 - 源码编译安装:进入Qt源码目录的
install目录(如cd qt-everywhere-src-5.15.2),执行sudo make uninstall(若编译时启用了-prefix),或手动删除安装目录(如sudo rm -rf /opt/qt5)。 - 清理残留配置:删除用户配置文件(如
rm -rf ~/.config/QtProject/)和缓存文件(rm -rf ~/.cache/QtProject/)。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/34017.html