feat: implement configurable font settings for VTK viewports and GUI elements with persistent preferences.
This commit is contained in:
@@ -11,6 +11,7 @@
|
||||
#include <QColorDialog>
|
||||
#include <QFrame>
|
||||
#include <QSlider>
|
||||
#include <QFontDialog>
|
||||
#include "Settings.h"
|
||||
|
||||
namespace uLib {
|
||||
@@ -151,7 +152,7 @@ DoublePropertyWidget::DoublePropertyWidget(Property<double>* prop, QWidget* pare
|
||||
}
|
||||
m_Edit->setValue(prop->Get());
|
||||
m_Layout->addWidget(m_Edit, 1);
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set(val); });
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set(val); emit updated(); });
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<double>::Updated, [this](){
|
||||
m_Edit->setValue(m_Prop->Get());
|
||||
});
|
||||
@@ -169,7 +170,7 @@ FloatPropertyWidget::FloatPropertyWidget(Property<float>* prop, QWidget* parent)
|
||||
}
|
||||
m_Edit->setValue(prop->Get());
|
||||
m_Layout->addWidget(m_Edit, 1);
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set((float)val); });
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set((float)val); emit updated(); });
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<float>::Updated, [this](){
|
||||
m_Edit->setValue((double)m_Prop->Get());
|
||||
});
|
||||
@@ -188,7 +189,7 @@ IntPropertyWidget::IntPropertyWidget(Property<int>* prop, QWidget* parent)
|
||||
}
|
||||
m_Edit->setValue(prop->Get());
|
||||
m_Layout->addWidget(m_Edit, 1);
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set((int)val); });
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set((int)val); emit updated(); });
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<int>::Updated, [this](){
|
||||
m_Edit->setValue((double)m_Prop->Get());
|
||||
});
|
||||
@@ -199,7 +200,7 @@ BoolPropertyWidget::BoolPropertyWidget(Property<bool>* prop, QWidget* parent)
|
||||
m_CheckBox = new QCheckBox(this);
|
||||
m_CheckBox->setChecked(prop->Get());
|
||||
m_Layout->addWidget(m_CheckBox, 1);
|
||||
connect(m_CheckBox, &QCheckBox::toggled, [this](bool val){ if (m_Prop->Get() != val) m_Prop->Set(val); });
|
||||
connect(m_CheckBox, &QCheckBox::toggled, [this](bool val){ if (m_Prop->Get() != val) { m_Prop->Set(val); emit updated(); } });
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<bool>::Updated, [this](){
|
||||
if (m_CheckBox->isChecked() != m_Prop->Get()) {
|
||||
QSignalBlocker blocker(m_CheckBox);
|
||||
@@ -222,7 +223,7 @@ RangePropertyWidget::RangePropertyWidget(Property<double>* prop, QWidget* parent
|
||||
m_Layout->addWidget(m_Edit, 0);
|
||||
|
||||
connect(m_Slider, &QSlider::valueChanged, this, &RangePropertyWidget::onSliderChanged);
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set(val); });
|
||||
connect(m_Edit, &UnitLineEdit::valueManualChanged, [this](double val){ m_Prop->Set(val); emit updated(); });
|
||||
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<double>::Updated, [this](){
|
||||
this->updateUi();
|
||||
@@ -244,6 +245,7 @@ void RangePropertyWidget::updateUi() {
|
||||
void RangePropertyWidget::onSliderChanged(int val) {
|
||||
double realVal = m_Prop->GetMin() + (val / 100.0) * (m_Prop->GetMax() - m_Prop->GetMin());
|
||||
m_Prop->Set(realVal);
|
||||
emit updated();
|
||||
}
|
||||
|
||||
ColorPropertyWidget::ColorPropertyWidget(Property<Vector3d>* prop, QWidget* parent)
|
||||
@@ -276,6 +278,7 @@ void ColorPropertyWidget::onClicked() {
|
||||
QColor selected = QColorDialog::getColor(current, this, "Select Color");
|
||||
if (selected.isValid()) {
|
||||
m_Prop->Set(Vector3d(selected.redF(), selected.greenF(), selected.blueF()));
|
||||
emit updated();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -286,7 +289,7 @@ StringPropertyWidget::StringPropertyWidget(Property<std::string>* prop, QWidget*
|
||||
m_Layout->addWidget(m_LineEdit, 1);
|
||||
connect(m_LineEdit, &QLineEdit::editingFinished, [this](){
|
||||
std::string val = m_LineEdit->text().toStdString();
|
||||
if (m_Prop->Get() != val) m_Prop->Set(val);
|
||||
if (m_Prop->Get() != val) { m_Prop->Set(val); emit updated(); }
|
||||
});
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<std::string>::Updated, [this](){
|
||||
if (m_LineEdit->text().toStdString() != m_Prop->Get()) {
|
||||
@@ -297,6 +300,40 @@ StringPropertyWidget::StringPropertyWidget(Property<std::string>* prop, QWidget*
|
||||
}
|
||||
StringPropertyWidget::~StringPropertyWidget() {}
|
||||
|
||||
FontPropertyWidget::FontPropertyWidget(Property<FontConfig>* prop, QWidget* parent)
|
||||
: PropertyWidgetBase(prop, parent), m_Prop(prop) {
|
||||
m_Button = new QPushButton(this);
|
||||
m_Button->setMinimumWidth(100);
|
||||
this->updateButtonText();
|
||||
m_Layout->addWidget(m_Button, 1);
|
||||
|
||||
connect(m_Button, &QPushButton::clicked, this, &FontPropertyWidget::onClicked);
|
||||
m_Connection = uLib::Object::connect(m_Prop, &Property<FontConfig>::Updated, [this](){
|
||||
this->updateButtonText();
|
||||
});
|
||||
}
|
||||
FontPropertyWidget::~FontPropertyWidget() {}
|
||||
|
||||
void FontPropertyWidget::updateButtonText() {
|
||||
FontConfig f = m_Prop->Get();
|
||||
m_Button->setText(QString::fromStdString(f.family) + " " + QString::number(f.size));
|
||||
}
|
||||
|
||||
void FontPropertyWidget::onClicked() {
|
||||
FontConfig current = m_Prop->Get();
|
||||
QFont font(QString::fromStdString(current.family), current.size);
|
||||
font.setBold(current.bold);
|
||||
font.setItalic(current.italic);
|
||||
|
||||
bool ok;
|
||||
QFont selected = QFontDialog::getFont(&ok, font, this, "Select Font");
|
||||
if (ok) {
|
||||
FontConfig newF(selected.family().toStdString(), selected.pointSize(), selected.bold(), selected.italic());
|
||||
m_Prop->Set(newF);
|
||||
emit updated();
|
||||
}
|
||||
}
|
||||
|
||||
class GroupHeaderWidget : public QWidget {
|
||||
public:
|
||||
GroupHeaderWidget(const QString& name, QWidget* parent = nullptr) : QWidget(parent) {
|
||||
@@ -332,8 +369,9 @@ public:
|
||||
// Get initial value
|
||||
if (auto* p = dynamic_cast<Property<int>*>(prop)) {
|
||||
m_Combo->setCurrentIndex(p->Get());
|
||||
connect(m_Combo, &QComboBox::currentIndexChanged, [p](int index){
|
||||
connect(m_Combo, &QComboBox::currentIndexChanged, [this, p](int index){
|
||||
p->Set(index);
|
||||
emit updated();
|
||||
});
|
||||
// Store connection in base m_Connection so it's auto-disconnected on destruction.
|
||||
m_Connection = uLib::Object::connect(p, &Property<int>::Updated, [this, p](){
|
||||
@@ -374,6 +412,9 @@ PropertyEditor::PropertyEditor(QWidget* parent) : QWidget(parent), m_Object(null
|
||||
registerFactory<std::string>([](PropertyBase* p, QWidget* parent){
|
||||
return new StringPropertyWidget(static_cast<Property<std::string>*>(p), parent);
|
||||
});
|
||||
registerFactory<FontConfig>([](PropertyBase* p, QWidget* parent){
|
||||
return new FontPropertyWidget(static_cast<Property<FontConfig>*>(p), parent);
|
||||
});
|
||||
|
||||
// Register EnumProperty specifically (needs to check type since it holds Property<int> but is EnumProperty)
|
||||
m_Factories[std::type_index(typeid(EnumProperty))] = [](PropertyBase* p, QWidget* parent) {
|
||||
@@ -462,6 +503,12 @@ void PropertyEditor::setObject(::uLib::Object* obj, bool displayOnly) {
|
||||
}
|
||||
|
||||
if (widget) {
|
||||
if (auto* propWidget = qobject_cast<PropertyWidgetBase*>(widget)) {
|
||||
connect(propWidget, &PropertyWidgetBase::updated, [this, prop](){
|
||||
emit propertyUpdated(prop);
|
||||
});
|
||||
}
|
||||
|
||||
if (!groupName.empty()) {
|
||||
// Indent grouped properties
|
||||
widget->setContentsMargins(16, 0, 0, 0);
|
||||
|
||||
Reference in New Issue
Block a user