Evgenii Legotckoi
Evgenii Legotckoi06 листопада 2015 р. 08:17

QML - Урок 014. GridLayout QML – Позиціонування елементів

Невелика замітка, що народилася з одного з постійних читачів сайту. При розробці інтерфейсу програми під QML для позиціонування об'єктів у GridLayout необхідно використовувати функціонал вкладених властивостей Layout. Таких як:

  • Layout.row - вказує рядок, у якому розташовується об'єкт;
  • Layout.column - вказує колонку, в якій розташовується об'єкт;
  • Layout.rowSpan - вказує, на скільки рядків має бути розтягнутий об'єкт;
  • Layout.columnSpan - вказує, на скільки колонок має бути розтягнутий об'єкт;
  • Layout.minimumWidth - мінімальна ширина об'єкта в шарі;
  • Layout.minimumHeight - мінімальна висота об'єкта в шарі;
  • Layout.preferredWidth - краща ширина об'єкта в шарі;
  • Layout.preferredHeight - краща висота об'єкта в шарі;
  • Layout.maximumWidth - максимальна ширина об'єкта в шарі;
  • Layout.maximumHeight - максимальна висота об'єкта в шарі;
  • Layout.fillWidth - заповнення по ширині;
  • Layout.fillHeight - заповнення по висоті;
  • Layout.alignment - вирівнювання у шарі;

Властивості GridLayout

Також для повноти картини вкажу властивості GridLayout і за що вони відповідають:

  • columnSpacing : real - пробіли між колонками (розрив між об'єктами);
  • columns : int - кількість колонок;
  • flow : enumeration - напрямок розташування об'єктів у GridLayout
  • GridLayout.LeftToRight (default) - зліва направо
  • GridLayout.TopToBottom - зверху вниз
  • layoutDirection : enumeration - напрямок перерахування об'єктів при заданому flow
  • Qt.LeftToRight (default) - зліва направо
  • Qt.RightToLeft – справа наліво
  • rowSpacing : real - пробіли між рядками (розрив між об'єктами);
  • rows : int - кількість рядків;

Якщо ставимо:

  • потік: GridLayout.TopToBottom
  • layoutDirection: Qt.RightToLeft

То в результаті отримаємо, що перший елемент рядка буде вгорі, а останній елемент рядка буде в самому низу. У разі наявності двох рядків елементи першого рядка будуть розташовуватися праворуч.

Робота з GridLayout

Для демонстрації позиціонування елементів шарі пропоную наступний програмний код. У якому кілька прямокутників розтягуватимуться на кілька осередків 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
       }
   }
}

Підсумок

Результат роботи даного програмного коду показано малюнку. Також вище перерахована логіка розташування об'єктів застосовна до інших об'єктів Layout.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
Дмитрий

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:60бали,
  • Рейтинг балів-1
Дмитрий

C++ - Тест 003. Условия и циклы

  • Результат:92бали,
  • Рейтинг балів8
d
  • dsfs
  • 26 квітня 2024 р. 11:56

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:80бали,
  • Рейтинг балів4
Останні коментарі
k
kmssr09 лютого 2024 р. 02:43
Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Анатолий Кононенко05 лютого 2024 р. 09:50
Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25 грудня 2023 р. 18:30
Boost - статичне зв&#39;язування в проекті CMake під Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
J
JonnyJo25 грудня 2023 р. 16:38
Boost - статичне зв&#39;язування в проекті CMake під Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
G
Gvozdik19 грудня 2023 р. 05:01
Qt/C++ - Урок 056. Підключення бібліотеки Boost в Qt для компіляторів MinGW і MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Тепер обговоріть на форумі
G
George1307 травня 2024 р. 07:27
добавить qlineseries в функции в функции: "GPlotter::addSeries(QString title, QVector &arr)" я вызываю метод setChart(...), я в конструктор передал адрес на QChartView элемент
BlinCT
BlinCT05 травня 2024 р. 12:46
Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
PS
Peter Son04 травня 2024 р. 00:57
Best Indian Food Restaurant In Cincinnati OH Ready to embark on a gastronomic journey like no other? Join us at App india restaurant and discover why we're renowned as the Best Indian Food Restaurant In Cincinnati OH . Whether y…
Evgenii Legotckoi
Evgenii Legotckoi02 травня 2024 р. 21:07
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.
IscanderChe
IscanderChe30 квітня 2024 р. 11:22
Во Flask рендер шаблона не передаётся в браузер Доброе утро! Имеется вот такой шаблон: <!doctype html><html> <head> <title>{{ title }}</title> <link rel="stylesheet" href="{{ url_…

Слідкуйте за нами в соціальних мережах