Как динамически обновить модель QCompleter
Я использую QCompleter
с QLineEdit
и я хочу обновить QCompleter
Модель динамически. т.е. содержимое модели обновляется в соответствии с QLineEdit
текст.
1) mdict.h
#include <QtGui/QWidget>
class QLineEdit;
class QCompleter;
class QModelIndex;
class mdict : public QWidget
{
Q_OBJECT
public:
mdict(QWidget *parent = 0);
~mdict() {}
private slots:
void on_textChanged(const QString &text);
private:
QLineEdit *mLineEdit;
QCompleter *mCompleter;
};
2) mdict.cpp
#include <cassert>
#include <QtGui>
#include "mdict.h"
mdict::mdict(QWidget *parent) : QWidget(parent), mLineEdit(0), mCompleter(0)
{
mLineEdit = new QLineEdit(this);
QPushButton *button = new QPushButton(this);
button->setText("Lookup");
QHBoxLayout *layout = new QHBoxLayout(this);
layout->addWidget(mLineEdit);
layout->addWidget(button);
setLayout(layout);
QStringList stringList;
stringList << "m0" << "m1" << "m2";
QStringListModel *model = new QStringListModel(stringList);
mCompleter = new QCompleter(model, this);
mLineEdit->setCompleter(mCompleter);
mLineEdit->installEventFilter(this);
connect(mLineEdit, SIGNAL(textChanged(const QString&)),
this, SLOT(on_textChanged(const QString&)));
}
void mdict::on_textChanged(const QString &)
{
QStringListModel *model = (QStringListModel*)(mCompleter->model());
QStringList stringList;
stringList << "h0" << "h1" << "h2";
model->setStringList(stringList);
}
Я ожидаю, когда я введу h
, он должен дать мне список автозаполнения с h0
, h1
, а также h2
и я мог бы использовать keyborad для выбора элемента. Но это не поведение, как я ожидал.
Похоже, модель должна быть установлена раньше QLineEdit
излучает textChanged
сигнал. Одним из способов является переопределение keyPressEvent
, но это включает в себя много условий, чтобы получить QLineEdit
текст.
Итак, я хочу знать, есть ли простой способ обновить QCompleter
модель динамически?
3 ответа
О, я нашел ответ:
Использовать сигнал textEdited
вместо textChanged
,
Отладка исходного кода QT сказала мне ответ.
Вы можете использовать что-то вроде этого:
Foo:Foo()
{
...
QLineEdit* le_foodName = new QLineEdit(this);
QCompleter* foodNameAutoComplete = new QCompleter(this);
le_foodName->setCompleter(foodNameAutoComplete);
updateFoodNameAutoCompleteModel();
...
}
// We call this function everytime you need to update completer
void Foo::updateFoodNameAutoCompleteModel()
{
QStringListModel *model;
model = (QStringListModel*)(foodNameAutoComplete->model());
if(model==NULL)
model = new QStringListModel();
// Get Latest Data for your list here
QStringList foodList = dataBaseManager->GetLatestFoodNameList() ;
model->setStringList(foodList);
foodNameAutoComplete->setModel(model);
}
Использование filterMode : Qt::MatchFlags
имущество. Это свойство содержит порядок выполнения фильтрации. Если filterMode установлен в Qt::MatchStartsWith
будут отображаться только те записи, которые начинаются с напечатанных символов. Qt::MatchContains
отобразит записи, которые содержат напечатанные символы, и Qt::MatchEndsWith
те, которые заканчиваются напечатанными символами. В настоящее время реализованы только эти три режима. Установка filterMode для любого другого Qt::MatchFlag
выдаст предупреждение, и никакие действия не будут выполнены. Режим по умолчанию Qt::MatchStartsWith
,
Это свойство было введено в Qt 5.2.
Функции доступа:
Qt::MatchFlags filterMode() const
void setFilterMode(Qt::MatchFlags filterMode)