From 6701d22a95ea0d09a4792696098874b675634aa8 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Sat, 25 Jun 2022 22:27:35 +0300 Subject: [PATCH 53/53] Qt: Rewrite color options part of option dialog The old implementation had so many problems that there was no way to fix it. See osdn #44947 Signed-off-by: Marko Lindqvist --- client/gui-qt/optiondlg.cpp | 91 +++++++++++++++++-------------------- client/gui-qt/optiondlg.h | 4 +- 2 files changed, 44 insertions(+), 51 deletions(-) diff --git a/client/gui-qt/optiondlg.cpp b/client/gui-qt/optiondlg.cpp index 0d1b272152..9257f5fa78 100644 --- a/client/gui-qt/optiondlg.cpp +++ b/client/gui-qt/optiondlg.cpp @@ -41,6 +41,7 @@ // gui-qt #include "fc_client.h" + #include "optiondlg.h" enum { @@ -228,7 +229,7 @@ void option_dialog::apply_option(int response) } /************************************************************************//** - Return selected colors (for highlighting chat). + Return selected colors ****************************************************************************/ void option_dialog::get_color(struct option *poption, QByteArray &a1, QByteArray &a2) @@ -236,7 +237,7 @@ void option_dialog::get_color(struct option *poption, QByteArray &a1, QPalette pal; QColor col1, col2; QWidget *w; - QPushButton* but; + QPushButton *but; w = reinterpret_cast(option_get_gui_data(poption)); but = w->findChild("text_color"); @@ -277,7 +278,7 @@ void option_dialog::apply_options() option_font_set(poption, get_button_font(poption).constData()); break; case OT_COLOR: - get_color(poption, ba1, ba2); + get_color(poption, ba1, ba2); option_color_set(poption, ft_color_construct(ba1.data(), ba2.data())); break; case OT_VIDEO_MODE: @@ -467,16 +468,19 @@ unsigned int option_dialog::get_bitwise(struct option *poption) } /************************************************************************//** - Find option indicating colors. + Update color button stylesheet to show new color ****************************************************************************/ -struct option* option_dialog::get_color_option() +void option_dialog::set_button_color(QPushButton *button, + const char *colorname) { - options_iterate(curr_options, poption) { - if (option_type(poption) == OT_COLOR) { - return poption; - } - } options_iterate_end; - return NULL; + if (button != nullptr && colorname != NULL && colorname[0] != '\0') { + QString s1 = "QPushButton { background-color: "; + QString s2 = ";}"; + QColor col; + + col.setNamedColor(colorname); + button->setStyleSheet(s1 + col.name() + s2); + } } /************************************************************************//** @@ -484,26 +488,15 @@ struct option* option_dialog::get_color_option() ****************************************************************************/ void option_dialog::set_color(struct option *poption, struct ft_color color) { - QPalette pal, pal2; - QColor col; QWidget *w; QPushButton *but; - QString s1 = "QPushButton { background-color: "; - QString s2 = ";}"; w = reinterpret_cast(option_get_gui_data(poption)); but = w->findChild("text_color"); - if (NULL != but && NULL != color.foreground - && '\0' != color.foreground[0]) { - col.setNamedColor(color.foreground); - but->setStyleSheet(s1 + col.name() + s2); - } + set_button_color(but, color.foreground); + but = w->findChild("text_background"); - if (NULL != but && NULL != color.background - && '\0' != color.background[0]) { - col.setNamedColor(color.background); - but->setStyleSheet(s1 + col.name() + s2); - } + set_button_color(but, color.background); } /************************************************************************//** @@ -511,7 +504,6 @@ void option_dialog::set_color(struct option *poption, struct ft_color color) ****************************************************************************/ void option_dialog::option_dialog_refresh(struct option *poption) { - switch (option_type(poption)) { case OT_BOOLEAN: set_bool(poption, option_bool_get(poption)); @@ -632,6 +624,8 @@ void option_dialog::add_option(struct option *poption) QPalette pal; int min, max, i; unsigned int j; + struct ft_color ft_color; + QColor c; category_name = option_category_name(poption); widget = nullptr; @@ -719,12 +713,17 @@ void option_dialog::add_option(struct option *poption) break; case OT_COLOR: + ft_color = option_color_get(poption); button = new QPushButton(); button->setToolTip(_("Select the text color")); button->setObjectName("text_color"); button->setAutoFillBackground(true); button->setAutoDefault(false); - connect(button, SIGNAL(clicked()), this, SLOT(set_color())); + c.setNamedColor(ft_color.foreground); + pal = button->palette(); + pal.setColor(QPalette::Button, c); + button->setPalette(pal); + connect(button, SIGNAL(clicked()), this, SLOT(select_color())); hbox_layout = new QHBoxLayout(); hbox_layout->addWidget(button); button = new QPushButton(); @@ -732,9 +731,14 @@ void option_dialog::add_option(struct option *poption) button->setObjectName("text_background"); button->setAutoFillBackground(true); button->setAutoDefault(false); - connect(button, SIGNAL(clicked()), this, SLOT(set_color())); + c.setNamedColor(ft_color.background); + pal = button->palette(); + pal.setColor(QPalette::Button, c); + button->setPalette(pal); + connect(button, SIGNAL(clicked()), this, SLOT(select_color())); hbox_layout->addWidget(button); widget = new QWidget(); + widget->setObjectName(option_name(poption)); widget->setLayout(hbox_layout); break; @@ -829,34 +833,23 @@ QByteArray option_dialog::get_button_font(struct option *poption) } /************************************************************************//** - Set color of buttons (user just changed colors). + Ask user for the color option value ****************************************************************************/ -void option_dialog::set_color() +void option_dialog::select_color() { QPushButton *but; - QColor color, c; - struct option *color_option; - struct ft_color ft_color; + QColor color; QPalette pal; - color_option = get_color_option(); - ft_color = option_color_get(color_option); but = qobject_cast(QObject::sender()); - if (but->objectName() == "text_color") { - c.setNamedColor(ft_color.foreground); - color = QColorDialog::getColor(c, this); - if (color.isValid()) { - pal.setColor(QPalette::Button, color); - but->setPalette(pal); - } - } else if (but->objectName() == "text_background") { - c.setNamedColor(ft_color.background); - color = QColorDialog::getColor(c, this); - if (color.isValid()) { - pal.setColor(QPalette::Button, color); - but->setPalette(pal); - } + pal = but->palette(); + color = QColorDialog::getColor(pal.color(QPalette::Button), this); + if (color.isValid()) { + pal.setColor(QPalette::Button, color); + but->setPalette(pal); + + set_button_color(but, color.name().toUtf8()); } } diff --git a/client/gui-qt/optiondlg.h b/client/gui-qt/optiondlg.h index 8deae7a27e..a2ba4f39bf 100644 --- a/client/gui-qt/optiondlg.h +++ b/client/gui-qt/optiondlg.h @@ -70,6 +70,7 @@ private: void set_enum(struct option *poption, int index); void set_bitwise(struct option *poption, unsigned value); void set_color(struct option *poption, struct ft_color color); + void set_button_color(QPushButton *button, const char *colorname); void set_font(struct option *poption, QString s); void get_color(struct option *poption, QByteArray &a1, QByteArray &a2); bool get_bool(struct option *poption); @@ -78,7 +79,6 @@ private: QByteArray get_button_font(struct option *poption); QByteArray get_string(struct option *poption); int get_enum(struct option *poption); - struct option* get_color_option(); unsigned get_bitwise(struct option *poption); void full_reset(); @@ -89,7 +89,7 @@ protected: private slots: void apply_option(int response); - void set_color(); + void select_color(); void set_font(); }; -- 2.35.1