インストール - Qt5

提供:MochiuWiki - SUSE, Electronic Circuit, PCB
2021年4月7日 (水) 07:31時点におけるWiki (トーク | 投稿記録)による版 (→‎Qtの構築)
ナビゲーションに移動 検索に移動

概要

ここでは、Qt 5.14のインストール方法を記載する。


通常のインストール

依存関係のライブラリのインストール

Qtの依存関係のライブラリをインストールする。
これらのライブラリは不要な可能性がある。(調査中)

sudo zypper install Mesa-devel Mesa-KHR-devel
または
sudo zypper install Mesa-KHR-devel Mesa-devel Mesa-dri-devel Mesa-libEGL-devel Mesa-libGL-devel Mesa-libGLESv1_CM-devel Mesa-libGLESv2-devel \
                    Mesa-libglapi-devel kbproto-devel libOSMesa-devel libOSMesa8 libX11-devel libXau-devel libdrm-devel libgbm-devel \
                    libglvnd-devel libxcb-devel libxcb-screensaver0 libxcb-xf86dri0 libxcb-xtest0 libxcb-xvmc0 pthread-stubs-devel xproto-devel


Qtのダウンロード

最新版のQtをダウンロードするため、以下のコマンドを実行する。
ファイル情報を知りたい場合はこのWebサイトを参照する。

wget http://download.qt.io/official_releases/online_installers/qt-unified-linux-x64-online.run

ダウンロードしたファイルのアクセス権限を変更する。

chmod +x qt-unified-linux-x64-online.run


Qtのインストール

/usr/localディレクトリ等にインストールする場合は、スーパーユーザでインストールする。
ホームディレクトリにインストールする場合は、ローカルユーザでインストールする。

次に、GCCおよびmake、付随するライブラリをインストールする。

# CentOS
sudo yum groupinstall "Development tools"

# SUSE
sudo zypper install --type pattern devel_basis


Qtをインストールする。

./qt-unified-linux-x64-online.run


Qtのインストール画面に従って、インストールを実行する。


ソースコードからインストール

必須環境

  • Qt 5.14.0以降
  • Qt WebEngine module for QtWebEngine based help viewer
  • GCC 7以降
  • オプション : CMake
    CMakeを使用してLLVM / ClangとQt Creatorをビルドする時に必要である。
  • オプション : Ninja
    CMakeを使用してビルドする時に必要である。
  • オプション : LLVM / Clang 8.0.0以降
    Clang Code Model、Clang Tools、ClangFormat、Clang PCH Manager、Clang Refactoringプラグインに必要である。
    LLVM C++ APIは互換性を保証するものではないので、それ以降のバージョンがコンパイルできない場合は、そのバージョンをサポートしていない。
  • オプション : Qbs 1.7.x
    Qtのソースコードには、Qbs自身も含まれている。


また、Qtをビルドする時のオプション設定を以下に記載する。

# オプション : 環境変数PATHにおいて、llvm-configのパスが通っていない場合に必要である
export LLVM_INSTALL_DIR=<LLVMのインストールディレクトリ>

# オプション : Clangのリファクタリングを無効にする場合、1を設定する
export QTC_DISABLE_CLANG_REFACTORING=1

# オプション : QbsProjectManagerプラグインがQbsを使用する場合に必要である
export QBS_INSTALL_DIR=/path/to/qbs

# オプション : KSyntaxHighlightingを使用する場合、KSYNTAXHIGHLIGHTING_LIB_DIRライブラリを保持するディレクトリを設定する
# インクルードディレクトリの自動推定に失敗する場合、KSYNTAXHIGHLIGHTING_INCLUDE_DIRを設定して、
# 両方の設定をqmakeコマンドのオプションで渡すこともできる
export KSYNTAXHIGHLIGHTING_INCLUDE_DIR=<インクルードファイルを保持するディレクトリ>
export KSYNTAXHIGHLIGHTING_LIB_DIR=<ライブラリを保持するディレクトリ>


依存関係のライブラリのインストール

Qtのソースコードをコンパイルするために必要な依存関係のライブラリをインストールする。

