Evgenii Legotckoi
6 ноября 2015 г. 19: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 - количество строк;

Если задаём:

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

То в результате получим, что первый элемент строки будет в самом вверху, а последний элемент строки будет в самом низу. В случае наличия двух строк, элементы первой строки будут располагаться справа.

Работа с GridLayout

Для демонстрации позиционирования элементов в слое предлагаю следующий программный код. В котором несколько прямоугольников будут растягиваться на несколько ячеек GridLayout.

  1. import QtQuick 2.5
  2. import QtQuick.Controls 1.4
  3. import QtQuick.Layouts 1.1
  4.  
  5. ApplicationWindow {
  6. visible: true
  7. width: 480
  8. height: 480
  9. title: qsTr("Hello World")
  10.  
  11. GridLayout {
  12. id: grid
  13. anchors.fill: parent
  14.  
  15. rows: 3
  16. columns: 3
  17.  
  18. Rectangle {
  19. color: "red"
  20. Layout.fillHeight: true
  21. Layout.fillWidth: true
  22. Layout.columnSpan: 2
  23. Layout.rowSpan: 1
  24. Layout.row: 1
  25. Layout.column: 2
  26. }
  27.  
  28. Rectangle {
  29. color: "blue"
  30. Layout.fillHeight: true
  31. Layout.fillWidth: true
  32. Layout.columnSpan: 1
  33. Layout.rowSpan: 2
  34. Layout.row: 1
  35. Layout.column: 1
  36. }
  37.  
  38. Rectangle {
  39. color: "green"
  40. Layout.fillHeight: true
  41. Layout.fillWidth: true
  42. Layout.columnSpan: 1
  43. Layout.rowSpan: 2
  44. Layout.row: 2
  45. Layout.column: 3
  46. }
  47.  
  48. Rectangle {
  49. color: "white"
  50. Layout.fillHeight: true
  51. Layout.fillWidth: true
  52. Layout.columnSpan: 1
  53. Layout.rowSpan: 1
  54. Layout.row: 2
  55. Layout.column: 2
  56. }
  57.  
  58. Rectangle {
  59. color: "yellow"
  60. Layout.fillHeight: true
  61. Layout.fillWidth: true
  62. Layout.columnSpan: 2
  63. Layout.rowSpan: 1
  64. Layout.row: 3
  65. Layout.column: 1
  66. }
  67. }
  68. }

Итог

Результат работы данного программного кода показан на рисунке. Также выше перечисленная логика расположения объектов применима и к другим объектам Layout.

Вам это нравится? Поделитесь в социальных сетях!

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь