Я только начал экспериментировать с Qt’s AbstractListModel и в качестве учебного приложения я пытаюсь создать модель, которая будет хранить пользовательские объекты. Классы testperson
, personlistmodel
класс и mainwindow
, У меня проблема в том, что мое представление не отображает правильные данные, если я добавлю два ‘testperson’s, то мой listView отобразит две пустые строки. Так может кто-нибудь, пожалуйста, подскажите мне, как на самом деле работает форматирование данных модели для просмотра ??? что я делаю не так сейчас ??
Person Class.cpp
testPerson::testPerson(const QString &name, QObject *parent):QObject (parent)
{
this->fName = name;
connect(this,SIGNAL(pesonAdd()),this,SLOT(personConfirm()));
emit pesonAdd();
}
void testPerson::setPerson(QString setTo)
{
fName = setTo;
}
QString testPerson::getPerson() const
{
return fName;
}void testPerson::personConfirm()
{
qDebug() << fName << QTime::currentTime().toString();
}
PersonListModel.h
class personListModel : public QAbstractListModel
{
Q_OBJECT
public:
explicit personListModel(QObject *parent = 0);
int rowCount(const QModelIndex &parent = QModelIndex()) const;
QVariant data(const QModelIndex &index, int role) const;
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
Qt::ItemFlags flags(const QModelIndex &index) const;
//Custom functions
void addPerson(testPerson &person);
private:
QList<testPerson*> dataStore;
};
PersonListModel.cpp
personListModel::personListModel(QObject *parent): QAbstractListModel (parent)
{
}
int personListModel::rowCount(const QModelIndex &parent) const
{
return dataStore.count();
}
QVariant personListModel::data(const QModelIndex &index, int role) const
{
if(role != Qt::DisplayRole || role != Qt::EditRole){
return QVariant();
}
if(index.column() == 0 && index.row() < dataStore.count() ){
return QVariant(dataStore[index.row()]->getPerson());
}else{
return QVariant();
}
}
bool personListModel::setData(const QModelIndex &index, const QVariant &value, int role)
{
if (index.isValid() && role == Qt::EditRole) {
testPerson *item = dataStore[index.row()];
item->setPerson(value.toString());
dataStore.at(index.row())->setPerson(value.toString());
emit dataChanged(index,index);
return true;
}
return false;
}
Qt::ItemFlags personListModel::flags(const QModelIndex &index) const
{
if(!index.isValid()){
return Qt::ItemIsEnabled;
}
return Qt::ItemIsSelectable | Qt::ItemIsEditable | Qt::ItemIsEnabled;
}
void personListModel::addPerson(testPerson &person)
{
beginInsertRows(QModelIndex(),dataStore.count(), dataStore.count());
dataStore.append(&person);
endInsertRows();
}
Вот некоторый тестовый код в mainWindow.cpp
// Inc needed files
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
//Test model
personListModel *model = new personListModel(this);
testPerson one("Adam Smith",this);
testPerson two("John Smith",this);
model->addPerson(one);
model->addPerson(two);
ui->listView->setModel(model);
}
Если указанный вами код верен, вы объявляете testPerson
объекты в стеке затем сохраняют их как указатели внутри модели. Удивительно то, что это не вызывает сбой.
Других решений пока нет …