sudo zypper install git-core gcc-c++ make python3 perl \
                    xorg-x11-libxcb-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-renderutil-devel \
                    xcb-util-wm-devel xorg-x11-devel libxkbcommon-x11-devel libxkbcommon-devel libXi-devel \
                    flex bison gperf libicu-devel ruby \
                    alsa-devel dbus-1-devel libXcomposite-devel libXcursor-devel libXrandr-devel libXtst-devel mozilla-nspr-devel \
                    mozilla-nss-devel gperf bison nodejs10 nodejs10-devel \
                    pulseaudio-libs-devel alsa-lib-devel gstreamer1-devel gstreamer1-plugins-base-devel wayland-devel


  • fontconfig-devel
  • libfontenc-devel
  • libXft-devel
  • libx11-devel
  • libxcb-devel
  • libXext-devel
  • libXfixes-devel
  • libXrender-devel
  • libxcb-devel
  • Mesa-libGL-devel
  • xcb-util-keysyms-devel
  • xcb-util-image-devel
  • xcb-util-wm-devel
  • libXfixes-devel
  • xcb-util-renderutil-devel
  • libXinerama-devel
  • libxcb-shm0-dev
  • libxcb-sync0-dev
  • libxcb-shape0-dev


ソースコードのダウンロード

Qtのソースコードをダウンロードする。

git clone --recursive https://code.qt.io/qt-creator/qt-creator.git


ソースコードのビルド

Qtのソースコードをビルドするため、ビルド用のディレクトリを作成する。

mkdir build
cd build


  • qmakeを使用する場合
    オプションのClang Code Modelプラグインをビルドする場合、LLVMのインストールディレクトリへのパスを指定する必要がある。
    export LLVM_INSTALL_DIR=<LLVMのインストールディレクトリ>
    qmake ../qt-creator/qtcreator.pro
    make qmake_all
    make -j 8
    もし、Project ERROR: Unknown module(s) in QT: scriptというエラーが出力される場合、以下のコマンドを実行する。
    make -j 8 module-qtscript

  • cmakeを使用する場合
    Qtのソースコードをビルドする。
    cmake -G Ninja -D CMAKE_BUILD_TYPE=Release -D CMAKE_PREFIX_PATH=<Qtのインストールディレクトリ>; <LLVMのインストールディレクトリ> ../qt-creator
    cmake --build ..


コンパイルには時間が掛かるので気長に待つ。(バイナリファイルは、qt-createor-build/binディレクトリに作成される)

Qtのインストール

Qtをインストールする。

make install INSTALL_ROOT=<Qtのインストールディレクトリ>



デスクトップエントリの追加

以下のコマンドを実行して、デスクトップエントリを追加する。

sudo vi /usr/share/applications/qtcreator.desktop

# qtcreator.desktopファイル
[Desktop Entry]
Type=Application
Exec="/home/ユーザ名/Qt/Tools/QtCreator/bin/qtcreator" %F
Name=Qt Creator
GenericName=The IDE of choice for Qt development.
Icon=QtProject-qtcreator
StartupWMClass=qtcreator
Terminal=false
Categories=Development;IDE;Qt;
MimeType=text/x-c++src;text/x-c++hdr;text/x-xsrc;application/x-designer;application/vnd.qt.qmakeprofile;application/vnd.qt.xml.resource;text/x-qml;text/x-qt.qml;text/x-qt.qbs;


sudo vi /usr/share/applications/Qt-MaintenanceTool.desktop

# Qt-MaintenanceTool.desktopファイル
[Desktop Entry]
Type=Application
Exec=/home/ユーザ名/Qt/MaintenanceTool
Path=/home/ユーザ名/Qt
Name=Qt Maintenance Tool
GenericName=Install or uninstall Qt components.
Icon=/home/ユーザ名/Qt/QtIcon.png
Terminal=false
Categories=Development;Qt;


sudo vi /usr/share/applications/qt-project.qtdesigner.desktop

# qt-project.qtdesigner.desktopファイル
[Desktop Entry]
Type=Application
Exec="/home/ユーザ名/Qt/5.14.0/gcc_64/bin/designer" %F
Name=Qt Designer
GenericName=Qt designer
Icon=/home/ユーザ名/Qt/designer.png
StartupWMClass=qtdesigner
Terminal=false
Categories=Development;IDE;Qt;
MimeType=text/x-c++src;text/x-c++hdr;text/x-xsrc;application/x-designer;application/vnd.qt.qmakeprofile;application/vnd.qt.xml.resource;text/x-qml;text/x-qt.qml;text/x-qt.qbs;



クロスコンパイル

Raspberry Piにおいて、クロスコンパイルを行う手順を記載する。

これは、デスクトップスタイルのソフトウェアをX11の下で実行するためのものではなく、
ソフトウェアがBroadcomドライバを使用して、dispmanx / EGLの上でフルスクリーンで実行するという、
実際の組み込み / デバイス作成のユースケースを想定している。

