136 lines
4.2 KiB
C++
136 lines
4.2 KiB
C++
/*
|
|
* This file is part of RawTherapee.
|
|
*/
|
|
#ifndef _RETINEX_H_
|
|
#define _RETINEX_H_
|
|
|
|
#include <gtkmm.h>
|
|
#include "adjuster.h"
|
|
#include "toolpanel.h"
|
|
#include "guiutils.h"
|
|
#include "curveeditor.h"
|
|
#include "curveeditorgroup.h"
|
|
#include "thresholdadjuster.h"
|
|
#include "colorprovider.h"
|
|
|
|
class Retinex : public ToolParamBlock, public FoldableToolPanel, public rtengine::RetinexListener, public CurveListener,
|
|
public AdjusterListener, public ColorProvider
|
|
|
|
{
|
|
private:
|
|
IdleRegister idle_register;
|
|
|
|
protected:
|
|
CurveEditorGroup* curveEditorGD;
|
|
CurveEditorGroup* curveEditorGDH;
|
|
CurveEditorGroup* curveEditorGH;
|
|
CurveEditorGroup* curveEditormap;
|
|
Adjuster* str;
|
|
Adjuster* scal;
|
|
Adjuster* grad;
|
|
Adjuster* grads;
|
|
Adjuster* iter;
|
|
Adjuster* neigh;
|
|
Adjuster* offs;
|
|
Adjuster* vart;
|
|
Adjuster* limd;
|
|
Adjuster* highl;
|
|
Adjuster* skal;
|
|
Adjuster* gam;
|
|
Adjuster* slope;
|
|
Adjuster* highlights;
|
|
Adjuster* h_tonalwidth;
|
|
Adjuster* shadows;
|
|
Adjuster* s_tonalwidth;
|
|
Adjuster* radius;
|
|
|
|
MyExpander* expsettings;
|
|
|
|
Gtk::Label* labmdh;
|
|
Gtk::Grid* dhgrid;
|
|
Gtk::Grid* mapgrid;
|
|
Gtk::Label* labmap;
|
|
Gtk::Grid* viewgrid;
|
|
Gtk::Label* labview;
|
|
|
|
Gtk::Label* labgam;
|
|
Gtk::Grid* gamgrid;
|
|
Gtk::Button* neutral;
|
|
|
|
MyComboBoxText* retinexMethod;
|
|
MyComboBoxText* retinexcolorspace;
|
|
MyComboBoxText* gammaretinex;
|
|
MyComboBoxText* mapMethod;
|
|
MyComboBoxText* viewMethod;
|
|
Gtk::CheckButton* medianmap;
|
|
double nextmin;
|
|
double nextmax;
|
|
double nextminiT;
|
|
double nextmaxiT;
|
|
double nextmeanT;
|
|
double nextminT;
|
|
double nextmaxT;
|
|
double nextsigma;
|
|
|
|
Gtk::Label* mMLabels;
|
|
Gtk::Label* transLabels;
|
|
Gtk::Label* transLabels2;
|
|
Gtk::Frame *gainFrame;
|
|
Gtk::Frame *tranFrame;
|
|
Gtk::Frame *iterFrame;
|
|
Gtk::Frame *equalFrame;
|
|
|
|
DiagonalCurveEditor* cdshape;
|
|
DiagonalCurveEditor* cdshapeH;
|
|
DiagonalCurveEditor* mapshape;
|
|
CurveEditorGroup* transmissionCurveEditorG;
|
|
CurveEditorGroup* gaintransmissionCurve;
|
|
sigc::connection retinexMethodConn, neutralconn, mapMethodConn, viewMethodConn;
|
|
sigc::connection retinexColorSpaceConn;
|
|
sigc::connection gammaretinexConn;
|
|
FlatCurveEditor* transmissionShape;
|
|
FlatCurveEditor* gaintransmissionShape;
|
|
FlatCurveEditor* lhshape;
|
|
bool lastmedianmap;
|
|
sigc::connection medianmapConn;
|
|
|
|
public:
|
|
Retinex ();
|
|
~Retinex ();
|
|
|
|
void read (const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr);
|
|
void write (rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr);
|
|
void setBatchMode (bool batchMode);
|
|
void setDefaults (const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr);
|
|
void trimValues (rtengine::procparams::ProcParams* pp);
|
|
void adjusterChanged (Adjuster* a, double newval);
|
|
void autoOpenCurve ();
|
|
void medianmapChanged ();
|
|
void minmaxChanged (double cdma, double cdmin, double mini, double maxi, double Tmean, double Tsigma, double Tmin, double Tmax);
|
|
bool minmaxComputed_ ();
|
|
void updateLabel ();
|
|
void updateTrans ();
|
|
void neutral_pressed ();
|
|
|
|
void enabledChanged ();
|
|
void curveChanged (CurveEditor* ce);
|
|
void retinexMethodChanged();
|
|
void mapMethodChanged();
|
|
void viewMethodChanged();
|
|
void retinexColorSpaceChanged();
|
|
void gammaretinexChanged();
|
|
void ColorSpaceUpdateUI();
|
|
void writeOptions (std::vector<int> &tpOpen);
|
|
void updateToolState (std::vector<int> &tpOpen);
|
|
void setAdjusterBehavior (bool strAdd, bool neighAdd, bool limdAdd, bool offsAdd, bool vartAdd, bool gamAdd, bool slopeAdd);
|
|
void updateCurveBackgroundHistogram (LUTu & histToneCurve, LUTu & histLCurve, LUTu & histCCurve,/* LUTu & histCLurve, LUTu & histLLCurve,*/ LUTu & histLCAM, LUTu & histCCAM, LUTu & histRed, LUTu & histGreen, LUTu & histBlue, LUTu & histLuma, LUTu & histLRETI);
|
|
|
|
virtual void colorForValue (double valX, double valY, enum ColorCaller::ElemType elemType, int callerId, ColorCaller* caller);
|
|
|
|
private:
|
|
void foldAllButMe (GdkEventButton* event, MyExpander *expander);
|
|
|
|
};
|
|
|
|
#endif
|