Kirigami med C++
Installera Kirigami
Innan vi börjar måste vi installera Kirigami på datorn. Det finns tre sätt att göra det:
- Installera Kirigami från arkiven i Linux-distribution
- Använda kde-builder
- Installera Kirigami med Craft
Installera Kirigami från arkiven i Linux-distribution.
Vi behöver en C++-kompilator, Qt-utvecklingspaket och Kirigami. Öppna ett terminalprogram och kör något av följande, beroende på vilken Linux-distribution du använder:
ManjaroArch | sudo pacman -S base-devel extra-cmake-modules cmake kirigami ki18n kcoreaddons breeze kiconthemes qt6-base qt6-declarative qqc2-desktop-style |
OpenSUSE | 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 |
Fedora | sudo dnf groupinstall "Development Tools" "Development Libraries" sudo dnf install 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 |
Ytterligare information för andra distributioner finns här.
Använda kde-builder
Ställ in utvecklingsmiljön med kde-builder. Det ger nödvändiga utvecklingsverktyg och underliggande bibliotek, och bygger KDE:s ramverk från grunden.
Skapa katalogen ~/kde/src/kirigami-tutorial
. I den katalogen placeras källkodsfilerna från handledningen.
Lägg till följande i slutet på ~/.config/kde-builder.yaml
:
project kirigami-tutorial:
no-src: true
⏳ Med kdesrc-build...
Klicka här för att ta reda på hur det gjordes med kdesrc-build
Steget gjordes tidigare genom att istället skriva till ~/.config/kdesrc-buildrc
med en annan syntax:
# after include ${module-definitions-dir}/kf6-qt6.ksb
module kirigami-tutorial
no-src
end module
Installera Kirigami med Craft
KDE har ett eget verktyg för att enkelt installera de flesta av dess bibliotek och program: Craft. Det kan användas för att installera Kirigami på Linux, FreeBSD, Windows, Android och macOS.
Du måste följa installationsinstruktionerna för Craft. I slutet av installationen ska du ha kört en miljöinstallationsfil (craftenv.ps1
eller craftenv.sh
), som ger dig ett skal i en terminal där du kan kompilera ditt Kirigami-program.
Därefter kan du helt enkelt köra följande på en terminal:
craft kirigami kcoreaddons ki18n breeze kiconthemes qqc2-desktop-style
Om du stänger din terminal kan du helt enkelt köra miljöinstallationsfilen igen för att kompilera ditt program.
Projektstruktur
Även om det finns verktyg som enkelt kan skapa våra filer, kommer vi att skapa dem manuellt. Det låter oss förstå delarna som utgör vårt nya program bättre.
Först skapar vi vår projektkatalog (du kan använda kommandona nedan). Vi kallar vår kirigami-tutorial/
.
kirigami-tutorial/
├── CMakeLists.txt
├── org.kde.tutorial.desktop
└── src/
├── CMakeLists.txt
├── main.cpp
└── Main.qml
Under katalogen skapar vi katalogen src/
och CMakeLists.txt
. Det anses i allmänhet vara god praxis att placera alla våra huvudsakliga C++ källkodsfiler i katalogen src
. Vi placerar också filen Main.qml
i den eftersom den används tillsammans med det körbara programmet.
Tips
Du kan snabbt skapa filstrukturen med:
mkdir -p kirigami-tutorial/src
touch kirigami-tutorial/{CMakeLists.txt,org.kde.tutorial.desktop}
touch kirigami-tutorial/src/{CMakeLists.txt,main.cpp,Main.qml}
Anmärkning
Om projektet ska byggas automatiskt med kde-builder, bör det egna modulnamnet vara detsamma som projektets rotkatalog (i vårt fall är det "kirigami-tutorial"), annars skulle man behöva ange "source-dir" eller "dest-dir" för modulen. Vi antar att sökvägen tillmain.cpp
är ~/kde/src/kirigami-tutorial/src/main.cpp
.Main.qml
|
|
Här är stället där vi hanterar vårt förgrundsprogram.
Om du kan lite Javascript ser mycket av QML bekant ut (även om det har sina egenheter). Qt:s dokumentation har en omfattande mängd material om språket om du känner för att prova något på egen hand. Genom alla de här handledningarna kommer vi att fokusera mycket av vår uppmärksamhet på vår QML-kod, där vi kan använda Kirigami för att få ut så mycket som möjligt av den.
Låt oss för tillfället fokusera på Main.qml
. Först importerar vi ett antal viktiga moduler:
- QtQuick, standardbiblioteket som används i QML-program.
- QtQuick Controls, som tillhandahåller ett antal standardkontroller som vi kan använda för att göra vårt program interaktivt.
- QtQuick Layouts, som tillhandahåller verktyg för att placera komponenter inom programmets fönster.
- Kirigami, som tillhandahåller ett antal komponenter lämpade för att skapa program som fungerar över apparater av olika form och storlek.
Anmärkning
Att placera QtQuick-kontroller och Kirigami-import i separata namnrymder med nyckelordetas
är bästa praxis för att säkerställa att inga komponenter med samma namn kan orsaka konflikt. Du kan se olika namn för QtQuick Controls i verkligheten, såsom "QQC" eller "QQC2". Vi använder "Controls" i handledningen för tydlighetens skull.Sedan kommer vi till vårt baselement, Kirigami.ApplicationWindow som tillhandahåller några grundfunktioner nödvändiga för alla Kirigami-program. Det är fönstret som kommer att innehålla alla våra sidor, huvuddelen av vårt användargränssnitt.
Vi ställer sedan in fönstrets egenskap id
till 'root'. Identifierare är användbara eftersom de låter oss referera till en komponent unikt, även om vi har flera av samma typ.
Vi ställer också in fönstrets egenskap title
till "Hello World". Du märker att vi har omgivit vår "Hello World" sträng med en funktion som heter i18nc()
, där vi beskriver strängens sammanhang förutom själva strängen.
Anmärkning
i18n()-funktioner gör programmet lättare att översätta, eftersom de returnerar en version av den tillhandahållna strängen på användarens språk (under förutsättning att vårt program har översatts till det språket). Även om en engelskspråkig användare ser vår fönstertitel som 'Hello World', skulle en spansk användare kunna se "Hola Mundo".
i18nc() bygger på funktionen i18n()
genom att tillåta utvecklare att ge visst sammanhang till översättarna som arbetar med programmet. Det är därför vi har inkluderat strängen "@title" innan "Hello World". Se Ki18n Programmer's guide för mer information.
Därefter anger vi första sidan i vår sidstapel. Del flesta Kirigami-program är organiserade som en stapel av sidor, där varje sida innehåller relaterade komponenter anpassade för en viss uppgift. För närvarande låter vi det vara enkelt, och håller oss till en enda sida. pageStack är en sidstapel som initialt är tom som Kirigami.ApplicationWindow tillhandahåller, och med pageStack.initialPage: Kirigami.Page {...}
ställer vi in den första sidan som presenteras när programmet laddas i en Kirigami.Page. Sidan står för allt vårt innehåll.
Slutligen inkluderar vi en Controls.Label på vår sida, som låter oss placera text på den. Vi använder anchors.centerIn: parent
för att centrera vår beteckning horisontellt och vertikalt inom vårt överliggande element. I det här fallet är det överliggande elementet för Controls.Label
vår Kirigami.Page. Det sista vi behöver göra är att ange texten: text: i18n("Hello World!")
.
org.kde.tutorial.desktop
Det primära syftet med Desktop Entry-filer är att visa programmet i programstart på Linux. En annan anledning att ha dem är att ha fönsterikoner på Wayland, eftersom de måste tala om för sammansättningen att "det här fönstret hör ihop med den här ikonen".
Det måste följa ett omvänt domännamnsschema följt av tillägget .desktop
såsom org.kde.tutorial.desktop
:
|
|
Anmärkning
Fönster- och aktivitetsradsikoner fungerar bara i en Wayland-session om programmens skrivbordsfiler placeras i~/.local/share/applications
eller /usr/share/applications
. För att få ikoner att fungera i den här handledningen kopiera antingen programmets skrivbordsfil dit eller byt till en utvecklingssession enligt instruktionerna i kde-builder tutorial. Vissa KDE-program kan ha fungerande ikoner om de redan har installerats på systemet.CMakeLists.txt
Filerna kallade CMakeLists.txt
behövs för att använda KDE:s utvalda byggsystem, CMake. Vår kirigami-tutorial/CMakeLists.txt
specificerar vissa av programmets egenskaper. Den inkluderar också några av de beroenden vi behöver för att kunna kompilera vårt projekt.
|
|
CMakeLists.txt
definierar hur dina projekt byggs. Det mesta av innehållet här är bara för att projektet ska komma igång. Du kan läsa en radvis, djupgående, förklaring av vad CMakeLists filen gör här.
Det viktigaste att komma ihåg är att C++ beroenden av Qt och KDE Ramverk hanteras med find_package() och QML körtidsberoenden hanteras med ecm_find_qml_module(). Du måste ändra raderna och inkludera alla ytterligare komponenter som du bestämmer dig för att använda under utvecklingen av programmet.
Raden med add_subdirectory(src)
, pekar CMake på katalogen 'kirigami-tutorial/src/', där vår källkod finns.
Raden med install()
talar om för CMake var skrivbordsfilen ska installeras.
Låt oss fördjupa oss i filen kirigami-tutorial/src/CMakeLists.txt
där.
|
|
Filen består av fem steg:
- skapa en körbar fil
- ändra den körbara filen till en QML-modul som accepterar QML-filer
- lägg till C++ och QML-filer i den körbara filen
- länka biblioteken som krävs för att körbara filen ska köras
- installera den körbara filen på rätt plats
Nästa gång fler QML-filer behöver läggas till, gör det i det befintliga anropet ecm_target_qml_sources()
. C++ filer som använder nyckelordet QML_ELEMENT, som vi kommer att se senare i handledningen, kan läggas till med target_sources()
.
Nu när vi har tagit hand om CMake, låt oss titta på filerna vi ska spendera den största delen av tiden att arbeta med.
main.cpp
Filen kirigami-tutorial/src/main.cpp
hanterar "uppgiftslogiken" i vårt program. C++ är praktiskt eftersom det är flexibelt och snabbt, även om det är mer omfattande än andra programspråk.
Den fungerar också som programmets startpunkt. De två delarna av vårt projekt, bakgrund och användargränssnittet, skapas och startas båda här.
|
|
För tillfället behöver vi inte gå in på detaljerna rörande vad vår kod i main.cpp
gör i så stor utsträckning, men dess roll växer signifikant när vi bestämmer oss för att lägga till mer komplicerad funktionalitet i vårt program i framtiden.
Tema på Windows
Klicka här för att läsa mer
Programmet måste ställa in sitt ikontema, QStyle och QtQuick Controls-stil i Breeze för att visas på Windows. För att lära dig mer om det, se Förstå sig på main.cpp.
Om du vill komma framåt, kan du läsa mer om hur main.cpp
fungerar i Figuring out main.cpp.
Om du vill se några sätt C++ koden kan förbättras, som att använda KAboutData för översättbar metadata i programmet, se till att ta en titt på vår KXmlGui handledning /kxmlgui).
För tillfället är den del som intresserar oss den här raden:
engine.loadFromModule("org.kde.tutorial", "Main");
Det första argumentet är URI angiven i kirigami-tutorial/src/CMakeLists.txt
, och det andra argumentet är namnet på QML-modulen vi vill använda (Main
, kommer från namnet på vår Main.qml
-fil, som måste börja med en stor bokstav).
Den gamla metoden
Du kan stöta på det här alternativa sättet att ladda QML-filer i riktig kod!
Den gamla metoden att ladda QML-filer hade några nackdelar och efter Qt6 blev den överdrivet omfattande:
engine.load(QUrl(QStringLiteral("qrc:/qt/qml/org/kde/tutorial/qml/Main.qml")));
Ovanstående Qt resurs-URI följer mönstret <resurs_prefix><import_URI><valfri_QML_kaalog><fil>
. I vårt fall:
- resource prefix = default / i Qt5, /qt/qml i Qt6
- import URI = /org/kde/tutorial, som motsvarar webbadressen org.kde.tutorial
- optional QML dir = /qml, nödvändigt om QML-filerna lagras i en katalog som heter qml/
- file = QML-filen
Kompilera och installera programmet
Vi har nästa nått mållinjen. Det sista vi måste göra är att bygga och köra vårt program. Hur man gör det beror på vilken plattform som används.
Linux eller FreeBSD
Kompilera med kde-builder
Säkerställ att instruktionerna i Använda kde-builder har följts.
Kompilera de nödvändiga byggberoendena med kde-builder, kompilera sedan kirigami-tutorial
genom att köra följande kommandon i en terminal:
kde-builder kirigami ki18n kcoreaddons breeze kiconthemes qqc2-desktop-style
kde-builder kirigami-tutorial
Kompilera manuellt
Byt katalog till projektets rotkatalog och kör sedan följande kommando i en terminal:
cmake -B build/ --install-prefix ~/.local
cmake --build build/
cmake --install build/
Programmet installeras i ~/.local/bin
och dess skrivbordspost i ~/.local/share/applications
.
Windows
Om du kompilerar projektet på Windows efter att ha ställt in Craft, ska CMake automatiskt upptäcka rätt kompilator:
cmake -B build/
cmake --build build/
cmake --install build/
Beroende på hur du installerade kompilatorn, kan du behöva ange en CMake Generator för det första steget, beroende på om du använder Visual Studio (msvc) eller MinGW (make) för att kompilera dina projekt.
Om Visual Studio, beroende på kompilatorn du valde att installera, kan det vara:
cmake -B build/ -G "Visual Studio 16 2019"
Eller:
cmake -B build/ -G "Visual Studio 17 2022"
För MinGW:
cmake -B build/ -G "MinGW Makefiles"
cmake --build build/
cmake --install build/
I båda fall, installeras programmet i C:\CraftRoot\bin
.
Om du någon gång tvivlar på namnet på kompilatorn som ska användas i 'cme-anropet', kör:
cmake -G
Det listar alla tillgängliga generatorer.
Köra programmet
Därefter kan programmet kirigami-hello
köras med:
kirigami-hello # På Linux, manuellt
kde-builder --run kirigami-hello # Med kde-builder
kdesrc-build --run --exec kirigami-hello kirigami-tutorial # Med kdesrc-build
kirigami-hello.exe # På Windows
Se där! Nu dyker ditt allra första Kirigami-program upp framför dina ögon.
För att köra den nya QML-applikationen i mobilläge kan man använda QT_QUICK_CONTROLS_MOBILE=1
:
QT_QUICK_CONTROLS_MOBILE=1 kirigami-hello
Om du har kompilerat projektet manuellt med CMake och av någon anledning vill avinstallera projektet kan du köra:
cmake --build build/ --target uninstall
Anmärkning
Nästa gång du vill skapa filerna och katalogerna som behövs, kan du använda KAppTemplate eller KDevelop för att automatiskt generera ett lämpligt projekt att starta med. De är tillgängliga från alla större distributioners arkiv. Programmen genererar också filer som innehåller AppStream metadata och en .desktop
-fil som innehåller information om hur programmet ska visas i en Linux programstart.
Tack vare magin i CMakeLists, kan du också använda integrerade utvecklingsmiljöer såsom KDevelop eller QtCreator för att utveckla programmet i en bekväm miljö med minimal ansträngning.