1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-12 02:28:11 +02:00

Improve bool fields in inspector

This commit is contained in:
nordsoft 2023-09-10 18:10:50 +02:00
parent 5136305455
commit d07fbc2204
4 changed files with 26 additions and 33 deletions

View File

@ -47,14 +47,6 @@ Initializer::Initializer(CGObjectInstance * o, const PlayerColor & pl) : default
//INIT_OBJ_TYPE(CGSeerHut);
}
bool stringToBool(const QString & s)
{
if(s == "TRUE")
return true;
//if(s == "FALSE")
return false;
}
void Initializer::initialize(CArmedInstance * o)
{
if(!o) return;
@ -236,7 +228,7 @@ void Inspector::updateProperties(CGGarrison * o)
if(!o) return;
addProperty("Owner", o->tempOwner, false);
addProperty("Removable units", o->removableUnits, InspectorDelegate::boolDelegate(), false);
addProperty("Removable units", o->removableUnits, false);
}
void Inspector::updateProperties(CGShipyard * o)
@ -345,8 +337,8 @@ void Inspector::updateProperties(CGCreature * o)
delegate->options << "COMPLIANT" << "FRIENDLY" << "AGRESSIVE" << "HOSTILE" << "SAVAGE";
addProperty<CGCreature::Character>("Character", (CGCreature::Character)o->character, delegate, false);
}
addProperty("Never flees", o->neverFlees, InspectorDelegate::boolDelegate(), false);
addProperty("Not growing", o->notGrowingTeam, InspectorDelegate::boolDelegate(), false);
addProperty("Never flees", o->neverFlees, false);
addProperty("Not growing", o->notGrowingTeam, false);
addProperty("Artifact reward", o->gainedArtifact); //TODO: implement in setProperty
addProperty("Army", PropertyEditorPlaceholder(), true);
addProperty("Amount", o->stacks[SlotID(0)]->count, false);
@ -367,9 +359,9 @@ void Inspector::updateProperties(CGEvent * o)
{
if(!o) return;
addProperty("Remove after", o->removeAfterVisit, InspectorDelegate::boolDelegate(), false);
addProperty("Human trigger", o->humanActivate, InspectorDelegate::boolDelegate(), false);
addProperty("Cpu trigger", o->computerActivate, InspectorDelegate::boolDelegate(), false);
addProperty("Remove after", o->removeAfterVisit, false);
addProperty("Human trigger", o->humanActivate, false);
addProperty("Cpu trigger", o->computerActivate, false);
//ui8 availableFor; //players whom this event is available for
}
@ -499,13 +491,13 @@ void Inspector::setProperty(CGEvent * o, const QString & key, const QVariant & v
if(!o) return;
if(key == "Remove after")
o->removeAfterVisit = stringToBool(value.toString());
o->removeAfterVisit = value.toBool();
if(key == "Human trigger")
o->humanActivate = stringToBool(value.toString());
o->humanActivate = value.toBool();
if(key == "Cpu trigger")
o->computerActivate = stringToBool(value.toString());
o->computerActivate = value.toBool();
}
void Inspector::setProperty(CGTownInstance * o, const QString & key, const QVariant & value)
@ -562,7 +554,7 @@ void Inspector::setProperty(CGGarrison * o, const QString & key, const QVariant
if(!o) return;
if(key == "Removable units")
o->removableUnits = stringToBool(value.toString());
o->removableUnits = value.toBool();
}
void Inspector::setProperty(CGHeroInstance * o, const QString & key, const QVariant & value)
@ -626,9 +618,9 @@ void Inspector::setProperty(CGCreature * o, const QString & key, const QVariant
o->character = CGCreature::Character::SAVAGE;
}
if(key == "Never flees")
o->neverFlees = stringToBool(value.toString());
o->neverFlees = value.toBool();
if(key == "Not growing")
o->notGrowingTeam = stringToBool(value.toString());
o->notGrowingTeam = value.toBool();
if(key == "Amount")
o->stacks[SlotID(0)]->count = value.toString().toInt();
}
@ -693,7 +685,10 @@ QTableWidgetItem * Inspector::addProperty(int value)
QTableWidgetItem * Inspector::addProperty(bool value)
{
return new QTableWidgetItem(value ? "TRUE" : "FALSE");
auto item = new QTableWidgetItem;
item->setFlags(item->flags() & ~Qt::ItemIsEditable | Qt::ItemIsUserCheckable);
item->setCheckState(value ? Qt::Checked : Qt::Unchecked);
return item;
}
QTableWidgetItem * Inspector::addProperty(const std::string & value)
@ -827,13 +822,6 @@ Inspector::Inspector(CMap * m, CGObjectInstance * o, QTableWidget * t): obj(o),
* Delegates
*/
InspectorDelegate * InspectorDelegate::boolDelegate()
{
auto * d = new InspectorDelegate;
d->options << "TRUE" << "FALSE";
return d;
}
QWidget * InspectorDelegate::createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
return new QComboBox(parent);

View File

@ -107,7 +107,8 @@ protected:
{
auto * itemValue = addProperty(value);
if(restricted)
itemValue->setFlags(Qt::NoItemFlags);
itemValue->setFlags(itemValue->flags() & ~Qt::ItemIsEnabled);
//itemValue->setFlags(Qt::ItemIsEditable | Qt::ItemIsSelectable);
QTableWidgetItem * itemKey = nullptr;
if(keyItems.contains(key))
@ -120,7 +121,6 @@ protected:
else
{
itemKey = new QTableWidgetItem(key);
itemKey->setFlags(Qt::NoItemFlags);
keyItems[key] = itemKey;
table->setRowCount(row + 1);
@ -130,6 +130,7 @@ protected:
table->setItemDelegateForRow(row, delegate);
++row;
}
itemKey->setFlags(restricted ? Qt::NoItemFlags : Qt::ItemIsEnabled);
}
template<class T>
@ -153,8 +154,6 @@ class InspectorDelegate : public QStyledItemDelegate
{
Q_OBJECT
public:
static InspectorDelegate * boolDelegate();
using QStyledItemDelegate::QStyledItemDelegate;
QWidget * createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override;

View File

@ -1015,7 +1015,10 @@ void MainWindow::on_inspectorWidget_itemChanged(QTableWidgetItem *item)
//set parameter
Inspector inspector(controller.map(), obj, tableWidget);
inspector.setProperty(param, item->text());
if(item->flags() & Qt::ItemIsUserCheckable)
inspector.setProperty(param, QVariant::fromValue(item->checkState() == Qt::Checked));
else
inspector.setProperty(param, item->text());
controller.commitObjectChange(mapLevel);
}

View File

@ -390,6 +390,9 @@
<property name="columnCount">
<number>2</number>
</property>
<attribute name="horizontalHeaderStretchLastSection">
<bool>true</bool>
</attribute>
<attribute name="verticalHeaderVisible">
<bool>false</bool>
</attribute>