Kirigami con C++
Installazione di Kirigami
Before getting started, we will need to install Kirigami on our machine. There are three ways to do so:
- Installazione di Kirigami dai depositi della tua distribuzione
- Uso di kde-builder
- Installazione di Kirigami con Craft
If you are on a sufficiently up-to-date distribution such as Debian Testing, latest non-LTS Ubuntu, Fedora, openSUSE Tumbleweed, or Arch, you may install Kirigami from your distribution.
If you are on a not up-to-date distribution such as Debian Stable or LTS Ubuntu, you should use kde-builder for this tutorial. It should use at most 2 GB of storage.
Installazione di Kirigami dai depositi della tua distribuzione
We need a C++ compiler, Qt development packages, and Kirigami. Open a terminal application and run one of the following, depending on which Linux distribution you are using:
| sudo apt install build-essential cmake extra-cmake-modules libkirigami-dev libkf6i18n-dev libkf6coreaddons-dev libkf6iconthemes-dev qt6-base-dev qt6-declarative-dev libkf6qqc2desktopstyle-dev | |
| sudo pacman -S base-devel extra-cmake-modules cmake kirigami ki18n kcoreaddons breeze kiconthemes qt6-base qt6-declarative qqc2-desktop-style | |
| sudo zypper install cmake kf6-extra-cmake-modules kf6-kirigami-devel kf6-ki18n-devel kf6-kcoreaddons-devel kf6-kiconthemes-devel qt6-base-devel qt6-declarative-devel qt6-quickcontrols2-devel kf6-qqc2-desktop-style | |
| sudo dnf install @development-tools @development-libs cmake extra-cmake-modules kf6-kirigami2-devel kf6-ki18n-devel kf6-kcoreaddons-devel kf6-kiconthemes-devel qt6-qtbase-devel qt6-qtdeclarative-devel qt6-qtquickcontrols2-devel kf6-qqc2-desktop-style | 
Further information for other distributions can be found here.
Usare kde-builder
Set up your development environment with kde-builder. That will give you the necessary development tools and underlying libraries, and build the KDE Frameworks from scratch.
Create a folder ~/kde/src/kirigami-tutorial. In that folder you will place the source code files from this tutorial.
Aggiungere quanto segue alla fine di ~/.config/kde-builder.yaml:
project kirigami-tutorial:
  repository: ""
  no-src: true⏳ Con kdesrc-build...
Click here to know how this was done with kdesrc-build
This step used to be done by writing to ~/.config/kdesrc-buildrc instead with a different syntax:
# after include ${module-definitions-dir}/kf6-qt6.ksb
module kirigami-tutorial
  no-src
end moduleInstallazione di Kirigami con Craft
KDE has a custom tool to easily install most of its libraries and programs: Craft. It can be used to install Kirigami on Windows, Android and macOS.
While Craft is also available for Linux and FreeBSD, its intended use is only for AppImages and packaging.
You will need to follow the setup instructions for Craft. By the end of the setup, you should have run an environment setup file (craftenv.ps1 or craftenv.sh), which will give you a terminal shell where you will be compiling your Kirigami application.
After that, you may simply run the following on a terminal:
craft kirigami kcoreaddons ki18n breeze kiconthemes qqc2-desktop-styleThis will take a long while to finish on first run. If you close your terminal, you can simply run the environment setup file again to compile your app.
Struttura del progetto
Sebbene esistano degli strumenti che possono impostare facilmente i file, li creeremo manualmente. Questo ci consentirà di capire meglio tutti i pezzi che costituiranno la nostra nuova applicazione.
First we create our project folder (you can use the commands below). We are going to call ours kirigami-tutorial/.
kirigami-tutorial/
├── CMakeLists.txt
├── org.kde.tutorial.desktop
└── src/
    ├── CMakeLists.txt
    ├── main.cpp
    └── Main.qmlWithin this folder we are going to create a src/ folder and CMakeLists.txt. It is generally considered good practice to place all our main C++ code files in a src/ folder. We also put the Main.qml file in it since it will be run together with the executable.
