在QSqlTableModel中为UI值执行单位转换

时间:2015-07-09 17:04:52

标签: c++ qt sqlite model-view-controller

我已经将QSqlTableModel子类化,并重写了data()和setData()来进行单位转换。也就是说,我想在进入db时将值乘以用户指定的乘数,并在UI中显示该字段时除以相同的乘数。但是,由于某些原因,除了最初填充字段之外,不会调用setData()。

结果:每次我点击UI中的某个字段时,data()中的转换都会完成并且值被分割,而不会在setData()中首先相乘。再次单击该字段,该字段最终达到零值。

调用setData()会有什么影响?

当我查看到达我的data()的堆栈跟踪时,似乎每次都调用QSqlTableModel :: setData,而不是我的函数。

每次调用setData时我都会提交()更改。(/ p>)

根据解决方案,github存储库中的代码现已修复为按预期工作。 完整代码:https://github.com/savolai/qsqltablemodel_conversion_example

mainwindow.cpp:

MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);

// connect to db
QSqlDatabase db;
db = QSqlDatabase::addDatabase("QSQLITE", "db");
db.setDatabaseName("db.sqlite");

if (!db.open()) {
    QMessageBox::critical(0, "Opening database failed",
        "Opening database failed. It really did.", QMessageBox::Close);
}

// connect model to db table table1
TableModel *model=new TableModel(this,db);
model->setTable("table1");
model->setEditStrategy(QSqlTableModel::OnFieldChange);
model->select();

// add new record

QSqlRecord record;
QSqlField field0("radio", QVariant::Int);
field0.setValue(QVariant(QVariant::Int));

int fieldnumber=0;
record.insert(fieldnumber,field0);

int id=-1;
QSqlError error;

if(model->insertRecord(model->rowCount(),record)){
    if(model->submitAll()){
        id=record.value("id").toInt();
    }else{
        error=model->lastError();
        qDebug()<<error.text();

    }

}else{
    error=model->lastError();
    qDebug()<<error.text();
}

QDataWidgetMapper* mapper = new QDataWidgetMapper(this);
mapper->setModel(model);
mapper->toLast();


mapper->addMapping(ui->lineEdit,model->fieldIndex("text"));





}

tablemodel.cpp:

TableModel::TableModel(QObject *parent, QSqlDatabase db)
    :    QSqlTableModel(parent,db)

{

}


bool TableModel::setData(const QModelIndex &index, QVariant &value, int role){

    double dValue=value.toDouble();
    double baseValue=dValue*2;

    bool success=QSqlTableModel::setData(index,QVariant(baseValue),role);
    emit dataChanged(index,index);

    return success;

}

QVariant TableModel::data(const QModelIndex &index, int role) const
{
    QVariant value=QSqlTableModel::data(index,role);
    double dValue=value.toDouble();
    double userValue=dValue/2;
    return QVariant(userValue);

}

1 个答案:

答案 0 :(得分:1)

你的setData原型与原始版本不匹配。

你有

bool TableModel::setData(const QModelIndex &index, QVariant &value, int role)

何时应该

bool TableModel::setData(const QModelIndex &index, const QVariant &value, int role)