Редакция 161 |
Редакция 166 |
К новейшей редакции |
Авторство |
Сравнить с предыдущей |
Последнее изменение |
Открыть журнал
| Скачать
| RSS
#include "mymodel.h"
MyModel::MyModel(QObject *parent) :
QSqlTableModel(parent)
{
setEditStrategy(QSqlTableModel::OnManualSubmit);
}
Qt::ItemFlags MyModel::flags(
const QModelIndex &index) const {
Qt::ItemFlags flags = QSqlTableModel::flags(index);
if ((index.column() != 3) && (index.column() != 0) /* && (index.column() != 5)*/)
flags |= Qt::ItemIsEditable;
//if (index.column() == 4)
// flags |= Qt::ItemIsUserCheckable;
else
{
if ((index.column() == 3) || (index.column() == 0) /* || (index.column() == 5)*/) flags &= ~Qt::ItemIsEditable; // çàïðåùàåì ðåäàêòèðîâàíèå 0, 3 è 5 ñòîëáöà
}
return flags;
}
bool MyModel::setData(const QModelIndex &index, const QVariant &value, int role) {
//// if (index.column()==3) return false; // â òðåòüåé êîëîíêå íå äàåì ïîìåíÿòü çíà÷åíèå
bool lResult = false;
/*
QString str_tmp;
if (index.column()==1) { // åñëè ìåíÿåì èìÿ êëàññà
str_tmp = value.toString(); // òî ïîìåíÿåì è èìÿ òàáëèöû
str_tmp.append(tr(" instance"));
}
*/
/*
QString str_tmp;
if (index.column()==0) { // åñëè ìåíÿåì èìÿ êëàññà
str_tmp = value.toString(); // òî ïîìåíÿåì è èìÿ òàáëèöû
str_tmp.append(tr("_instance"));
}
*/
lResult = QSqlTableModel::setData(index, value, role);
if (lResult) {
QModelIndex newindex;
QSqlRecord rec = record(index.row());
rec.setValue(index.column(), value);
rec.setGenerated(index.column(), true);
/*
if (index.column()==1){
rec.setValue(index.column()+2, QVariant(str_tmp));
rec.setGenerated(index.column()+2, true);
newindex = MyModel::index(index.row(), index.column()+2);
QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
}
*/
/*
if (index.column()==0){
rec.setValue(index.column()+3, QVariant(str_tmp));
rec.setGenerated(index.column()+3, true);
newindex = MyModel::index(index.row(), index.column()+3);
QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
}
*/
lResult = updateRowInTable(index.row(), rec);
/// QSqlTableModel::setData(newindex, QVariant(str_tmp), Qt::EditRole);
}
return lResult;
}
QVariant MyModel::data(const QModelIndex &index, int role) const {
QVariant value = QSqlTableModel::data(index, role);
switch (role) {
case Qt::DisplayRole: return value;
case Qt::EditRole: return value;
case Qt::TextColorRole:
if(index.column() == 1)
return qVariantFromValue(QColor(Qt::blue));
else
return value;
case Qt::TextAlignmentRole: return value;
case Qt::FontRole:
if(index.column() == 1) {
QFont font = QFont("Helvetica", 16, QFont::Bold);
return qVariantFromValue(font);
}else
return value;
case Qt::BackgroundColorRole: {
int a = (index.row() % 2) ? 14 : 0;
if(index.column() == 2)
return qVariantFromValue(QColor(220,240-a,230-a));
else if(index.column() == 4)
return qVariantFromValue(QColor(200,220-a,255-a));
else
return value;
}
case Qt::CheckStateRole: return value;
case Qt::SizeHintRole:
{
// QSize size(200,100);
return value;
// return QVariant(size);
}
case Qt::DecorationRole: {
/* if(index.column() == 5) {
QVariant currentImage = QSqlTableModel::data(index, 0);
QByteArray bytes = currentImage.toByteArray();
QPixmap pxmp;
if (currentImage.isValid()) {
pxmp.loadFromData(bytes);
QIcon icon;
icon.addPixmap(pxmp);
return icon;
}
else {
//QItemDelegate::paint(painter, option, index);
return value;
}
}
*/
}
}
return value;
}