BlinCT
BlinCT19 августа 2019 г. 8:53

Не отображается ListView

Всем привет.
Пытаюсь сделать qml обьект ListView который будет меить прокрутку если обьектов там будет больше дефолтной высоты.
Под ним 4 кнопки для добавления и удаления этих обьектов.
Но почему то у меня не отображается он. Подскажите где ошибку допускаю?
Вроде выставил высоту и ширину, но чет не показывает.
И еще, если это важно то я пытаюсь делегат который будет представлять из себя обьекты в листе как индекс : данные
Например:
0 : 124
1 : 333

    ScrollView
    {
        id: scrollView
        anchors.top: parent.top

        ListView
        {
            id: listView
            anchors.fill: parent

            width: 180; height: 200
            anchors.top: parent.top
            anchors.verticalCenter: parent.verticalCenter
            delegate: listDelegate

            contentWidth: 320
            flickableDirection: Flickable.AutoFlickDirection

        }
    }

    Component
    {
        id: listDelegate

        Label
        {
            id: delegateLabel

            anchors.centerIn: parent

            color: "red"

            text: workerA.time
        }
    }

    GridLayout
    {
        id: grid

        rows: 2
        columns: 2
        anchors.top: scrollView.bottom

        rowSpacing: 10
        columnSpacing: 10

        Rectangle
        {
            width: 50
            height: 40
            Text { id: textbutton_1; text: qsTr("ADD"); anchors.centerIn: parent }
            Layout.row: 0; Layout.column: 0;
            gradient: Gradient {
                GradientStop { position: 0.0; color: "lightsteelblue" }
                GradientStop { position: 1.0; color: "blue" }
            }
//            MouseArea { anchors.fill: parent; onClicked: { workerA.change = !workerA.change } }
        }
        Rectangle
        {
            width: 50
            height: 40
            Text { id: textbutton_2; text: qsTr("REM"); anchors.centerIn: parent }
            Layout.row: 1; Layout.column: 0;
            gradient: Gradient {
                GradientStop { position: 0.0; color: "lightsteelblue" }
                GradientStop { position: 1.0; color: "blue" }
            }
            /*onClicked: Core.stack.push(nandTest);*/
        }
        Rectangle
        {
            width: 50
            height: 40
            Text { id: textbutton_3; text: qsTr("START"); anchors.centerIn: parent }
            Layout.row: 0; Layout.column: 1;
            gradient: Gradient {
                GradientStop { position: 0.0; color: "lightsteelblue" }
                GradientStop { position: 1.0; color: "blue" }
            }
            /*onClicked: Core.stack.push(displayTest);*/
        }
        Rectangle
        {
            width: 50
            height: 40
            Text { id: textbutton_4; text: qsTr("STOP"); anchors.centerIn: parent }
            Layout.row: 1; Layout.column: 1;
            gradient: Gradient {
                GradientStop { position: 0.0; color: "lightsteelblue" }
                GradientStop { position: 1.0; color: "blue" }
            }
            /*onClicked: Core.stack.push(touchTest);*/
        }
    }

Заранее спасибо.

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

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

12
R
  • 19 августа 2019 г. 9:13

