First patch for issue 2648: "Improvements related to the GUI" ; now RT uses the new MyExpander class that integrates the Enabled button.

This commit is contained in:
Hombrenatureh.510
2015-03-11 02:03:48 +01:00
parent 1aa2ae3903
commit 6020234205
104 changed files with 5099 additions and 1257 deletions

View File

@@ -23,6 +23,7 @@
#include <glibmm.h>
#include "../rtengine/rtengine.h"
#include "../rtengine/procparams.h"
#include "guiutils.h"
#include "multilangmgr.h"
#include "paramsedited.h"
#include "edit.h"
@@ -61,19 +62,21 @@ class ToolParamBlock : public Gtk::VBox {
class ToolPanel {
protected:
Glib::ustring toolName;
ToolPanelListener* listener;
ToolPanelListener* tmp;
bool batchMode; // True if the ToolPanel is used in Batch mode
bool multiImage; // True if more than one image are being edited at the same time (also imply that batchMode=true), false otherwise
bool need100Percent;
public:
ToolPanel () : listener(NULL), tmp(NULL), batchMode(false), multiImage(false) {}
ToolPanel (Glib::ustring toolName="", bool need11=false) : toolName(toolName), listener(NULL), tmp(NULL), batchMode(false), multiImage(false), need100Percent(need11) {}
virtual ~ToolPanel() {}
virtual void setParent (Gtk::Box* parent) {}
virtual Gtk::Box* getParent () { return NULL; }
virtual Gtk::Expander* getExpander () { return NULL; }
virtual MyExpander* getExpander () { return NULL; }
virtual void setExpanded (bool expanded) {}
virtual bool getExpanded () { return false; }
void setMultiImage (bool m) { multiImage = m; }
@@ -103,19 +106,36 @@ class FoldableToolPanel : public ToolPanel {
protected:
Gtk::Box* parentContainer;
MyExpander* exp;
bool lastEnabled;
sigc::connection enaConn;
void foldThemAll (GdkEventButton* event);
Gtk::Expander* exp;
void enabled_toggled();
public:
FoldableToolPanel(Gtk::Box* content);
FoldableToolPanel(Gtk::Box* content, Glib::ustring toolName, Glib::ustring UILabel, bool need11=false, bool useEnabled=false);
Gtk::Expander * getExpander() { return exp; }
MyExpander* getExpander() { return exp; }
void setExpanded (bool expanded) { if (exp) exp->set_expanded( expanded ); }
bool getExpanded () { if (exp) return exp->get_expanded(); return false; }
void setParent (Gtk::Box* parent) { parentContainer = parent; }
Gtk::Box* getParent () { return parentContainer; }
void setLabel (Glib::ustring label, bool need100Percent=false);
virtual void enabledChanged () {}
bool getUseEnabled () { if (exp) return exp->getUseEnabled(); else return true; }
bool getEnabled(); // related to the enabled/disabled state
void setEnabled(bool isActive); // related to the enabled/disabled state
void setEnabledTooltipMarkup(Glib::ustring tooltipMarkup);
void setEnabledTooltipText(Glib::ustring tooltipText);
bool get_inconsistent(); // related to the enabled/disabled state
void set_inconsistent(bool isInconsistent); // related to the enabled/disabled state
// Functions that want to receive an enabled/disabled event from this class
// will have to receive it from MyExpander directly, we do not create
// a relaying event
MyExpander::type_signal_enabled_toggled signal_enabled_toggled() { return exp->signal_enabled_toggled(); }
};
#endif