Evgenii Legotckoi
2 ноября 2015 г. 13:55

QML - Урок 010. Доступ к дочерним объектам в TabView в Qml Qt

Структура объектов в Qml представляет собой иерахическое дерево, в котором, чтобы получить доступ к свойствам объектов нижележащего уровня необходимо обратиться к первоначальному объекту, далее выбрать дочерний объект и выбрать свойство дочернего объекта, к которому требуется получить доступ.

Но в случае с TabView данный подход не сработает, поскольку объекты вкладок Tab добавляются динамически, следовательно необходимо получить доступ к вкладке по её индексу, забрать объект item из неё и найти интересующий нас дочерний объект в данном item также по индексу. И уже после этого получить доступ к интересующему Нас свойству. Также рекомендую обратить внимание на то, что в данном случае автозавершение кода не работает в QtCreator.

Причём, скорее всего Вы получите ошибку следующего содержания:

ReferenceError: 'something' is not defined


Структура проекта для работы с TabView

В данном примере будет использоваться проект созданный по умолчанию:

  • QmlTableView.pro - профайл проекта;
  • main.cpp - основной файл исходных кодов C++;
  • main.qml - файл исходных кодов qml-слоя.

main.qml

Поскольку в проекте изменения вносятся только в файл main.qml, то не буду углубляться в описание файлов, которые остаются созданными по умолчанию.

А что касается данного файла, то логика работы приложение следующая. Имеется главное окно приложения, в котором находится объект Button и объект TabView. В TabView находится две вкладки, в одной из которых помещена вторая кнопка. При нажатии на первую кнопку меняется текст на второй, при нажатии на вторую кнопку меняется текст на первой кнопке.

  1. import QtQuick 2.5
  2. import QtQuick.Controls 1.4
  3.  
  4. ApplicationWindow {
  5. visible: true
  6. width: 640
  7. height: 480
  8. title: qsTr("Qml TabView")
  9.  
  10. // Кнопка, по нажатию которой изменится текст кнопки в объекте Tab
  11. Button {
  12. id: button
  13. text: qsTr("Кнопка 1")
  14. anchors.top: parent.top
  15. anchors.topMargin: 5
  16. anchors.left: parent.left
  17. anchors.leftMargin: 5
  18.  
  19. /* Забираем вкладку с целевой кнопкой,
  20. * далее объект, который формирует набивку вкладки.
  21. * После чего вычленяем нужный дочерний объект по индексу.
  22. * И уже из этого объекта берём требуемое свойство,
  23. * то есть текст, которому присваиваем новое текстовое значение
  24. * */
  25. onClicked: {
  26. tabView.getTab(0).item.children[0].text = "Кнопка 1"
  27. }
  28. }
  29.  
  30. /* TabView, в первой вкладке которого находится кнопка,
  31. * по нажатию кнопки которой из изменится текст в первой кнопке
  32. */
  33. TabView {
  34. id: tabView
  35. anchors.top: button.bottom
  36. anchors.topMargin: 5
  37. anchors.left: parent.left
  38. anchors.right: parent.right
  39. anchors.bottom: parent.bottom
  40.  
  41. Tab {
  42. id: tab1
  43. title: qsTr("Первая вкладка")
  44.  
  45. component: Item {
  46. id: rect1
  47.  
  48. Button {
  49. id: buttonTab
  50. text: qsTr("Кнопка 2")
  51. anchors.top: parent.top
  52. anchors.topMargin: 5
  53. anchors.left: parent.left
  54. anchors.leftMargin: 5
  55.  
  56. /* Переписываем текстовое значение
  57. * первой кнопки
  58. * */
  59. onClicked: {
  60. button.text = "Кнопка 2"
  61. }
  62. }
  63. }
  64. }
  65.  
  66. Tab {
  67. id: tab2
  68. title: qsTr("Вторая вкладка")
  69. }
  70. }
  71. }

Итог

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

Рекомендую также ознакомиться с видеоуроком, в котором дано более подробное объяснение возникающей ошибки "Reference error: something is not defined" при неправильном обращении к объектам во вкладках TabView.

Видеоурок

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

Terabaytus
  • 4 июня 2018 г. 14:49

Добрый день, не совсем понятна закономерность вызовов, то есть

здесь любой объект.get (0/*индекс*/). Если у меня нет группы что будет.children[0].text 
можно более подробно ?

Evgenii Legotckoi
  • 4 июня 2018 г. 16:38

не обязательно, но вполне возможно, children возвращает контейнер со всеми дочерними объектами, которые находятся в текущем объекте.

Этот метод идёт ещё из QObject. Потом можно в цикле по objectName искать нужный объект.

Комментарии

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