разместить LineEdit под каждым столбом QTableView
Привет. Хочу сделать делегат от QTableView, в котором разместить QLineEdit под каждым столбцом, но в QTableView! Вводим текст в QLineEdit и он через 0,5 сек делает фильтр по введенному шаблону для этого столбца. Вобщем-то сделать всё получилось, только вот как разместить QLineEdit под каждым столбцом я не знаю. Прошу подсказать. ПС: пока разместил его просто поверх HorizontalHeaderLabels, как на скрине. Проект прилагаю .zip
#ifndef FILTERTABLEVIEW_H #define FILTERTABLEVIEW_H #include <QTableView> #include <QTimer> #include <QLineEdit> #include <QHBoxLayout> #include <QHeaderView> #include <QRegExpValidator> #include <QAbstractItemModel> #include <QSortFilterProxyModel> class FilterTableView : public QTableView { Q_OBJECT public: explicit FilterTableView(QWidget *parent = nullptr); void setRegExpForColumn(QMap<int, QString> regexpColumns); void setEditColumns(QVector<int> editColumns); void setModel(QAbstractItemModel *model) Q_DECL_OVERRIDE; private: void setFilter(const QString text, const int column); QWidget *createLineEditForColumn(const int column); void filterLayoutAddWidgets(); QHBoxLayout *_filterLayout; QAbstractItemModel *_model; QMap<int, QString> _regexpColumns; QVector<int> _editColumns; QTimer *_timer; signals: void filterTViewTextChanged(const int column, const QString text); }; #endif // FILTERTABLEVIEW_H
#include "filtertableview.h" FilterTableView::FilterTableView(QWidget *parent) : QTableView(parent) { _timer = new QTimer(this); _filterLayout = new QHBoxLayout; horizontalHeader()->setLayout(_filterLayout); horizontalHeader()->setSectionResizeMode(QHeaderView::ResizeMode::Stretch); } void FilterTableView::filterLayoutAddWidgets() { if(!_editColumns.isEmpty()) for(int i(0); i < _editColumns.size(); ++i) _filterLayout->addWidget(createLineEditForColumn(_editColumns[i])); else for(int i(0); i < _model->columnCount(); ++i) _filterLayout->addWidget(createLineEditForColumn(i)); } QWidget *FilterTableView::createLineEditForColumn(const int column) { QLineEdit *widget = new QLineEdit(); if(_regexpColumns.contains(column)) widget->setValidator(new QRegExpValidator(QRegExp(_regexpColumns.value(column)))); connect(widget, &QLineEdit::textChanged, [this, column](const QString text) { _timer->start(500); connect(_timer, &QTimer::timeout, [this, column, text](){ emit filterTViewTextChanged(column, text);}); }); return widget; } void FilterTableView::setRegExpForColumn(QMap<int, QString> regexpColumns) { _regexpColumns = regexpColumns; } void FilterTableView::setEditColumns(QVector<int> editColumns) { _editColumns = editColumns; } void FilterTableView::setModel(QAbstractItemModel *model) { _model = model; QTableView::setModel(model); filterLayoutAddWidgets(); }
#include "mainwindow.h" #include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) , ui(new Ui::MainWindow) { ui->setupUi(this); _tv = new FilterTableView(); _proxy = new QSortFilterProxyModel; _model = new QStandardItemModel(_tv); _model->setHorizontalHeaderLabels(QStringList() << "Column 1" << "Column 2" << "Column 3"); for (int i = 0; i < 4; ++i) { QList<QStandardItem *> items; items.append(new QStandardItem(QString("Row %1").arg(i))); // Первая колонка items.append(new QStandardItem("Item 2")); // Вторая колонка items.append(new QStandardItem("Item 3")); // Третья колонка _model->appendRow(items); } _proxy->setSourceModel(_model); _tv->setModel(_proxy); ui->verticalLayout->addWidget(_tv); connect(_tv, &FilterTableView::filterTViewTextChanged, [this](const int column, const QString text){ setFilter(column, text); }); } MainWindow::~MainWindow() { delete ui; } void MainWindow::setFilter(const int column, const QString pattern) { _proxy->setFilterKeyColumn(column); _proxy->setFilterCaseSensitivity(Qt::CaseInsensitive); _proxy->setFilterFixedString(pattern); }
Ну и замечания по коду приму во внимание.
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
AD
- Akiv Doros
- 11 ноября 2024 г. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50баллов,
- Очки рейтинга-4
m
- molni99
- 26 октября 2024 г. 1:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80баллов,
- Очки рейтинга4
m
- molni99
- 26 октября 2024 г. 1:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20баллов,
- Очки рейтинга-10
Последние комментарии
ИМ
Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 ноября 2024 г. 11:51
Evgenii Legotckoi31 октября 2024 г. 14:37
Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов5 октября 2024 г. 7:51
QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Сейчас обсуждают на форуме
Evgenii Legotckoi24 июня 2024 г. 15:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 ноября 2024 г. 6:04
NSProject4 июня 2022 г. 3:49
IscanderChe31 октября 2024 г. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день.
QHeaderView имеет метод setItemDelegateForColumn . Думаю, что вам нужно написать делегат, в котором будет QLineEdit. И устанавливать этот делегат в колонки QHeaderView.
Пример написания делегата есть в этой статье Qt/C++ - Урок 091. Как написать кастомный делегат управляющий подсветкой строки в таблице
Единственное, вам нужно будет разобраться с тем, чтобы добавить туда QLineEdit... Возможно, через метод createEditor (кажется так называется), то есть переопределить его.
не получается. Может быть из-за этого
Note: Each header renders the data for each section itself, and does not rely on a delegate. As a result, calling a header's setItemDelegate() function will have no effect.
наверное )) Этого я не заметил, сорян
какие способы вообще приемлемы для отображения строки ввода под названием столбца?
Пример, как я хочу сделать (нажать кнопку фильтра).
headerView переопределить может быть..
делаю проверку в делегате такую
всегда FALSE. никуда ничего в QHeaderView не хочет ни добавляться, ни перемещаться. Жестянка какая-то.
Понял, что вы хотите сделать... Надо подумать.
я вот , что вчера нашел))
уже сделал, но что-то не так, хотя, заметно лучше уже)
а еще решение подсказали:
присосаться к
по которому открывать лайнэдит прямо под курсором. Но мне может быть такое не разрешат сделать.
сделал. Думаю, по этой задаче можно и статейку написать для коллекции, тк решений в сети нет. Получилось в два делегата, тк мне необходима была задержка фильтрации по столбцам.
Думаю, что сообщество будет радо увидеть подобную статью. Дерзайте ))
Наидобрейший человек! Спасибо! Код действительно очень помог сообществу. Его до сих под не сыскать на просторах чего то подобного на C++. Сделал несколько оптимизаций:
(1). Вернуть сортировку по нажатию на столбец можно в конструкторе FilterTableView, добавив:
Функция
тут не поможет
(2). Чтобы не дергать итоговую проксимодель ненужными сигналами, то на выходе мы создаем единственный сигнал об изменениях которые были сделаны во всех столбцах с задержской в 1 секунду.
В конструкторе "FilterHeader" добавляем
Переписываем FilterHeader::setFilterBoxes, ну и меняем сигнал на нужный тип данных в заголовочном файле
(3). Возвращаем подвижность столбцам в конструкторе FilterTableView параметром