BlinCT
BlinCT30 жовтня 2019 р. 07:17

Заполнение из TableModel происходит только для первого столбца

Всем привет.
При дебаге заметил что в методе data(const QModelIndex &index, int role) аргумент role изменяется, и получается что в switch не проходит проверку.
То есть заполняется первый столбец который попал под аргумент со значением 0 а дальше проверка пролетает.
Подскажите, я где то ошибаюсь в реализации или может ошибку допустил?
Спасибо

//
// Created by root on 08.10.19.
//

#include <QDebug>
#include <utility>

#include "TableModel.hpp"
#include "SupPowerStatesModelObject.hpp"

TableModel::TableModel(QVector<SupportedPowerStates * > vector)
    : m_columnCount(0)
    , m_rowCount(0)
    , m_object(0)
    , m_vector(std::move(vector))
{}

int TableModel::rowCount(const QModelIndex &parent) const
{
    return m_vector.size();
}

int TableModel::columnCount(const QModelIndex &parent) const
{
    return 11;
}

QVariant TableModel::data(const QModelIndex &index, int role) const
{
    if(!index.isValid())
    {
        qDebug() << "Not Valid: ";
        return QVariant();
    }

    int row = index.row();
    int col = index.column();

    auto tmp = m_vector.at(row);

    switch (role)
    {
        case Qt::DisplayRole:
            return getData(tmp, col);
        default:
            break;
    }

    return QVariant();
}

QVariant TableModel::headerData(int section, Qt::Orientation orientation, int role) const
{
    if( role != Qt::DisplayRole )
    {
        return QVariant();
    }

    if( orientation == Qt::Vertical )
    {
        return section;
    }

    switch( section )
    {
        case 0:
            return tr( "St" );
        case 1:
            return tr( "Op" );
        case 2:
            return tr( "Max" );
        case 3:
            return tr( "Active" );
        case 4:
            return tr( "Idle" );
        case 5:
            return tr( "RL" );
        case 6:
            return tr( "RT" );
        case 7:
            return tr( "WL" );
        case 8:
            return tr( "WT" );
        case 9:
            return tr( "Ent_Lat" );
        case 10:
            return tr( "Ex_lat" );
    }

}

QVariant TableModel::getData(SupportedPowerStates* data, int column) const
{
    if (column == 0)
        return QVariant(data->id);
    else if (column == 1)
        return QVariant(data->nvmeIdPowerState.flags);
    else if (column == 2)
            return QVariant(data->nvmeIdPowerState.max_power);
    else if (column == 3)
            return QVariant(data->nvmeIdPowerState.active_power);
    else if (column == 4)
            return QVariant(data->nvmeIdPowerState.idle_power);
    else if (column == 5)
            return QVariant(data->nvmeIdPowerState.read_lat);
    else if (column == 6)
            return QVariant(data->nvmeIdPowerState.read_tput);
    else if (column == 7)
            return QVariant(data->nvmeIdPowerState.write_lat);
    else if (column == 8)
            return QVariant(data->nvmeIdPowerState.write_tput);
    else if (column == 9)
        return QVariant(data->nvmeIdPowerState.entry_lat);
    else if (column == 10)
        return QVariant(data->nvmeIdPowerState.exit_lat);
}

QHash<int, QByteArray> TableModel::roleNames() const
{
    QHash<int, QByteArray> roles;
    roles[St]       = "St";
    roles[Op]       = "Op";
    roles[Max]      = "Max";
    roles[Active]   = "Active";
    roles[Idle]     = "Idle";
    roles[RL]       = "RL";
    roles[RT]       = "RT";
    roles[WL]       = "WL";
    roles[WT]       = "WT";
    roles[Ent_Lat]  = "Ent_Lat";
    roles[Ex_lat]   = "Ex_lat";
    return roles;
}

//////////////////////////////////////////////////////////////

TableView
{
    clip: true

    TableViewColumn { width: 40; role: "St"; title: "St" }
    TableViewColumn { width: 40; role: "Op"; title: "Op" }
    TableViewColumn { width: 80; role: "Max"; title: "Max" }
    TableViewColumn { width: 80; role: "Active"; title: "Active" }
    TableViewColumn { width: 40; role: "Idle"; title: "Idle" }
    TableViewColumn { width: 40; role: "RL"; title: "RL" }
    TableViewColumn { width: 40; role: "RT"; title: "RT" }
    TableViewColumn { width: 40; role: "WL"; title: "WL" }
    TableViewColumn { width: 40; role: "WT"; title: "WT" }
    TableViewColumn { width: 80; role: "Ent_Lat"; title: "Ent_Lat" }
    TableViewColumn { width: 80; role: "Ex_lat"; title: "Ex_lat" }

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

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

4
МП
  • 30 жовтня 2019 р. 07:42
  • Відповідь була позначена як рішення.

Ну так вы определили роли. Вот в data их и используйте теперь. role это столбец.

    МП
    • 30 жовтня 2019 р. 07:45

    Первое что попалось:

      BlinCT
      • 30 жовтня 2019 р. 07:48

      Спасибо, понял где реализация не доделана)

        BlinCT
        • 30 жовтня 2019 р. 09:08

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

          Коментарі

          Only authorized users can post comments.
          Please, Log in or Sign up
          AD

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

          • Результат:50бали,
          • Рейтинг балів-4
          m
          • molni99
          • 26 жовтня 2024 р. 01:37

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

          • Результат:80бали,
          • Рейтинг балів4
          m
          • molni99
          • 26 жовтня 2024 р. 01:29

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

          • Результат:20бали,
          • Рейтинг балів-10
          Останні коментарі
          ИМ
          Игорь Максимов22 листопада 2024 р. 11:51
          Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
          Evgenii Legotckoi
          Evgenii Legotckoi31 жовтня 2024 р. 14:37
          Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
          A
          ALO1ZE19 жовтня 2024 р. 08:19
          Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
          ИМ
          Игорь Максимов05 жовтня 2024 р. 07:51
          Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
          d
          dblas505 липня 2024 р. 11:02
          QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
          Тепер обговоріть на форумі
          Evgenii Legotckoi
          Evgenii Legotckoi24 червня 2024 р. 15:11
          добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
          t
          tonypeachey115 листопада 2024 р. 06:04
          google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
          NSProject
          NSProject04 червня 2022 р. 03:49
          Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
          9
          9Anonim25 жовтня 2024 р. 09:10
          Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

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