Fixes incorrect icon width on previewmodepanel toggle buttons

This commit is contained in:
Pandagrapher 2022-12-13 11:47:56 +01:00
parent 21ebb81ece
commit 41a0bef2d8
2 changed files with 86 additions and 72 deletions

View File

@ -19,10 +19,11 @@
#include "options.h" #include "options.h"
#include "multilangmgr.h" #include "multilangmgr.h"
#include "imagearea.h" #include "imagearea.h"
#include "rtimage.h"
PreviewModePanel::PreviewModePanel (ImageArea* ia) : PreviewModePanel::PreviewModePanel (ImageArea* ia) :
imageArea(ia), imageArea(ia),
// Note: RTImage custom class only manages squared icon. To reduce toggle button width,
// toggle button image is managed by icon name
nR("square-toggle-red-on-narrow"), ngR("square-toggle-red-off-narrow"), nR("square-toggle-red-on-narrow"), ngR("square-toggle-red-off-narrow"),
nG("square-toggle-green-on-narrow"), ngG("square-toggle-green-off-narrow"), nG("square-toggle-green-on-narrow"), ngG("square-toggle-green-off-narrow"),
nB("square-toggle-blue-on-narrow"), ngB("square-toggle-blue-off-narrow"), nB("square-toggle-blue-on-narrow"), ngB("square-toggle-blue-off-narrow"),
@ -30,63 +31,55 @@ PreviewModePanel::PreviewModePanel (ImageArea* ia) :
nBC0("square-toggle-theme-on-narrow"), ngBC0("square-toggle-theme-off-narrow"), nBC0("square-toggle-theme-on-narrow"), ngBC0("square-toggle-theme-off-narrow"),
nBC1("square-toggle-black-on-narrow"), ngBC1("square-toggle-black-off-narrow"), nBC1("square-toggle-black-on-narrow"), ngBC1("square-toggle-black-off-narrow"),
nBC2("square-toggle-white-on-narrow"), ngBC2("square-toggle-white-off-narrow"), nBC2("square-toggle-white-on-narrow"), ngBC2("square-toggle-white-off-narrow"),
nBC3("square-toggle-gray-on-narrow"), ngBC3("square-toggle-gray-off-narrow"), nBC3("square-toggle-gray-on-narrow"), ngBC3("square-toggle-gray-off-narrow")
iR(Gtk::manage (new RTImage(ngR, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iG(Gtk::manage (new RTImage(ngG, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iB(Gtk::manage (new RTImage(ngB, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iL(Gtk::manage (new RTImage(ngL, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iBC0(Gtk::manage (new RTImage(options.bgcolor == 0 ? nBC0 : ngBC0, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iBC1(Gtk::manage (new RTImage(options.bgcolor == 1 ? nBC1 : ngBC1, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iBC2(Gtk::manage (new RTImage(options.bgcolor == 2 ? nBC2 : ngBC2, Gtk::ICON_SIZE_LARGE_TOOLBAR))),
iBC3(Gtk::manage (new RTImage(options.bgcolor == 3 ? nBC3 : ngBC3, Gtk::ICON_SIZE_LARGE_TOOLBAR)))
{ {
backColor0 = Gtk::manage (new Gtk::ToggleButton ()); backColor0 = Gtk::manage (new Gtk::ToggleButton ());
backColor0->get_style_context()->add_class("narrowbutton"); backColor0->get_style_context()->add_class("narrowbutton");
backColor0->set_relief(Gtk::RELIEF_NONE); backColor0->set_relief(Gtk::RELIEF_NONE);
backColor0->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR0")); backColor0->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR0"));
backColor0->set_image(*iBC0); backColor0->set_image_from_icon_name(options.bgcolor == 0 ? nBC0 : ngBC0, Gtk::ICON_SIZE_LARGE_TOOLBAR);
backColor1 = Gtk::manage (new Gtk::ToggleButton ()); backColor1 = Gtk::manage (new Gtk::ToggleButton ());
backColor1->get_style_context()->add_class("narrowbutton"); backColor1->get_style_context()->add_class("narrowbutton");
backColor1->set_relief(Gtk::RELIEF_NONE); backColor1->set_relief(Gtk::RELIEF_NONE);
backColor1->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR1")); backColor1->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR1"));
backColor1->set_image(*iBC1); backColor1->set_image_from_icon_name(options.bgcolor == 1 ? nBC1 : ngBC1, Gtk::ICON_SIZE_LARGE_TOOLBAR);
backColor3 = Gtk::manage (new Gtk::ToggleButton ());
backColor3->get_style_context()->add_class("narrowbutton");
backColor3->set_relief(Gtk::RELIEF_NONE);
backColor3->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR3"));
backColor3->set_image(*iBC3);
backColor2 = Gtk::manage (new Gtk::ToggleButton ()); backColor2 = Gtk::manage (new Gtk::ToggleButton ());
backColor2->get_style_context()->add_class("narrowbutton"); backColor2->get_style_context()->add_class("narrowbutton");
backColor2->set_relief(Gtk::RELIEF_NONE); backColor2->set_relief(Gtk::RELIEF_NONE);
backColor2->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR2")); backColor2->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR2"));
backColor2->set_image(*iBC2); backColor2->set_image_from_icon_name(options.bgcolor == 2 ? nBC2 : ngBC2, Gtk::ICON_SIZE_LARGE_TOOLBAR);
backColor3 = Gtk::manage (new Gtk::ToggleButton ());
backColor3->get_style_context()->add_class("narrowbutton");
backColor3->set_relief(Gtk::RELIEF_NONE);
backColor3->set_tooltip_markup (M("MAIN_TOOLTIP_BACKCOLOR3"));
backColor3->set_image_from_icon_name(options.bgcolor == 3 ? nBC3 : ngBC3, Gtk::ICON_SIZE_LARGE_TOOLBAR);
previewR = Gtk::manage (new Gtk::ToggleButton ()); previewR = Gtk::manage (new Gtk::ToggleButton ());
previewR->get_style_context()->add_class("narrowbutton"); previewR->get_style_context()->add_class("narrowbutton");
previewR->set_relief(Gtk::RELIEF_NONE); previewR->set_relief(Gtk::RELIEF_NONE);
previewR->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWR")); previewR->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWR"));
previewR->set_image(*iR); previewR->set_image_from_icon_name(ngR, Gtk::ICON_SIZE_LARGE_TOOLBAR);
previewG = Gtk::manage (new Gtk::ToggleButton ()); previewG = Gtk::manage (new Gtk::ToggleButton ());
previewG->get_style_context()->add_class("narrowbutton"); previewG->get_style_context()->add_class("narrowbutton");
previewG->set_relief(Gtk::RELIEF_NONE); previewG->set_relief(Gtk::RELIEF_NONE);
previewG->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWG")); previewG->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWG"));
previewG->set_image(*iG); previewG->set_image_from_icon_name(ngG, Gtk::ICON_SIZE_LARGE_TOOLBAR);
previewB = Gtk::manage (new Gtk::ToggleButton ()); previewB = Gtk::manage (new Gtk::ToggleButton ());
previewB->get_style_context()->add_class("narrowbutton"); previewB->get_style_context()->add_class("narrowbutton");
previewB->set_relief(Gtk::RELIEF_NONE); previewB->set_relief(Gtk::RELIEF_NONE);
previewB->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWB")); previewB->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWB"));
previewB->set_image(*iB); previewB->set_image_from_icon_name(ngB, Gtk::ICON_SIZE_LARGE_TOOLBAR);
previewL = Gtk::manage (new Gtk::ToggleButton ()); previewL = Gtk::manage (new Gtk::ToggleButton ());
previewL->get_style_context()->add_class("narrowbutton"); previewL->get_style_context()->add_class("narrowbutton");
previewL->set_relief(Gtk::RELIEF_NONE); previewL->set_relief(Gtk::RELIEF_NONE);
previewL->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWL")); previewL->set_tooltip_markup (M("MAIN_TOOLTIP_PREVIEWL"));
previewL->set_image(*iL); previewL->set_image_from_icon_name(ngL, Gtk::ICON_SIZE_LARGE_TOOLBAR);
previewR->set_active (false); previewR->set_active (false);
previewG->set_active (false); previewG->set_active (false);
@ -162,35 +155,50 @@ void PreviewModePanel::togglebackColor3 ()
void PreviewModePanel::buttonToggled (Gtk::ToggleButton* tbpreview) void PreviewModePanel::buttonToggled (Gtk::ToggleButton* tbpreview)
{ {
connR.block(true); connR.block(true);
connG.block(true); connG.block(true);
connB.block(true); connB.block(true);
connL.block(true); connL.block(true);
// control state of the buttons // Control state of the others buttons: only 0 or 1 button at a time can remain pressed
// only 0 or 1 button at a time can remain pressed // Note: Only refresh previously toggled button
if (tbpreview != previewR) { if (previewR->get_active() && tbpreview != previewR) {
previewR->set_active(false); previewR->set_active(false);
previewR->set_image_from_icon_name(ngR, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} }
if (tbpreview != previewG) { if (previewG->get_active() && tbpreview != previewG) {
previewG->set_active(false); previewG->set_active(false);
previewG->set_image_from_icon_name(ngG, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} }
if (tbpreview != previewB) { if (previewB->get_active() && tbpreview != previewB) {
previewB->set_active(false); previewB->set_active(false);
previewB->set_image_from_icon_name(ngB, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} }
if (tbpreview != previewL) { if (previewL->get_active() && tbpreview != previewL) {
previewL->set_active(false); previewL->set_active(false);
previewL->set_image_from_icon_name(ngL, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} }
// set image based on button's state // Change image on activated button
iR->set_from_icon_name(previewR->get_active() ? nR : ngR); // Note: Only refresh toggled button
iG->set_from_icon_name(previewG->get_active() ? nG : ngG); if (tbpreview == previewR) {
iB->set_from_icon_name(previewB->get_active() ? nB : ngB); previewR->set_image_from_icon_name(previewR->get_active() ? nR : ngR, Gtk::ICON_SIZE_LARGE_TOOLBAR);
iL->set_from_icon_name(previewL->get_active() ? nL : ngL); }
if (tbpreview == previewG) {
previewG->set_image_from_icon_name(previewG->get_active() ? nG : ngG, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
if (tbpreview == previewB) {
previewB->set_image_from_icon_name(previewB->get_active() ? nB : ngB, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
if (tbpreview == previewL) {
previewL->set_image_from_icon_name(previewL->get_active() ? nL : ngL, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
connR.block(false); connR.block(false);
connG.block(false); connG.block(false);
@ -246,52 +254,67 @@ void PreviewModePanel::togglebackColor()
void PreviewModePanel::buttonToggled_backColor (Gtk::ToggleButton* tbbackColor) void PreviewModePanel::buttonToggled_backColor (Gtk::ToggleButton* tbbackColor)
{ {
connbackColor0.block(true); connbackColor0.block(true);
connbackColor1.block(true); connbackColor1.block(true);
connbackColor2.block(true); connbackColor2.block(true);
connbackColor3.block(true); connbackColor3.block(true);
// control the state of the buttons // Control state of the others buttons: only 1 button at a time shall remain pressed
// Exactly 1 button at a time must remain pressed // Note: Only refresh previously toggled button
if (tbbackColor == backColor0 && !backColor0->get_active()) { if (backColor0->get_active() && tbbackColor != backColor0) {
backColor0->set_active(false);
backColor0->set_image_from_icon_name(ngBC0, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
if (backColor1->get_active() && tbbackColor != backColor1) {
backColor1->set_active(false);
backColor1->set_image_from_icon_name(ngBC1, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
if (backColor2->get_active() && tbbackColor != backColor2) {
backColor2->set_active(false);
backColor2->set_image_from_icon_name(ngBC2, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
if (backColor3->get_active() && tbbackColor != backColor3) {
backColor3->set_active(false);
backColor3->set_image_from_icon_name(ngBC3, Gtk::ICON_SIZE_LARGE_TOOLBAR);
}
// Change image on toggled button
// Note: Only refresh toggled button if newly active (otherwise keep it active)
if (tbbackColor == backColor0) {
if (backColor0->get_active()) {
backColor0->set_image_from_icon_name(nBC0, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} else {
backColor0->set_active(true); backColor0->set_active(true);
} }
}
if (tbbackColor == backColor1 && !backColor1->get_active()) { if (tbbackColor == backColor1) {
if (backColor1->get_active()) {
backColor1->set_image_from_icon_name(nBC1, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} else {
backColor1->set_active(true); backColor1->set_active(true);
} }
}
if (tbbackColor == backColor2 && !backColor2->get_active()) { if (tbbackColor == backColor2) {
if (backColor2->get_active()) {
backColor2->set_image_from_icon_name(nBC2, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} else {
backColor2->set_active(true); backColor2->set_active(true);
} }
}
if (tbbackColor == backColor3 && !backColor3->get_active()) { if (tbbackColor == backColor3) {
if (backColor3->get_active()) {
backColor3->set_image_from_icon_name(nBC3, Gtk::ICON_SIZE_LARGE_TOOLBAR);
} else {
backColor3->set_active(true); backColor3->set_active(true);
} }
if (tbbackColor != backColor0) {
backColor0->set_active(false);
} }
if (tbbackColor != backColor1) {
backColor1->set_active(false);
}
if (tbbackColor != backColor2) {
backColor2->set_active(false);
}
if (tbbackColor != backColor3) {
backColor3->set_active(false);
}
// set image based on button's state
iBC0->set_from_icon_name(backColor0->get_active() ? nBC0 : ngBC0);
iBC1->set_from_icon_name(backColor1->get_active() ? nBC1 : ngBC1);
iBC2->set_from_icon_name(backColor2->get_active() ? nBC2 : ngBC2);
iBC3->set_from_icon_name(backColor3->get_active() ? nBC3 : ngBC3);
connbackColor0.block(false); connbackColor0.block(false);
connbackColor1.block(false); connbackColor1.block(false);
connbackColor2.block(false); connbackColor2.block(false);

View File

@ -20,7 +20,6 @@
#include <gtkmm.h> #include <gtkmm.h>
class ImageArea; class ImageArea;
class RTImage;
class PreviewModePanel : class PreviewModePanel :
public Gtk::Box public Gtk::Box
@ -45,14 +44,6 @@ protected:
const Glib::ustring nBC1, ngBC1; const Glib::ustring nBC1, ngBC1;
const Glib::ustring nBC2, ngBC2; const Glib::ustring nBC2, ngBC2;
const Glib::ustring nBC3, ngBC3; const Glib::ustring nBC3, ngBC3;
RTImage* const iR;
RTImage* const iG;
RTImage* const iB;
RTImage* const iL;
RTImage* const iBC0;
RTImage* const iBC1;
RTImage* const iBC2;
RTImage* const iBC3;
public: public:
explicit PreviewModePanel (ImageArea* ia); explicit PreviewModePanel (ImageArea* ia);