ChristoF
ChristoF28 апреля 2020 г. 11:22

Отобразить список с вложенным в него еще одним списком

QAbstractListModel, ListView

Доброго времени суток, В QML есть ListView моделью которого является QAbstractListModel в который из интерфейса для обращения к данным передаётся контейнер std::vector(родительский) c полями. Помимо простых типов данных в нем содержится вложенный контейнер std::vector(дочерний). Для того чтобы "показать" в QML элементы родительского контейнера требуется определить методы QAbstractListModel такие как:
rowCount( )
data( )
roleNames( )
А также создать Enum ролей

Для простых типов, таких как string, int, double нет ничего сложного

int DailyModel::rowCount(const QModelIndex &parent) const
{
    Q_UNUSED(parent)
    return static_cast<int>(m_dailys.size());
}

QVariant DailyModel::data(const QModelIndex &index, int role) const
{
    if (!index.isValid() || index.row() > rowCount(index)) {
            return QVariant();
        }
    const ns1__dayArc *daily = m_dailys.at(index.row());

    switch (role) {
        case DailyRoles::TimeRole: {
            char buffer [80];
            struct tm * timeinfo;
            timeinfo = localtime (daily->Time);
            strftime (buffer,80,"%d/%m/%y %X", timeinfo);
            return QString::fromStdString(buffer);
            }
        case DailyRoles::VbTRole: {
            return QVariant::fromValue(*daily->VbT);
            }

        case DailyRoles::StatusRole: {        
            std::string arr=DailyModel::translator(daily->state);
            return QString::fromStdString(arr);
        }
        case DailyRoles::TRole: {
            return QVariant::fromValue(*daily->T);
            }
        case DailyRoles::K_smtRole: {
            return QVariant::fromValue(*daily->K_USCOREsmt);
            }
        default: {
             return {};
        }
    }
}

QHash<int, QByteArray> DailyModel::roleNames() const
{
    QHash<int, QByteArray> roles;
    roles[DailyRoles::TimeRole] = "time";    
    roles[DailyRoles::StatusRole] = "status";
    roles[DailyRoles::VbTRole] = "VbT";
    roles[DailyRoles::TRole] = "T";
    roles[DailyRoles::K_smtRole] = "K_smt";

    return roles;
}

Но как мне задать роль для std::vector а также вывести его в делегате?

Хочется реализовать что-то подобное

import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.5

Window {
    ListModel{
        id: dataModel;

        ListElement{
            color: "skyblue";
            text: "one";
            texts:[
                ListElement{
                    text: "one_000";
                },
                ListElement{
                    text: "one_001";
                },
                ListElement{
                    text: "one_002";
                }
            ]
        }
        ListElement{
            color: "lightgreen";
            text: "two";
            texts:[
                ListElement{
                    text: "two_000";
                },
                ListElement{
                    text: "two_001";
                },
                ListElement{
                    text: "two_002";
                }
            ]
        }
        ListElement{
            color: "orchid";
            text: "three";
            texts:[
                ListElement{
                    text: "three_000";
                },
                ListElement{
                    text: "three_001";
                },
                ListElement{
                    text: "three_002";
                }
            ]
        }
    }
    visible: true
    width: 640
    height: 480

    ListView{
        id: view;
        anchors.fill: parent;
        anchors.margins: 10;
        spacing: 10;
        clip: true;

        model: dataModel;

        delegate: Rectangle{
            width: view.width;
            height: 50;

            color: model.color;
            Row{
                anchors.centerIn: parent;
                anchors.margins: 10;
                spacing: 10;

                Text{
                    renderType: Text.NativeRendering;
                    font.pointSize: 15;
                    text: model.text;
                }
                ComboBox{
                    model: texts;

                }
            }
        }
    }
}

Буду благодарен за помощь

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

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

5
Evgenii Legotckoi
  • 28 апреля 2020 г. 12:55

Добрый день

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

    ChristoF
    • 28 апреля 2020 г. 15:10
    • (ред.)

    На данный момент придумал полумеру решения данного вопроса, сделать делегаты RadioDelegate внутри котороых вложенный Reapiter,
    при checked отправляю во вложенную модель currentIndex. В результате вложенная модель при каждом клике переопределяется и выводит список соответсвующий данному делегату. Минусом данного подхода является, то что я не могу основываясь на вложеном списке выводить в главный список какую либо информацию (Например количество строк списка), так как при изменении модели вложенного списка он меняется во всех делегатах

    Говоря "возвращать вложенную модель вместо вектора" вы имеете ввиду в методе data() установить роль возвращающую модель?

    QVariant DailyModel::data(const QModelIndex &index, int role) const
    {
        if (!index.isValid() || index.row() > rowCount(index)) {
                return QVariant();
            }
        const ns1__dayArc *daily = m_dailys.at(index.row());
    
        switch (role) {        
            case DailyRoles::VectorRole: {
                return QVariant::fromValue(/* MyModel */); //   либо другая реализация
                }
            default: {
                 return {};
            }
        }
    }
    
      Evgenii Legotckoi
      • 28 апреля 2020 г. 15:12

      Да, я думаю, что стоит попробовать такое сделать. Были бы это классические виджеты, то именно это я бы и посоветовал, как наиболее адекватное решение, а с QML, наверное, будет посложнее из-за необходимости регистрации мета-типов... интересный вопрос сам по себе.

        ChristoF
        • 28 апреля 2020 г. 15:19

        Если возможно, можете подсказать "правильный синтаксис" присвоения ролям значения модели? Мой вариант меня не до конца устраивает и я все же хотел бы выводить вложенный каждый список для всех делегатов одновреммено, так как значения Reapiter-ов я хотел бы использовать в главной моделе

          Evgenii Legotckoi
          • 28 апреля 2020 г. 15:21

          Самому нужно подумать, с наскоку это не сделать, да из головы даже не знаю...

            Комментарии

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

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

            • Результат:84баллов,
            • Очки рейтинга4
            Ua

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

            • Результат:42баллов,
            • Очки рейтинга-8
            ОК

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

            • Результат:47баллов,
            • Очки рейтинга-6
            Последние комментарии
            ИМ
            Игорь Максимов22 ноября 2024 г. 21:51
            Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
            Evgenii Legotckoi
            Evgenii Legotckoi31 октября 2024 г. 23:37
            Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
            A
            ALO1ZE19 октября 2024 г. 17:19
            Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
            ИМ
            Игорь Максимов5 октября 2024 г. 16:51
            Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
            d
            dblas55 июля 2024 г. 20:02
            QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
            Сейчас обсуждают на форуме
            f
            firstlunoxod15 февраля 2025 г. 13:46
            Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
            Дмитрий
            Дмитрий3 февраля 2025 г. 16:24
            Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
            NW
            Nayo Wai30 января 2025 г. 19:22
            не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
            n
            nkly3 января 2025 г. 12:52
            Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
            M
            Marsel17 августа 2023 г. 0:26
            OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

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