-
Notifications
You must be signed in to change notification settings - Fork 9
Qt5
Qt is a great framework for creating (not only) embedded applications with appealing GUIs. The apps are traditionally written in C++, but GUI design can be done in QML, a descriptive language. There is a rich library of platform independent C++ classes, somehow comparable to JAVA or .NET. Read more on the homepage https://www.qt.io/.
The rpi-avg-image
can be built with Qt5 support: LinuxFB (framebuffer) and EGLFS ( EGL) are configured as QPAs (Qt Platform Abstraction) and OpenGL ES 2.0 (OpenGL) is used for hardware accelerated drawing.
Check that the Qt5 related packages are included in the rpi-image-avg.bb recipe, like:
IMAGE_INSTALL_append += " \
qtbase \
qtbase-dev \
qtbase-mkspecs \
qtbase-plugins \
qtbase-tools \
qt3d \
qt3d-dev \
qt3d-mkspecs \
qtcharts \
qtcharts-dev \
qtcharts-mkspecs \
qtconnectivity-dev \
qtconnectivity-mkspecs \
qtquickcontrols2 \
qtquickcontrols2-dev \
qtquickcontrols2-mkspecs \
qtdeclarative \
qtdeclarative-dev \
qtdeclarative-mkspecs \
qtgraphicaleffects \
qtgraphicaleffects-dev \
qtsensors \
qtsensors-dev \
qtsensors-mkspecs \
"
For bitbake, the currently used branch of the Qt5 layer git://github.com/meta-qt5/meta-qt5.git
must be cloned parallel to the other layers in the recipes
folder and added to bblayers.conf.
Read more about using the meta-qt5
layer: https://doc-snapshots.qt.io/qtfordevicecreation-5.11/qtee-meta-qt5.html
rpi-avg-image
comes with the cimematicExperience example.
You might have to specify the correct graphical backend for running the examples:
export QT_QPA_PLATFORM=eglfs
root@raspberrypi3:~# /usr/share/cinematicexperience-1.0/Qt5_CinematicExperience
or alternatively specify it on the command line:
root@raspberrypi3:~# /usr/share/cinematicexperience-1.0/Qt5_CinematicExperience -platform eglfs
On the HDMI monitor, you should see a smooth rendering with 60 fps and, with htop
, only a moderate CPU usage of some 20%.
http://www.jumpnowtek.com/rpi/Qt5-and-QML-Development-with-the-Raspberry-Pi.html has a small app qqtest
which can be used for a first GUI test including a USB mouse for input.
Make sure that qtbase is configured with eglfs
, gles2
and linuxfb
. See https://github.com/jumpnow/meta-rpi/blob/rocko/recipes-qt/qt5/qtbase_git.bbappend. A nearby recipe https://github.com/jumpnow/meta-rpi/blob/rocko/recipes-qt/qt5-env/files/qt5-env.sh shows hot to automate path and environment settings.
After installing the image and booting the RasPi: compile a demo app on the RasPi.
root@raspberrypi3:~# wget http://quitcoding.com/download/Qt5_CinematicExperience_rpi_1.0.tgz
root@raspberrypi3:~# tar xvf Qt5_CinematicExperience_rpi_1.0.tgz
root@raspberrypi3:~# cd Qt5_CinematicExperience_rpi_1.0
### a patch needs to be applied, see http://wickwire2099.blogspot.de/2014/05/qt-530-qt5-cinematic-experience.html)
root@raspberrypi3:~/Qt5_CinematicExperience_rpi_1.0# sed -i 's/onText/textON/g' content/Switch.qml content/SettingsView.qml
root@raspberrypi3:~/Qt5_CinematicExperience_rpi_1.0# sed -i 's/offText/textOFF/g' content/Switch.qml content/SettingsView.qml
root@raspberrypi3:~/Qt5_CinematicExperience_rpi_1.0# qmake
root@raspberrypi3:~/Qt5_CinematicExperience_rpi_1.0# make
root@raspberrypi3:~/Qt5_CinematicExperience_rpi_1.0# ./Qt5_CinematicExperience
Output on HDMI monitor. USB mouse recommended.
There is also a bitbake recipe for it: bitbake cinematicexperience
would have build the demo on the build host.
Build (cross-compile) a test app on the build host.
From a bitbake shell:
frank@FrankBuntuSSD:~/raspi/build$ bitbake qt5-opengles2-test
The output package resides in one of the ${BUILDDIR}/tmp/deploy/ipk/*
folders.
This time we don't use the package server, but a mere copy over the network (adjust IP address accordingly):
frank@FrankBuntuSSD:~/raspi/build$ scp ${BUILDDIR}/tmp/deploy/ipk/*/qt5-opengles2-test_1.0.4*.ipk [email protected]:/home/root
On the RasPi install the package:
root@raspberrypi3:~# opkg install qt5-opengles2-test_1.0.4+gitr0+9383905070-r0_cortexa7hf-neon-vfpv4.ipk
and start it:
root@raspberrypi3:~# qt5-opengles2-test
Watch the output on an attached HDMI monitor. Its a quite simple test app only, but it demonstrates that all APIs needed are functional. I might be useful to study its recipe under sources/meta-qt5/recipes-qt/examples/qt5-opengles2-test_git.bb
.