mirror of
https://bitbucket.org/mfeemster/fractorium.git
synced 2025-01-22 13:40:06 -05:00
26c558a2f5
-Give tabs a height of 4px in the qss files. Looks a little large on 4k screens, but just right on HD screens which are much more common. -Allow for styling of zero and non-zero variation tree nodes via qss. -Allow for toggling whether to interpolate between colors in the palette editor, or to do hard cuts between colors. -Allow for adjusting spinner values with the + = or up arrow keys to increase, and - _ or down arrow keys to decrease. -Allow for responding to global presses of + = and - _ to cycle up or down to specify which xform is set as the current one. -Allow for adding "layers" via xaos which will add a user-specified number of xforms, and set certain xaos values to 0 or 1. -Add a new menu item under the Edit menu to copy the OpenCL iteration kernel source to the clipboard. -Show text on the status bar which indicates that an OpenCL kernel compilation is taking place. -Show xform name on xform combo box when expanded. Adjust size to fit all names. -Draw post affine circles using dashed lines. -Prevent QSS dialog from styling its editor, which makes it easier to see text when creating styles which have custom colors for text boxes. --Bug fixes -Fix up some table layouts which seemed to have regressed/decayed over time for reasons unknown. -Using undo/redo would create a new flame in the library every time. -Solo was not being preserved when using undo/redo. --Code changes -Make the solo flag be a part of the flame data now. -Fix some tabification in the OpenCL code for EllipticVariation. -Fix tabification in the varState code for OpenCL. -Add an event called m_CompileBegun to RendererCL that is called right before an OpenCL compile is begun. --This required making RendererCLBase not a pure virtual base class. Member functions just return defaults. -Filter key presses on main window to only process the third one. This is due to Qt triggering three events for every key press. -The palette preview table was installing an event filter for seemingly no reason. Remove it. -Mark certain virtual functions as override in SpinBox and DoubleSpinBox.
483 lines
16 KiB
C++
483 lines
16 KiB
C++
#include "FractoriumPch.h"
|
|
#include "VariationsDialog.h"
|
|
|
|
/// <summary>
|
|
/// Constructor that takes a parent widget and passes it to the base, then
|
|
/// sets up the GUI.
|
|
/// </summary>
|
|
/// <param name="settings">Pointer to the global settings object to use</param>
|
|
/// <param name="p">The parent widget. Default: nullptr.</param>
|
|
/// <param name="f">The window flags. Default: 0.</param>
|
|
FractoriumVariationsDialog::FractoriumVariationsDialog(QWidget* p, Qt::WindowFlags f)
|
|
: QDialog(p, f),
|
|
m_VariationList(VariationList<float>::Instance())
|
|
{
|
|
ui.setupUi(this);
|
|
auto table = ui.VariationsTable;
|
|
m_Settings = FractoriumSettings::DefInstance();
|
|
m_Vars = m_Settings->Variations();
|
|
Populate();
|
|
OnSelectAllButtonClicked(true);
|
|
m_CheckBoxes.push_back(ui.SumCheckBox);
|
|
m_CheckBoxes.push_back(ui.AssignCheckBox);
|
|
m_CheckBoxes.push_back(ui.PpSumCheckBox);
|
|
m_CheckBoxes.push_back(ui.PpAssignCheckBox);
|
|
m_CheckBoxes.push_back(ui.DcCheckBox);
|
|
m_CheckBoxes.push_back(ui.StateCheckBox);
|
|
m_CheckBoxes.push_back(ui.ParamCheckBox);
|
|
m_CheckBoxes.push_back(ui.NonParamCheckBox);
|
|
ui.SumCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterSum ()));
|
|
ui.AssignCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterAssign ()));
|
|
ui.PpSumCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterPpsum ()));
|
|
ui.PpAssignCheckBox->setCheckState(Qt::CheckState(m_Settings->VarFilterPpassign()));
|
|
ui.DcCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterSdc ()));
|
|
ui.StateCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterState ()));
|
|
ui.ParamCheckBox->setCheckState (Qt::CheckState(m_Settings->VarFilterParam ()));
|
|
ui.NonParamCheckBox->setCheckState(Qt::CheckState(m_Settings->VarFilterNonparam()));
|
|
|
|
for (auto& cb : m_CheckBoxes)
|
|
{
|
|
if (cb->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
auto f = cb->font();
|
|
f.setStrikeOut(true);
|
|
cb->setFont(f);
|
|
}
|
|
}
|
|
|
|
table->verticalHeader()->setSectionsClickable(true);
|
|
table->horizontalHeader()->setSectionsClickable(true);
|
|
table->verticalHeader()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
|
connect(table, SIGNAL(itemChanged(QTableWidgetItem*)), this, SLOT(OnVariationsTableItemChanged(QTableWidgetItem*)), Qt::QueuedConnection);
|
|
connect(ui.SelectAllButton, SIGNAL(clicked(bool)), this, SLOT(OnSelectAllButtonClicked(bool)), Qt::QueuedConnection);
|
|
connect(ui.InvertSelectionButton, SIGNAL(clicked(bool)), this, SLOT(OnInvertSelectionButtonClicked(bool)), Qt::QueuedConnection);
|
|
connect(ui.SelectNoneButton, SIGNAL(clicked(bool)), this, SLOT(OnSelectNoneButtonClicked(bool)), Qt::QueuedConnection);
|
|
connect(ui.SumCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.AssignCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.PpSumCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.PpAssignCheckBox, SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.DcCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.StateCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.ParamCheckBox , SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
connect(ui.NonParamCheckBox, SIGNAL(stateChanged(int)), this, SLOT(OnSelectionCheckBoxStateChanged(int)), Qt::QueuedConnection);
|
|
}
|
|
|
|
/// <summary>
|
|
/// A wrapper to iterate over every table widget item and perform the passed in function on it.
|
|
/// </summary>
|
|
/// <param name="func">Function to call on each object</param>
|
|
void FractoriumVariationsDialog::ForEachCell(std::function<void(QTableWidgetItem* cb)> func)
|
|
{
|
|
auto table = ui.VariationsTable;
|
|
auto rows = table->rowCount();
|
|
auto cols = table->columnCount();
|
|
table->model()->blockSignals(true);
|
|
|
|
for (auto row = 0; row < rows; row++)
|
|
for (auto col = 0; col < cols; col++)
|
|
if (auto cb = table->item(row, col))
|
|
func(cb);
|
|
|
|
table->model()->blockSignals(false);
|
|
table->model()->layoutChanged();
|
|
}
|
|
|
|
/// <summary>
|
|
/// A wrapper to iterate over every selected table widget item and perform the passed in function on it.
|
|
/// </summary>
|
|
/// <param name="func">Function to call on each object</param>
|
|
void FractoriumVariationsDialog::ForEachSelectedCell(std::function<void(QTableWidgetItem* cb)> func)
|
|
{
|
|
auto table = ui.VariationsTable;
|
|
QList<QTableWidgetItem*> selectedItems = table->selectedItems();
|
|
table->model()->blockSignals(true);
|
|
|
|
for (auto item : selectedItems)
|
|
if (item)
|
|
func(item);
|
|
|
|
table->model()->blockSignals(false);
|
|
table->model()->layoutChanged();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copy the values of the checkboxes to the map.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::SyncSettings()
|
|
{
|
|
QMap<QString, QVariant> m;
|
|
ForEachCell([&](QTableWidgetItem * cb)
|
|
{
|
|
if (!cb->text().isEmpty())
|
|
m[cb->text()] = cb->checkState() == Qt::CheckState::Checked;
|
|
});
|
|
m_Settings->Variations(m);
|
|
m_Settings->VarFilterSum (int(ui.SumCheckBox->checkState()));
|
|
m_Settings->VarFilterAssign (int(ui.AssignCheckBox->checkState()));
|
|
m_Settings->VarFilterPpsum (int(ui.PpSumCheckBox->checkState()));
|
|
m_Settings->VarFilterPpassign(int(ui.PpAssignCheckBox->checkState()));
|
|
m_Settings->VarFilterSdc (int(ui.DcCheckBox->checkState()));
|
|
m_Settings->VarFilterState (int(ui.StateCheckBox->checkState()));
|
|
m_Settings->VarFilterParam (int(ui.ParamCheckBox->checkState()));
|
|
m_Settings->VarFilterNonparam(int(ui.NonParamCheckBox->checkState()));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Return a const reference to the map.
|
|
/// This will contains the state of the checkboxes after
|
|
/// the user clicks ok.
|
|
/// </summary>
|
|
const QMap<QString, QVariant>& FractoriumVariationsDialog::Map()
|
|
{
|
|
return m_Vars;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Clears the type checkboxes without triggering any events.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::ClearTypesStealth()
|
|
{
|
|
for (auto& cb : m_CheckBoxes)
|
|
{
|
|
cb->blockSignals(true);
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
auto f = cb->font();
|
|
f.setStrikeOut(cb->checkState() == Qt::CheckState::PartiallyChecked);
|
|
cb->setFont(f);
|
|
cb->blockSignals(false);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Check all of the checkboxes.
|
|
/// </summary>
|
|
/// <param name="checked">Ignored</param>
|
|
void FractoriumVariationsDialog::OnSelectAllButtonClicked(bool checked)
|
|
{
|
|
ClearTypesStealth();
|
|
ForEachCell([&](QTableWidgetItem * cb) { cb->setCheckState(Qt::CheckState::Checked); });
|
|
}
|
|
|
|
/// <summary>
|
|
/// Invert the selection state of the checkboxes.
|
|
/// </summary>
|
|
/// <param name="checked">Ignored</param>
|
|
void FractoriumVariationsDialog::OnInvertSelectionButtonClicked(bool checked)
|
|
{
|
|
ClearTypesStealth();
|
|
ForEachCell([&](QTableWidgetItem * cb)
|
|
{
|
|
if (cb->checkState() != Qt::CheckState::Checked)
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
else
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
});
|
|
}
|
|
|
|
/// <summary>
|
|
/// Uncheck all of the checkboxes.
|
|
/// </summary>
|
|
/// <param name="checked">Ignored</param>
|
|
void FractoriumVariationsDialog::OnSelectNoneButtonClicked(bool checked)
|
|
{
|
|
ClearTypesStealth();
|
|
ForEachCell([&](QTableWidgetItem * cb) { cb->setCheckState(Qt::CheckState::Unchecked); });
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when any of the selection checkboxes change state.
|
|
/// This will re-evaluate the entire grid of checkboxes.
|
|
/// </summary>
|
|
/// <param name="i">Ignored</param>
|
|
void FractoriumVariationsDialog::OnSelectionCheckBoxStateChanged(int i)
|
|
{
|
|
static vector<string> dc{ "m_ColorX" };
|
|
static vector<string> assign{ "outPoint->m_X =", "outPoint->m_Y =", "outPoint->m_Z =",
|
|
"outPoint->m_X=", "outPoint->m_Y=", "outPoint->m_Z=" };
|
|
static std::set<eVariationId> excluded;
|
|
excluded.clear();
|
|
|
|
if (auto s = dynamic_cast<QCheckBox*>(sender()))
|
|
{
|
|
auto f = s->font();
|
|
f.setStrikeOut(s->checkState() == Qt::CheckState::PartiallyChecked);
|
|
s->setFont(f);
|
|
}
|
|
|
|
ForEachCell([&](QTableWidgetItem * cb) { cb->setCheckState(Qt::CheckState::Unchecked); });
|
|
ForEachCell([&](QTableWidgetItem * cb)
|
|
{
|
|
if (auto var = m_VariationList->GetVariation(cb->text().toStdString()))
|
|
{
|
|
if (ui.StateCheckBox->checkState() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (!var->StateOpenCLString().empty())
|
|
{
|
|
if (ui.StateCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(var->VariationId());
|
|
}
|
|
else if (!Contains(excluded, var->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (ui.SumCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (var->VarType() == eVariationType::VARTYPE_REG && !SearchVar(var, assign, false))
|
|
{
|
|
if (ui.SumCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(var->VariationId());
|
|
}
|
|
else if (!Contains(excluded, var->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (ui.AssignCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (var->VarType() == eVariationType::VARTYPE_REG && SearchVar(var, assign, false))
|
|
{
|
|
if (ui.AssignCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(var->VariationId());
|
|
}
|
|
else if (!Contains(excluded, var->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (ui.DcCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (SearchVar(var, dc, false))
|
|
{
|
|
if (ui.DcCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(var->VariationId());
|
|
}
|
|
else if (!Contains(excluded, var->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (ui.NonParamCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (!m_VariationList->GetParametricVariation(cb->text().toStdString()))
|
|
{
|
|
if (ui.NonParamCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(var->VariationId());
|
|
}
|
|
else if (!Contains(excluded, var->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (ui.PpSumCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (auto pre = m_VariationList->GetPreVariation(cb->text().toStdString()))
|
|
{
|
|
if (pre->AssignType() == eVariationAssignType::ASSIGNTYPE_SUM)
|
|
{
|
|
if (ui.PpSumCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(pre->VariationId());
|
|
}
|
|
else if (!Contains(excluded, pre->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (auto post = m_VariationList->GetPostVariation(cb->text().toStdString()))
|
|
{
|
|
if (post->AssignType() == eVariationAssignType::ASSIGNTYPE_SUM)
|
|
{
|
|
if (ui.PpSumCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(post->VariationId());
|
|
}
|
|
else if (!Contains(excluded, post->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (ui.PpAssignCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (auto pre = m_VariationList->GetPreVariation(cb->text().toStdString()))
|
|
{
|
|
if (pre->AssignType() == eVariationAssignType::ASSIGNTYPE_SET)
|
|
{
|
|
if (ui.PpAssignCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(pre->VariationId());
|
|
}
|
|
else if (!Contains(excluded, pre->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
|
|
if (auto post = m_VariationList->GetPostVariation(cb->text().toStdString()))
|
|
{
|
|
if (post->AssignType() == eVariationAssignType::ASSIGNTYPE_SET)
|
|
{
|
|
if (ui.PpAssignCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(post->VariationId());
|
|
}
|
|
else if (!Contains(excluded, post->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (ui.ParamCheckBox->isChecked() != Qt::CheckState::Unchecked)
|
|
{
|
|
if (auto parVar = m_VariationList->GetParametricVariation(cb->text().toStdString()))
|
|
{
|
|
if (ui.ParamCheckBox->checkState() == Qt::CheckState::PartiallyChecked)
|
|
{
|
|
cb->setCheckState(Qt::CheckState::Unchecked);
|
|
excluded.insert(parVar->VariationId());
|
|
}
|
|
else if (!Contains(excluded, parVar->VariationId()))
|
|
cb->setCheckState(Qt::CheckState::Checked);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
/// <summary>
|
|
/// Create all checkboxes and check them according to the map.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::Populate()
|
|
{
|
|
auto table = ui.VariationsTable;
|
|
int size = int(std::max<size_t>(std::max<size_t>(m_VariationList->RegSize(), m_VariationList->PreSize()), m_VariationList->PostSize()));
|
|
table->setRowCount(size);
|
|
|
|
for (auto i = 0; i < size; i++)
|
|
{
|
|
if (auto pre = m_VariationList->GetVariation(i, eVariationType::VARTYPE_PRE))
|
|
{
|
|
auto cb = new QTableWidgetItem(pre->Name().c_str());
|
|
table->setItem(i, 0, cb);
|
|
SetCheckFromMap(cb, pre);
|
|
}
|
|
|
|
if (auto reg = m_VariationList->GetVariation(i, eVariationType::VARTYPE_REG))
|
|
{
|
|
auto cb = new QTableWidgetItem(reg->Name().c_str());
|
|
table->setItem(i, 1, cb);
|
|
SetCheckFromMap(cb, reg);
|
|
}
|
|
|
|
if (auto post = m_VariationList->GetVariation(i, eVariationType::VARTYPE_POST))
|
|
{
|
|
auto cb = new QTableWidgetItem(post->Name().c_str());
|
|
table->setItem(i, 2, cb);
|
|
SetCheckFromMap(cb, post);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when a checkbox changes state.
|
|
/// There is a slight hack here to apply the change to all selected checkboxes
|
|
/// if ctrl is pressed.
|
|
/// Otherwise it will only apply to the checkbox that was clicked.
|
|
/// </summary>
|
|
/// <param name="item"></param>
|
|
void FractoriumVariationsDialog::OnVariationsTableItemChanged(QTableWidgetItem* item)
|
|
{
|
|
bool ctrl = QGuiApplication::keyboardModifiers().testFlag(Qt::ControlModifier);
|
|
|
|
if (ctrl)
|
|
ForEachSelectedCell([&](QTableWidgetItem * cb) { cb->setCheckState(item->checkState()); });
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when the user clicks ok.
|
|
/// Copy the state of the checkboxes to the map.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::accept()
|
|
{
|
|
GuiToData();
|
|
QDialog::accept();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Called when the user clicks cancel.
|
|
/// Reset the state of the the checkboxes to what the map previously was
|
|
/// when the dialog was shown.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::reject()
|
|
{
|
|
DataToGui();
|
|
QDialog::reject();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copy the state of the map to the checkboxes and show the dialog.
|
|
/// </summary>
|
|
/// <param name="e">Event, passed to base.</param>
|
|
void FractoriumVariationsDialog::showEvent(QShowEvent* e)
|
|
{
|
|
DataToGui();
|
|
QDialog::showEvent(e);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copy the values in the map to the state of the checkboxes.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::DataToGui()
|
|
{
|
|
ForEachCell([&](QTableWidgetItem * cb)
|
|
{
|
|
if (auto var = m_VariationList->GetVariation(cb->text().toStdString()))
|
|
SetCheckFromMap(cb, var);
|
|
});
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copy the state of the checkboxes to the map.
|
|
/// </summary>
|
|
void FractoriumVariationsDialog::GuiToData()
|
|
{
|
|
ForEachCell([&](QTableWidgetItem * cb)
|
|
{
|
|
if (auto var = m_VariationList->GetVariation(cb->text().toStdString()))
|
|
m_Vars[cb->text()] = (cb->checkState() == Qt::Checked);
|
|
});
|
|
}
|
|
|
|
/// <summary>
|
|
/// Set the state of the passed in table item checkbox based on the boolean contained
|
|
/// in the map for the passed in variation.
|
|
/// </summary>
|
|
/// <param name="cb">The checkbox to check</param>
|
|
/// <param name="var">That variation to be looked up in the map</param>
|
|
void FractoriumVariationsDialog::SetCheckFromMap(QTableWidgetItem* cb, const Variation<float>* var)
|
|
{
|
|
if (!m_Vars.contains(var->Name().c_str()))
|
|
{
|
|
cb->setCheckState(Qt::Checked);
|
|
}
|
|
else
|
|
{
|
|
bool chk = m_Vars[var->Name().c_str()].toBool();
|
|
cb->setCheckState(chk ? Qt::Checked : Qt::Unchecked);
|
|
}
|
|
}
|