raspi-configを実行して、Xではなくコンソールで起動するように変更して、VRAMを256[MB]に変更する。(オプション)

sudo raspi-config


ツールチェーン / SDKのセットアップ

Linux PCでRaspberry Pi用のソフトウェアをクロスコンパイルできるように、ツールチェーンをセットアップする。
Raspberry Pi上でネイティブにコンパイルすることもできる。(Linux PCの方がコンパイル速度が速い)

また、Raspbian Stretchの場合は、rpi-updateを実行する必要がある。(詳細については、こちらを参照すること)

sudo rpi-update
reboot


Qtの開発用ライブラリファイルをインストールする。(ここでは簡単にするために、build-depを使用する)
/etc/apt/sources.listファイルのdeb-srcから始まる行のコメントを外す。

sudo vi /etc/apt/sources.list

# /etc/apt/sources.list
# 編集前
#deb-src http://raspbian.raspberrypi.org/raspbian/ stretch main contrib non-free rpi

# 編集後
deb-src http://raspbian.raspberrypi.org/raspbian/ stretch main contrib non-free rpi


sudo apt-get update
sudo apt-get build-dep qt4-x11
sudo apt-get build-dep libqt5gui5
sudo apt-get install libudev-dev libinput-dev libts-dev libxcb-xinerama0-dev libxcb-xinerama0


ターゲットディレクトリを作成する。

sudo mkdir /usr/local/qt5pi
sudo chown pi:pi /usr/local/qt5pi


上記の設定により、Raspberry Piのルートファイルシステムにツールチェインと必要なファイルをインストールすることで、
ソフトウェアのクロスコンパイルができるようになる。

Qtの構築

Linux PC上に作業ディレクトリを作成して、ツールチェーンをダウンロードする。

mkdir -P ~/Program/Qt_Develop && cd ~/Program/Qt_Develop
git clone --depth 1 https://github.com/raspberrypi/tools


Gitを使用せずに、全てのQtモジュールをビルドおよびインストールする場合、以下のコマンドを実行する。

wget http://download.qt.io/official_releases/qt/5.x/5.x.x/single/qt-everywhere-opensource-src-x.x.x.tar.gz
tar xf qt-everywhere-opensource-src-x.x.x.tar.gz
cd qt-everywhere-opensource-src-x.x.x
mkdir build && cd build

../configure -release -opengl es2 -device linux-rasp-pi2-g++ -device-option \
CROSS_COMPILE=~/Program/Qt_Develop/tools/arm-bcmxxxx/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf- \
-sysroot ~/Program/Qt_Develop/sysroot -opensource -confirm-license \
-prefix /usr/local/qt5pi -extprefix ~/Program/Qt_Develop/qt5pi -hostprefix ~/Program/Qt_Develop/qt5 -v

make -j 8
make install 


この状態では、SDKにネイティブのrccバイナリが含まれていないため、rccバイナリをSDKのbinディレクトリにコピーする。
(Qtモジュールを使用するソフトウェアをビルドする場合、このrccバイナリが必要である)

cp ~/Program/Qt_Develop/qtbase/bin/rcc ~/Program/Qt_Develop/qt5pi/bin


Linux PC上に、~/Program/Qt_Develop/sysrootディレクトリを作成する。
rsyncコマンドを使用することにより、同期を取ることができる。

mkdir ~/Program/Qt_Develop/sysroot ~/Program/Qt_Develop/sysroot/usr ~/Program/Qt_Develop/sysroot/opt
rsync -avz <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/lib ~/Program/Qt_Develop/sysroot
rsync -avz <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/lib:/usr/include ~/Program/Qt_Develop/sysroot/usr
rsync -avz <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/lib:/usr/lib ~/Program/Qt_Develop/sysroot/usr
rsync -avz <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/lib:/opt/vc ~/Program/Qt_Develop/sysroot/opt


Linux PC上で、シンボリックリンクを相対的に調整する。
fixQualifiedLibraryPathsが正常に動作しないため、提供されたスクリプトをダウンロードして実行する。

wget https://raw.githubusercontent.com/Kukkimonsuta/rpi-buildqt/master/scripts/utils/sysroot-relativelinks.py
chmod +x sysroot-relativelinks.py
./sysroot-relativelinks.py ~/Program/Qt_Develop/sysroot


Linux PC上で、qtbaseの取得とQtの設定を行う。
ターゲットディレクトリは、Piでは/usr/local/qt5pi、qmake等のホストツールでは~/raspi/qt5、
make installでは、~/Program/Qt_Develop/qt5piをターゲットにする。(Raspberry Piと同期するのは、このディレクトリである)

