【问题标题】:Doing unit conversion for UI values in QSqlTableModel对 QSqlTableModel 中的 UI 值进行单位转换
【发布时间】:2015-07-09 17:04:52
【问题描述】:

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

结果:每次我在 UI 中单击一个字段时,data() 中的转换都会完成并除以值,而无需先在 setData() 中相乘。一遍又一遍地点击该字段,该字段最终达到零值。

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

当我查看到达我的 data() 的堆栈跟踪时,似乎 QSqlTableModel::setData 每次都被调用,而不是我的函数。每次调用 setData 时我都会提交()更改,所以这不应该是问题。

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

主窗口.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);

}

【问题讨论】:

  • 你能给我们看一些代码吗?
  • 当然!做了一个简化的例子来展示这种行为。除法完成,乘法没有。

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


【解决方案1】:

您的 setData 原型与原始原型不匹配。

你有

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

什么时候应该有

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

【讨论】:

  • 谢谢! #qt on freenode 再次拯救了这一天!
猜你喜欢
  • 1970-01-01
  • 2013-04-03
  • 1970-01-01
  • 1970-01-01
  • 2012-03-28
  • 1970-01-01
  • 2023-02-02
  • 2021-03-28
  • 2011-10-28
相关资源
最近更新 更多