Evgenii Legotckoi
Evgenii Legotckoi6. November 2015 08:17

QML - Lektion 014. GridLayout QML – Positionierung von Elementen

Eine kleine Anmerkung, entstanden aus der Frage eines der regelmäßigen Leser der Seite. Wenn Sie eine Anwendungsschnittstelle unter QML entwickeln, müssen Sie zum Positionieren von Objekten in GridLayout die Funktionalität von Layout. verschachtelten Eigenschaften verwenden, wie zum Beispiel:

  • Layout.row - gibt die Zeile an, in der sich das Objekt befindet;
  • Layout.column - gibt die Spalte an, in der sich das Objekt befindet;
  • Layout.rowSpan - gibt an, um wie viele Zeilen das Objekt gedehnt werden soll;
  • Layout.columnSpan - gibt an, auf wie viele Spalten das Objekt ausgedehnt werden soll;
  • Layout.minimumWidth - Mindestbreite des Objekts in der Ebene;
  • Layout.minimumHeight - Mindesthöhe eines Objekts in einer Ebene;
  • Layout.preferredWidth - die bevorzugte Breite des Objekts in der Ebene;
  • Layout.preferredHeight - die bevorzugte Höhe des Objekts in der Ebene;
  • Layout.maximumWidth - maximale Breite des Objekts in der Ebene;
  • Layout.maximumHeight - maximale Höhe des Objekts in der Ebene;
  • Layout.fillWidth - Füllbreite;
  • Layout.fillHeight - Füllhöhe;
  • Layout.alignment - Ausrichtung in der Ebene;

GridLayout-Eigenschaften

Außerdem werde ich der Vollständigkeit halber die Eigenschaften von GridLayout angeben und wofür sie verantwortlich sind:

  • columnSpacing : real - Abstände zwischen Spalten (Lücke zwischen Objekten);
  • Spalten : int - Anzahl der Spalten;
  • flow : Enumeration - die Richtung der Objekte im GridLayout
  • GridLayout.LeftToRight (Standard) - von links nach rechts
  • GridLayout.TopToBottom - von oben nach unten
  • layoutDirection : Enumeration - die Richtung der Enumeration von Objekten mit einem gegebenen Fluss
  • Qt.LeftToRight (Standard) - von links nach rechts
  • Qt.RightToLeft - von rechts nach links
  • rowSpacing : real - Abstände zwischen Zeilen (Lücke zwischen Objekten);
  • rows : int - Anzahl der Zeilen;

Wenn wir fragen:

  • Fluss: GridLayout.TopToBottom
  • layoutDirection: Qt.RightToLeft

Als Ergebnis erhalten wir, dass das erste Element der Zeile ganz oben und das letzte Element der Zeile ganz unten steht. Bei zwei Zeilen stehen die Elemente der ersten Zeile rechts.

Arbeiten mit GridLayout

Um die Positionierung von Elementen in einer Ebene zu demonstrieren, schlage ich folgenden Programmcode vor. In dem sich mehrere Rechtecke über mehrere Zellen erstrecken GridLayout.

import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Layouts 1.1

ApplicationWindow {
    visible: true
    width: 480
    height: 480
    title: qsTr("Hello World")

   GridLayout {
       id: grid
       anchors.fill: parent

       rows: 3
       columns: 3

       Rectangle {
            color: "red"
            Layout.fillHeight: true
            Layout.fillWidth: true
            Layout.columnSpan: 2
            Layout.rowSpan: 1
            Layout.row: 1
            Layout.column: 2
       }

       Rectangle {
            color: "blue"
            Layout.fillHeight: true
            Layout.fillWidth: true
            Layout.columnSpan: 1
            Layout.rowSpan: 2
            Layout.row: 1
            Layout.column: 1
       }

       Rectangle {
            color: "green"
            Layout.fillHeight: true
            Layout.fillWidth: true
            Layout.columnSpan: 1
            Layout.rowSpan: 2
            Layout.row: 2
            Layout.column: 3
       }

       Rectangle {
            color: "white"
            Layout.fillHeight: true
            Layout.fillWidth: true
            Layout.columnSpan: 1
            Layout.rowSpan: 1
            Layout.row: 2
            Layout.column: 2
       }

       Rectangle {
            color: "yellow"
            Layout.fillHeight: true
            Layout.fillWidth: true
            Layout.columnSpan: 2
            Layout.rowSpan: 1
            Layout.row: 3
            Layout.column: 1
       }
   }
}

Insgesamt

Das Ergebnis dieses Programmcodes ist in der Abbildung dargestellt. Die obige Logik für das Layout von Objekten gilt auch für andere Objekte Layout.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken