crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> [Решено] Cоздание собственной модели для отображения таблицы., наследник QAbstractTableModel
AD
  опции профиля:
сообщение 17.3.2009, 15:33
Сообщение #1


Профессионал
*****

Группа: Участник
Сообщений: 2003
Регистрация: 4.2.2008
Из: S-Petersburg
Пользователь №: 84

Спасибо сказали: 70 раз(а)




Репутация:   17  


Имеется QTableView* tblLicences. Это представление зависит от модели QSqlTableModel* modelLicView. Но есть желание, чтобы отображение таблички было немного другим, чем в базе данных. Для этого создал след. класс:
/// Класс для представления вида одной записи таблицы
class ViewLicence
{
private:
    QString licence_name;            ///< название лицензии
    QString path;                    ///< путь, по которому лежит данная лицензия
    QDateTime date;                    ///< дата создания лицензии
    QStringList list_numbers;        ///< список серийных номеров лицензии
    QList<uint> list_id;            ///< список id-шников данных серийных номеров

public:
    ViewLicence();
    ViewLicence(const QString name, const QString pth, const QDateTime& d, const QStringList& lst,
        const QList<uint>& lId) { licence_name = name; path = pth; date = d; list_numbers = lst; list_id = lId; }
    ViewLicence(const ViewLicence& view) { licence_name = view.licence_name; path = view.path; date = view.date;
        list_numbers = view.list_numbers; list_id = view.list_id; }
    virtual ~ViewLicence();
    uint size() const { return list_numbers.size(); }
    uint elementIndex(QString num) const { return list_numbers.indexOf(num, 0); }
    uint ID(uint index) const { return (index > -1 && index < size()) ? list_id[index] : -1; }
    QString licenceName() const { return licence_name; }
    QString licencePath() const { return path; }
    QString serialNumber(uint index) const { return (index > -1 && index < size()) ? list_numbers[index] : ""; }
    QDateTime createDate() const { return date; }
    void licenceName(const QString name) { licence_name = name; }
    void licencePath(const QString pth) { path = pth; }
    void addNum(const QString number) { if(!number.isEmpty()) list_numbers.append(number); }
    void createDate(const QDateTime& d) { date = d; }
    void ID(const uint id) { list_id.append(id); }
    bool operator==(const ViewLicence& lv) { return licence_name == lv.licence_name && path == lv.path &&
        date == lv.date && list_numbers == lv.list_numbers && list_id == lv.list_id; }
    const ViewLicence& operator=(const ViewLicence& lv) { licence_name = lv.licence_name; path = lv.path;
        date = lv.date; list_numbers = lv.list_numbers; list_id = lv.list_id; return *this; }
};

Смысл такой, что таблица должна отображаться так:
Имя лицензии | Локальный путь доступа к лицензии | Дата создания | Список серийных номеров.
У меня есть список QList<ViewLicence*> listView, который я уже заполнил из модели.

А в БД это отображается следующим образом
[attachment=497:table.JPG]

Как мне отобразить список QList<ViewLicences*> listView в представлении? Поможете, а то не сообразить что-то?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
4 страниц V   1 2 3 > »   
Начать новую тему
Ответов (1 - 9)
Litkevich Yuriy
  опции профиля:
сообщение 17.3.2009, 16:05
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(AD @ 17.3.2009, 18:33) *
У меня есть список QList<ViewLicence*> listView, который я уже заполнил из модели.
и что в этом списке? судя по имени список указателей на пачку предствалений
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
AD
  опции профиля:
сообщение 17.3.2009, 16:07
Сообщение #3


Профессионал
*****

Группа: Участник
Сообщений: 2003
Регистрация: 4.2.2008
Из: S-Petersburg
Пользователь №: 84

Спасибо сказали: 70 раз(а)




Репутация:   17  


Цитата(Litkevich Yuriy @ 17.3.2009, 16:05) *
и что в этом списке? судя по имени список указателей на пачку предствалений

Грубо говоря, список строк таблицы, которую хочу отобразить!
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 17.3.2009, 16:08
Сообщение #4


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


конечное представление должно предоставлять возможность редактировать данные?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
AD
  опции профиля:
сообщение 17.3.2009, 16:09
Сообщение #5


Профессионал
*****

Группа: Участник
Сообщений: 2003
Регистрация: 4.2.2008
Из: S-Petersburg
Пользователь №: 84

Спасибо сказали: 70 раз(а)




Репутация:   17  


Цитата(Litkevich Yuriy @ 17.3.2009, 16:08) *
конечное представление должно предоставлять возможность редактировать данные?

Нет (Слава Богу). Только просмотр!
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 17.3.2009, 16:13
Сообщение #6


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


тогда сделай запрос, положи его в модель запроса (QSqlQueryModel) ну а к ней прицепи представление

Цитата(AD @ 17.3.2009, 18:33) *
Имя лицензии |
откуда берется имя лицензии?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
AD
  опции профиля:
сообщение 17.3.2009, 16:15
Сообщение #7


Профессионал
*****

Группа: Участник
Сообщений: 2003
Регистрация: 4.2.2008
Из: S-Petersburg
Пользователь №: 84

Спасибо сказали: 70 раз(а)




Репутация:   17  


Цитата(Litkevich Yuriy @ 17.3.2009, 16:13) *
тогда сделай запрос, положи его в модель запроса (QSqlQueryModel) ну а к ней прицепи представление

Цитата(AD @ 17.3.2009, 18:33) *
Имя лицензии |
откуда берется имя лицензии?

Имя из БД. На картинке ведь видны данные БД. Там все это есть.

А с методом не очень понял. Какой запрос сделать? Можешь подсказать, пожалуйста?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 17.3.2009, 16:20
Сообщение #8


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(AD @ 17.3.2009, 18:33) *
Имя лицензии | Локальный путь доступа к лицензии
т.е. имя лицензии это просто имя файла без пути?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
AD
  опции профиля:
сообщение 17.3.2009, 16:29
Сообщение #9


Профессионал
*****

Группа: Участник
Сообщений: 2003
Регистрация: 4.2.2008
Из: S-Petersburg
Пользователь №: 84

Спасибо сказали: 70 раз(а)




Репутация:   17  


Цитата(Litkevich Yuriy @ 17.3.2009, 16:20) *
т.е. имя лицензии это просто имя файла без пути?

именно.

Вообще, если привести пример из картинки, то получается, что есть всего две строки у таблицы представления
Имя | Путь | Дата | Серийные номера
1 database.lic | D:/Projects/Win32/Bin/Release/LicenceBuilderGui/DBNAV1\ | 16.03.2009 17:56:23 | 22001
22004
22005
22009

2 database1.lic | D:/Projects/Win32/Bin/Release/LicenceBuilderGui/DBNAV1\ | 17.03.2009 15:13:59 | 22009
M-22001
MAKET
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 17.3.2009, 16:37
Сообщение #10


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(AD @ 17.3.2009, 19:29) *
1 database.lic | D:/Projects/Win32/Bin/Release/LicenceBuilderGui/DBNAV1\ | 16.03.2009 17:56:23 | 22001
22004
22005
22009
дак тебе дерево надо ?
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

4 страниц V   1 2 3 > » 
Тема закрытаНачать новую тему
Теги
Нет тегов для показа


1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0


RSS Рейтинг@Mail.ru Текстовая версия Сейчас: 21.6.2025, 15:17