Suggerimento
Puoi creare rapidamente questa struttura di file con:
mkdir -p kirigami-tutorial/src
touch kirigami-tutorial/{CMakeLists.txt,org.kde.tutorial.desktop}
touch kirigami-tutorial/src/{CMakeLists.txt,main.cpp,Main.qml}Nota
In case you want to automatically build the project with kde-builder, custom module name should be the same as the project root folder (in our case it will be "kirigami-tutorial"), otherwise you would need to customize thesource-dir or dest-dir for the module. We will assume the path to your main.cpp will be ~/kde/src/kirigami-tutorial/src/main.cpp.Main.qml
|  |  | 
Ecco dove gestiremo l'interfaccia della nostra applicazione.
Se conosci un po' di Javascript, allora la gran parte di QML ti sembrerà familiare (sebbene abbia delle sue caratteristiche proprie)). Se hai voglia di provare a fare qualcosa da solo la documentazione di Qt ha un'ampia quantità di materiale su questo linguaggio. In queste esercitazioni focalizzeremo la nostra attenzione principalmente sul codice QML, nel quale possiamo utilizzare Kirigami per ottenerne il massimo.
For now, let's focus on Main.qml. First we import a number of important modules:
- QtQuick, the standard library used in QML applications.
- QtQuick Controls, which provides a number of standard controls we can use to make our applications interactive.
- QtQuick Layouts, which provides tools for placing components within the application window.
- Kirigami, which provides a number of components suited for creating applications that work across devices of different shapes and sizes.
Nota
Putting the QtQuick Controls and Kirigami imports into separate namespaces using theas keyword is a best practice that ensures no components with the same name can conflict. You might see different names for QtQuick Controls in the wild, such as "QQC" or "QQC2". We will be using "Controls" in this tutorial for clarity.We then come to our base element, Kirigami.ApplicationWindow, which provides some basic features needed for all Kirigami applications. This is the window that will contain each of our pages, the main sections of our UI.
We then set the window's id property to "root". IDs are useful because they let us uniquely reference a component, even if we have several of the same type.
Abbiamo anche impostato la proprietà title a Hello World". Noterai che abbiamo messo la stringa Hello World in una funzione chiamata i18nc(), nella quale abbiamo dettagliato il contesto della stringa e la stringa stessa.
Nota
i18n() functions make your app more easily translatable, as they return a version of the provided string in the user's language (as long as your app has been localised for that language). While an English user might see our window title as "Hello World", a Spanish user would see "Hola Mundo".
i18nc() builds on the i18n() function by allowing developers to provide some context to translators working on the app. Here we clarify that the UI component is the title of the application window, so we have included the string "@title:window" before "Hello World". See the Ki18n Programmer's guide for more details.
We then set the first page of our page stack. Most Kirigami applications are organised as a stack of pages, each page containing related components suited to a specific task. For now, we are keeping it simple, and sticking to a single page. pageStack is an initially empty stack of pages provided by Kirigami.ApplicationWindow, and with pageStack.initialPage: Kirigami.Page {...} we set the first page presented upon loading the application to a Kirigami.Page. This page will contain all our content.
Finally, we include in our page a Controls.Label that lets us place text on our page. We use anchors.centerIn: parent to center our label horizontally and vertically within our parent element. In this case, the parent component of our label is Kirigami.Page. The last thing we need to do is set its text: text: i18n("Hello World!").
org.kde.tutorial.desktop
The primary purpose of Desktop Entry files is to show your app on the application launcher on Linux. Another reason to have them is to have window icons on Wayland, as they are required to tell the compositor "this window goes with this icon".
It must follow a reverse-DNS naming scheme followed by the .desktop extension such as org.kde.tutorial.desktop:
|  |  | 
Nota
Window and taskbar icons will work in a Wayland session only if apps' desktop files are placed in~/.local/share/applications or /usr/share/applications. To get icons working in this tutorial, either copy the app's desktop file there or switch to a development session as instructed in kde-builder tutorial. Some KDE applications might have working icons if they were already installed on the system.CMakeLists.txt
CMakeLists.txt files are needed to use KDE's build system of choice, CMake. Our kirigami-tutorial/CMakeLists.txt file is going to specify some of our application's characteristics. It also includes some of the dependencies we need in order to compile our project.
|  |  | 
The CMakeLists.txt defines how to build your projects. Most of the content here is just to bootstrap your project. You can read a line-by-line, in-depth explanation of what this CMakeLists file does here.
The most important thing to keep in mind is that the C++ build dependencies of Qt and KDE Frameworks are managed with find_package() and QML runtime dependencies are managed with ecm_find_qml_module(). You will have to modify these lines and include any additional components that you decide to use during the development of your application.
The line with add_subdirectory(src) points CMake to the kirigami-tutorial/src/ directory, where our source code is located.
The line with install() tells CMake where to install the desktop file.
Let's delve into the kirigami-tutorial/src/CMakeLists.txt file in there.
|  |  | 
This file consists of five steps:
- crea un eseguibile
- change the executable into a QML module that accepts QML files
- add C++ and QML files to the executable
- link the libraries necessary for the executable to run
- install the executable to the right place
Next time you need to add more QML files, add them to the existing ecm_target_qml_sources() call. C++ files that use the QML_ELEMENT keyword which we will see later in the tutorial can be added using target_sources().
Ora che CMake se n'è preso cura, vediamo i file su cui lavoreremo di più.
main.cpp
The file kirigami-tutorial/src/main.cpp handles the "business logic" of our application. C++ is handy because it is flexible and fast, even if it is more involved than other programming languages.
It also functions as the entrypoint to our application. The two parts of our project, the backend and the user interface, are both set up and started here.
|  |  | 
For now, we don't need to go into too much detail regarding what our main.cpp code does, but its role will grow significantly more important once we decide to add more complex functionality to our application in the future.
Theming on Windows
Fai clic qui per leggere di più
The application needs to set its icon theme, QStyle, and QtQuick Controls style to Breeze in order to show up on Windows. To learn more about it, see Figuring out main.cpp.
If you want to get ahead, you can read more about how this main.cpp works in Figuring out main.cpp.
If you want to see a few ways on how the C++ code can be improved, like using KAboutData for translatable application metadata, be sure to check our KXmlGui tutorial.
For now, the part that interests us is this line:
engine.loadFromModule("org.kde.tutorial", "Main");The first argument is the URI set in kirigami-tutorial/src/CMakeLists.txt, and the second argument is the name of the QML module we want to use (Main, coming from the name of our Main.qml file, which needs to start with an uppercase letter).
Il vecchio metodo
You might encounter this alternative way to load QML files in real code!
The old method of loading QML files had some disadvantages and after Qt6 it became excessively verbose:
engine.load(QUrl(QStringLiteral("qrc:/qt/qml/org/kde/tutorial/qml/Main.qml")));This Qt resource URI above follows the pattern <resource_prefix><import_URI><optional_QML_dir><file>. In this case:
- resource prefix = default / in Qt5, /qt/qml in Qt6
- import URI = /org/kde/tutorial, which matches the URI org.kde.tutorial
- optional QML dir = /qml, necessary if the QML files are stored in a directory called qml/
- file = il file QML
Compilazione ed installazione dell'applicazione
We are almost at the finish line. The last thing we need to do is build and run our application. Doing so will depend on which platform you are on.
Linux o FreeBSD
Compiling with kde-builder
Make sure you have followed the instructions in Using kde-builder.
Compile the necessary build dependencies with kde-builder, then compile kirigami-tutorial by running the following commands in a terminal:
kde-builder kirigami ki18n kcoreaddons breeze kiconthemes qqc2-desktop-style
kde-builder kirigami-tutorialCompilazione manuale
Change directories to the project's root folder, then run the following command in a terminal:
cmake -B build/ --install-prefix ~/.local
cmake --build build/
cmake --install build/The program will be installed to ~/.local/bin and its desktop entry to ~/.local/share/applications.
Windows
If you are compiling your project on Windows after having set up Craft, CMake should automatically detect the right compiler:
cmake -B build/
cmake --build build/
cmake --install build/Depending on how you installed the compiler, you might need to specify a CMake Generator for the first step, depending on whether you are using Visual Studio (msvc) or MinGW (make) to compile your projects.
If Visual Studio, depending on the compiler you chose to install, it might be:
cmake -B build/ -G "Visual Studio 16 2019"Oppure:
cmake -B build/ -G "Visual Studio 17 2022"If MinGW:
cmake -B build/ -G "MinGW Makefiles"
cmake --build build/
cmake --install build/In both cases, the program will be installed to C:\CraftRoot\bin.
If you ever get in doubt as to the name of the compiler that should be used in the cmake call, run:
cmake -GIt will list all available generators.
Esecuzione dell'applicazione
Puoi avviare il programma kirigami-hello con:
kirigami-hello # Su Linux, manualmente
kde-builder --run kirigami-hello # Con kde-builder
kdesrc-build --run --exec kirigami-hello kirigami-tutorial # Con kdesrc-build
kirigami-hello.exe # In WindowsVoilà! Now you will see your very first Kirigami app appear before your very own eyes.

To run the new QML application in mobile mode, you can use QT_QUICK_CONTROLS_MOBILE=1:
QT_QUICK_CONTROLS_MOBILE=1 kirigami-helloIf you have compiled the project manually with CMake and for some reason you'd like to uninstall the project, you can run:
cmake --build build/ --target uninstallNota
Next time you want to create the files and folders needed, you can use KAppTemplate or KDevelop to automatically generate a suitable project to start from. They are available from each major distribution's repositories. These applications will also generate files containing AppStream metadata and a .desktop file that contains information about how the application should be displayed in a linux application launcher.
Thanks to the magic of CMakeLists, you can also use IDEs such as KDevelop or QtCreator to develop this application within a comfortable environment with minimal effort.