так модель пуста у вас, що має відображатись?

    BlinCT
    • 19 августа 2019 г. 9:27

    Изначально там ничего нету, но по кнопке add для простого примера должен добавится элемент например как я выше написал с индексом и данными. 0 : 345
    Но у листа есть изначально высота.

      BlinCT
      • 19 августа 2019 г. 9:33

      Компонент навернео вот таким должен быть

          Component
          {
              id: listDelegate
      
              Row
              {
                  Label { id: index; color: "red"; text: "index :" }
                  Label { id: delegateLabel; color: "red"; text: "123" }
              }
          }
      

      Ну в качестве теста

        Pavel K.
        • 19 августа 2019 г. 9:38

        ссылка на весь проект есть?

          R
          • 19 августа 2019 г. 9:45

          спробуйте додати, чи буде відображатись

          ListView {
               id: listView
               model: p1model
               delegate: delegate
               anchors.top: p1name.bottom
               anchors.topMargin: units.gu(1)
          }
          
          ListModel {
               id: p1model
               ListElement { score: "0" }
          }
          
            BlinCT
            • 19 августа 2019 г. 9:46

            WrapWorker22.tar.gz WrapWorker22.tar.gz

            Вообще вприследуется такая логика что создается лист таймеров, при нажатии на add в лист доабвляется первый таймер и он вместе с его индексом отображается в qml.
            Дефолтно это 0.
            Если нажать старт или стоп то это само собою управление таймером по индексу.
            Единственное что я забыл добавить на qml так это текстовое поле куда вводится руками номер индекса таймера которым надо управлять, или удалить. На стороне крестов там все методы я уже написал.
            Осталось вот с qml разобратся.

              Алексей Внуков
              • 19 августа 2019 г. 10:17
              • (ред.)

              вам нужна модель, модель отвечает за данные в листе, делегат отвечает за то как эти данные должны отображаться, тоесть у вас есть как отображается, а что отображать нет

              при add должно происходить model.append(data)

                BlinCT
                • 19 августа 2019 г. 11:00

                Кинул вон архив с самим тестовым проектом.

                  BlinCT
                  • 19 августа 2019 г. 11:20

                  не могли бы по самому проекту что я архивом кинул как правильно нужно модель с делегатом сделать?

                    Алексей Внуков
                    • 19 августа 2019 г. 11:29

                    я в дороге, по тому примеру что в есть выше вам чтоб заработало нужно примерно следующее

                    ListModel{
                    id: list_model
                    }

                    в ListView добавить model:list_model

                    там где кнопка add по нажатию:
                    list_model.append(delegateLable.text="123")

                      Pavel K.
                      • 20 августа 2019 г. 2:45

                      видел ,как время повится , посмотрю

                        BlinCT
                        • 20 августа 2019 г. 3:49

                        Спасибо.
                        Для уточнения хотел написать, там класс Timers он в себе имеет лист с таймерами.
                        Таймеры добавляются через метод. То есть как я понимаю то что я хочу отобразить в листе на стороне qml это именно то что имеется в листе из Timers. У каждого таймера есть старт и стоп. Методы тоже у этого класса есть. И поулчается что отобразить хочу те таймеры что добавляются в лист и первой колонкой это индекс данного таймера. Потому что потом по данному индексу хочу удалять их.

                          Комментарии

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

                          C++ - Тест 001. Первая программа и типы данных

                          • Результат:66баллов,
                          • Очки рейтинга-1
                          t

                          C++ - Тест 001. Первая программа и типы данных

                          • Результат:33баллов,
                          • Очки рейтинга-10
                          t

                          Qt - Тест 001. Сигналы и слоты

                          • Результат:52баллов,
                          • Очки рейтинга-4
                          Последние комментарии
                          G
                          GoattRock3 сентября 2024 г. 10:50
                          Как Копировать Файлы в Linux Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                          ВР
                          Влад Русоков1 августа 2024 г. 22:47
                          Как Копировать Файлы в Linux Screenshot_20240802-065123.png
                          d
                          dblas55 июля 2024 г. 8:02
                          QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                          k
                          kmssr8 февраля 2024 г. 15:43
                          Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                          АК
                          Анатолий Кононенко4 февраля 2024 г. 22:50
                          Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                          Сейчас обсуждают на форуме
                          Evgenii Legotckoi
                          Evgenii Legotckoi24 июня 2024 г. 12:11
                          добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                          F
                          Fynjy22 июля 2024 г. 1:15
                          при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                          BlinCT
                          BlinCT24 июня 2024 г. 22:00
                          Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                          BlinCT
                          BlinCT5 мая 2024 г. 2:46
                          Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                          Evgenii Legotckoi
                          Evgenii Legotckoi2 мая 2024 г. 11:07
                          Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

                          Следите за нами в социальных сетях