<qt-version>を適切なQtのバージョンに変更する必要がある。(例. 5.12.1や5.15.2等)
<rpi-version>を適切なRaspberry Piのバージョンに変更する必要がある。
Raspberry Piにはlinux-rasp-pi-g++、Raspberry Pi 2にはlinux-rasp-pi2-g++、Reaspberry Pi 3にはlinux-rasp-pi3-g++を使用する。

Raspbianが64ビットの場合は、デバイスオプションを以下のように編集する。
また、Qt 5.9以降は、-no-use-gold-linkerオプションを追加する必要がある。

-device-option CROSS_COMPILE=~/raspi/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian-x64/bin/arm-linux-gnueabihf-


git clone --depth 1 git://code.qt.io/qt/qtbase.git -b <qt-version>
cd qtbase

./configure -release -opengl es2 -device <rpi-version> \
-device-option CROSS_COMPILE=~/raspi/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/arm-linux-gnueabihf- \
-sysroot ~/raspi/sysroot -opensource -confirm-license -make libs \
-prefix /usr/local/qt5pi -extprefix ~/raspi/qt5pi -hostprefix ~/raspi/qt5 -v

make -j 8
make install


失敗した場合は、全てを削除するために以下のコマンドを実行する。

git clean -dfx


Linux PC上で、QtをRaspberry Piにデプロイする。
ここでは、~/Program/Qt_Develop/qt5piから上で設定したプレフィックスに全てを同期させる。

rsync -avz ~/Program/Qt_Develop/qt5pi <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/usr/local


Linux PC上で、Qtのサンプルプログラムをビルドして動作確認を行う。
ビルドの完了後、実行ファイルをRaspberry Piにコピーする。

cd qtbase/examples/opengl/qopenglwidget

~/Program/Qt_Develop/qt5/bin/qmake

make -j 8

scp qopenglwidget <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/home/pi


Raspberry Pi上で、リンカがQtライブラリを見つけられるように、Raspberyy Piを更新する。
もし、サンプルの実行に問題がある場合は、qt5pi.confの代わりに00-qt5pi.confを使用して、適切な順序を導入する。

echo /usr/local/qt5pi/lib | sudo tee /etc/ld.so.conf.d/qt5pi.conf
sudo ldconfig


Raspberry Pi上で、EGL / GLESライブラリを修正する。
Raspberry Piの/usr/lib/arm-linux-gnueabihfディレクトリには、MesaのlibEGLとlibGLESv2が存在する。
Qtソフトウェアは、/opt/vc/libディレクトリにあるライブラリではなく、これらを選択することになる。

これは、OpenGLのパフォーマンスを気にしないX11デスクトップソフトウェアには都合が良いが、
フルスクリーンの組み込みソフトウェアをウィンドウ化するには全く役に立たない。

オリジナルのファイルは、必ず、バックアップする。

sudo mv /usr/lib/arm-linux-gnueabihf/libEGL.so.1.0.0 /usr/lib/arm-linux-gnueabihf/libEGL.so.1.0.0_org
sudo mv /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2.0.0 /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2.0.0_org
sudo ln -s /opt/vc/lib/libEGL.so /usr/lib/arm-linux-gnueabihf/libEGL.so.1.0.0
sudo ln -s /opt/vc/lib/libGLESv2.so /usr/lib/arm-linux-gnueabihf/libGLESv2.so.2.0.0
sudo ln -s /opt/vc/lib/libbrcmEGL.so /opt/vc/lib/libEGL.so
sudo ln -s /opt/vc/libbrcmGLESv2.so /opt/vc/libGLESv2.so


また、見つからないシンボリックリンクも追加する。

sudo ln -s /opt/vc/lib/libEGL.so /opt/vc/lib/libEGL.so.1
sudo ln -s /opt/vc/libGLESv2.so /opt/vc/lib/libGLESv2.so.2


以下の例では、Linux PC上で、Qtソフトウェアをダウンロードしてビルドしている。
(<qt-module>と<qt-version>はユーザ環境に合致するものを記述する)

git clone git://code.qt.io/qt/<Qtソフトウェアのサンプルプロジェクト>.git -b <qt-version>
cd <Qtソフトウェアのサンプルプロジェクト>

~/Program/Qt_Develop/qt5/bin/qmake
make -j 8
make install


最後に、Qtソフトウェアをデプロイする。

rsync -avz qt5pi <Raspberry Piのユーザ名>@<Raspberry Piのホスト名またはIPアドレス>:/usr/local