1287 lines
48 KiB
C++
1287 lines
48 KiB
C++
/*
|
|
* This file is part of RawTherapee.
|
|
*
|
|
* Copyright (c) 2004-2010 Gabor Horvath <hgabor@rawtherapee.com>frame
|
|
*
|
|
*
|
|
* RawTherapee is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* RawTherapee is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with RawTherapee. If not, see <http://www.gnu.org/licenses/>.
|
|
* 2019 Pierre Cabrera <pierre.cab@gmail.com>
|
|
*/
|
|
#ifndef _LOCALLABTOOLS_H_
|
|
#define _LOCALLABTOOLS_H_
|
|
|
|
#include "curveeditorgroup.h"
|
|
#include "curveeditor.h"
|
|
#include "labgrid.h"
|
|
#include "thresholdadjuster.h"
|
|
#include "toolpanel.h"
|
|
#include "adjuster.h"
|
|
|
|
/* ==== LocallabToolListener ==== */
|
|
class LocallabTool;
|
|
class LocallabToolListener
|
|
{
|
|
public:
|
|
LocallabToolListener() {};
|
|
virtual ~LocallabToolListener() {};
|
|
|
|
virtual void resetOtherMaskView(LocallabTool* current) = 0;
|
|
virtual void toolRemoved(LocallabTool* current) = 0;
|
|
};
|
|
|
|
|
|
/* ==== LocallabTool ==== */
|
|
class LocallabTool:
|
|
public ToolPanel,
|
|
public CurveListener,
|
|
public ColorProvider,
|
|
public AdjusterListener
|
|
{
|
|
protected:
|
|
// LocallabTool mode enumeration
|
|
enum modeType {
|
|
Expert = 0,
|
|
Normal = 1
|
|
};
|
|
|
|
// LocallabTool parameters
|
|
bool needMode;
|
|
bool isLocActivated;
|
|
Glib::ustring spotName;
|
|
LocallabToolListener* locToolListener;
|
|
|
|
// LocallabTool generic widgets
|
|
MyExpander* exp;
|
|
MyComboBoxText* const complexity;
|
|
|
|
sigc::connection enaExpConn, complexityConn;
|
|
|
|
IdleRegister idle_register;
|
|
|
|
public:
|
|
// Locallab tool constructor/destructor
|
|
LocallabTool(Gtk::Box* content, Glib::ustring toolName, Glib::ustring UILabel, bool need11 = false, bool needMode = true);
|
|
virtual ~LocallabTool();
|
|
|
|
// Getter for Locallab tool expander
|
|
MyExpander* getExpander() override
|
|
{
|
|
return exp;
|
|
}
|
|
|
|
// Getter/setter for Locallab tool expanded status
|
|
void setExpanded(bool expanded) override
|
|
{
|
|
exp->set_expanded(expanded);
|
|
}
|
|
|
|
bool getExpanded() override
|
|
{
|
|
return exp->get_expanded();
|
|
}
|
|
|
|
// Setter for Locallab activation indicator
|
|
void isLocallabActivated(bool cond)
|
|
{
|
|
isLocActivated = cond;
|
|
}
|
|
|
|
// Setter for spot name
|
|
void setSpotName(const Glib::ustring &spotname)
|
|
{
|
|
spotName = spotname;
|
|
}
|
|
|
|
// Setter for Locallab tool listener
|
|
void setLocallabToolListener(LocallabToolListener* ltl)
|
|
{
|
|
locToolListener = ltl;
|
|
}
|
|
|
|
// Management functions to add/remove Locallab tool
|
|
void addLocallabTool(bool raiseEvent);
|
|
void removeLocallabTool(bool raiseEvent);
|
|
bool isLocallabToolAdded();
|
|
|
|
// Mask background management function
|
|
void refChanged(const double huer, const double lumar, const double chromar);
|
|
|
|
// Mask preview functions
|
|
virtual bool isMaskViewActive()
|
|
{
|
|
return false;
|
|
};
|
|
virtual void resetMaskView() {};
|
|
virtual void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) {};
|
|
|
|
// Advice tooltips management function
|
|
virtual void updateAdviceTooltips(const bool showTooltips) {};
|
|
|
|
/* Notes:
|
|
- callerId #1: Mask CC shape (bottom bar) + Color CC/LC shape (left bar)
|
|
- callerId #2: Mask HH shape (main curve and bottom bar)
|
|
- callerId #3: Color LH/HH shape (main curve)
|
|
- callerId #4: Color CC/LC shape (bottom bar)
|
|
*/
|
|
void colorForValue(double valX, double valY, enum ColorCaller::ElemType elemType, int callerId, ColorCaller* caller) override;
|
|
|
|
// To be implemented
|
|
virtual void setDefaultExpanderVisibility() {};
|
|
virtual void disableListener();
|
|
virtual void enableListener();
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override {};
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override {};
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override {};
|
|
void adjusterChanged(Adjuster* a, double newval) override {};
|
|
void curveChanged(CurveEditor* ce) override {};
|
|
|
|
protected:
|
|
// To be implemented
|
|
virtual void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) {}; // Only necessary when using mask
|
|
|
|
private:
|
|
// Remove button event function
|
|
bool on_remove_change(GdkEventButton* event);
|
|
|
|
// Tool expander event function
|
|
void foldThemAll(GdkEventButton* event);
|
|
|
|
// Complexity mode event function
|
|
void complexityModeChanged();
|
|
|
|
// To be implemented
|
|
virtual void enabledChanged() {};
|
|
virtual void convertParamToNormal() {}; // Only necessary when using mode
|
|
virtual void updateGUIToMode(const modeType new_type) {}; // Only necessary when using mode
|
|
};
|
|
|
|
/* ==== LocallabColor ==== */
|
|
class LocallabColor:
|
|
public Gtk::VBox,
|
|
public LocallabTool,
|
|
public ThresholdAdjusterListener
|
|
{
|
|
private:
|
|
// Color & Light specific widgets
|
|
Gtk::Frame* const lumFrame;
|
|
Gtk::CheckButton* const curvactiv;
|
|
Adjuster* const lightness;
|
|
Adjuster* const contrast;
|
|
Adjuster* const chroma;
|
|
Gtk::Frame* const gridFrame;
|
|
LabGrid* const labgrid;
|
|
MyComboBoxText* const gridMethod;
|
|
Adjuster* const strengthgrid;
|
|
Adjuster* const sensi;
|
|
Adjuster* const structcol;
|
|
Adjuster* const blurcolde;
|
|
Adjuster* const softradiuscol;
|
|
Gtk::CheckButton* const invers;
|
|
MyExpander* const expgradcol;
|
|
Adjuster* const strcol;
|
|
Adjuster* const strcolab;
|
|
Adjuster* const strcolh;
|
|
Adjuster* const angcol;
|
|
MyExpander* const expcurvcol;
|
|
Gtk::Label* const labqualcurv;
|
|
MyComboBoxText* const qualitycurveMethod;
|
|
CurveEditorGroup* const llCurveEditorG;
|
|
DiagonalCurveEditor* const llshape;
|
|
DiagonalCurveEditor* const ccshape;
|
|
CurveEditorGroup* const clCurveEditorG;
|
|
DiagonalCurveEditor* const clshape;
|
|
DiagonalCurveEditor* const lcshape;
|
|
CurveEditorGroup* const HCurveEditorG;
|
|
FlatCurveEditor* const LHshape;
|
|
CurveEditorGroup* const H2CurveEditorG;
|
|
FlatCurveEditor* const HHshape;
|
|
CurveEditorGroup* const H3CurveEditorG;
|
|
FlatCurveEditor* const CHshape;
|
|
CurveEditorGroup* const rgbCurveEditorG;
|
|
MyComboBoxText* const toneMethod;
|
|
DiagonalCurveEditor* const rgbshape;
|
|
Gtk::CheckButton* const special;
|
|
MyExpander* const expmaskcol1;
|
|
MyComboBoxText* const merMethod;
|
|
ToolParamBlock* const mask7;
|
|
MyComboBoxText* const mergecolMethod;
|
|
Adjuster* const mercol;
|
|
Adjuster* const opacol;
|
|
Adjuster* const conthrcol;
|
|
Gtk::Frame* const gridmerFrame;
|
|
LabGrid* const labgridmerg;
|
|
Adjuster* const merlucol;
|
|
MyExpander* const expmaskcol;
|
|
MyComboBoxText* const showmaskcolMethod;
|
|
MyComboBoxText* const showmaskcolMethodinv;
|
|
Gtk::CheckButton* const enaColorMask;
|
|
CurveEditorGroup* const maskCurveEditorG;
|
|
FlatCurveEditor* const CCmaskshape;
|
|
FlatCurveEditor* const LLmaskshape;
|
|
FlatCurveEditor* const HHmaskshape;
|
|
Gtk::Frame* const struFrame;
|
|
Adjuster* const strumaskcol;
|
|
Gtk::CheckButton* const toolcol;
|
|
Gtk::Frame* const blurFrame;
|
|
Gtk::CheckButton* const fftColorMask;
|
|
Adjuster* const contcol;
|
|
Adjuster* const blurcol;
|
|
Adjuster* const blendmaskcol;
|
|
Adjuster* const radmaskcol;
|
|
Adjuster* const lapmaskcol;
|
|
Adjuster* const chromaskcol;
|
|
Adjuster* const gammaskcol;
|
|
Adjuster* const slomaskcol;
|
|
Adjuster* const shadmaskcol;
|
|
CurveEditorGroup* const maskHCurveEditorG;
|
|
FlatCurveEditor* const HHhmaskshape;
|
|
CurveEditorGroup* const mask2CurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskshape;
|
|
CurveEditorGroup* const mask2CurveEditorGwav;
|
|
FlatCurveEditor* const LLmaskcolshapewav;
|
|
ThresholdAdjuster* const csThresholdcol;
|
|
|
|
sigc::connection curvactivConn, gridMethodConn, inversConn, qualitycurveMethodConn, toneMethodConn, specialConn, merMethodConn, mergecolMethodConn, showmaskcolMethodConn, showmaskcolMethodConninv, enaColorMaskConn, toolcolConn, fftColorMaskConn;
|
|
|
|
public:
|
|
LocallabColor();
|
|
~LocallabColor();
|
|
|
|
void setListener(ToolPanelListener* tpl) override;
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottom, double newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottomLeft, double newTopLeft, double newBottomRight, double newTopRight) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottom, int newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottomLeft, int newTopLeft, int newBottomRight, int newTopRight) override {}; // Not used
|
|
void adjusterChanged2(ThresholdAdjuster* a, int newBottomL, int newTopL, int newBottomR, int newTopR) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void curvactivChanged();
|
|
void gridMethodChanged();
|
|
void inversChanged();
|
|
void qualitycurveMethodChanged();
|
|
void toneMethodChanged();
|
|
void specialChanged();
|
|
void merMethodChanged();
|
|
void mergecolMethodChanged();
|
|
void showmaskcolMethodChanged();
|
|
void showmaskcolMethodChangedinv();
|
|
void enaColorMaskChanged();
|
|
void toolcolChanged();
|
|
void fftColorMaskChanged();
|
|
|
|
void updateColorGUI1();
|
|
void updateColorGUI2();
|
|
void updateColorGUI3();
|
|
};
|
|
|
|
/* ==== LocallabExposure ==== */
|
|
class LocallabExposure:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
// Exposure specific widgets
|
|
MyComboBoxText* const expMethod;
|
|
Gtk::Frame* const pdeFrame;
|
|
Adjuster* const laplacexp;
|
|
Adjuster* const linear;
|
|
Adjuster* const balanexp;
|
|
Adjuster* const gamm;
|
|
MyComboBoxText* const exnoiseMethod;
|
|
Gtk::Frame* const fatFrame;
|
|
Adjuster* const fatamount;
|
|
Adjuster* const fatdetail;
|
|
Adjuster* const fatlevel;
|
|
Adjuster* const fatanchor;
|
|
Adjuster* const sensiex;
|
|
Adjuster* const structexp;
|
|
Adjuster* const blurexpde;
|
|
MyExpander* const exptoolexp;
|
|
Adjuster* const expcomp;
|
|
Adjuster* const black;
|
|
Adjuster* const hlcompr;
|
|
Adjuster* const hlcomprthresh;
|
|
Adjuster* const shadex;
|
|
Adjuster* const shcompr;
|
|
Adjuster* const expchroma;
|
|
CurveEditorGroup* const curveEditorG;
|
|
DiagonalCurveEditor* shapeexpos;
|
|
MyExpander* const expgradexp;
|
|
Adjuster* const strexp;
|
|
Adjuster* const angexp;
|
|
Adjuster* const softradiusexp;
|
|
Gtk::CheckButton* const inversex;
|
|
MyExpander* const expmaskexp;
|
|
MyComboBoxText* const showmaskexpMethod;
|
|
MyComboBoxText* const showmaskexpMethodinv;
|
|
Gtk::CheckButton* const enaExpMask;
|
|
Gtk::CheckButton* const enaExpMaskaft;
|
|
CurveEditorGroup* const maskexpCurveEditorG;
|
|
FlatCurveEditor* const CCmaskexpshape;
|
|
FlatCurveEditor* const LLmaskexpshape;
|
|
FlatCurveEditor* const HHmaskexpshape;
|
|
Adjuster* const blendmaskexp;
|
|
Adjuster* const radmaskexp;
|
|
Adjuster* const lapmaskexp;
|
|
Adjuster* const chromaskexp;
|
|
Adjuster* const gammaskexp;
|
|
Adjuster* const slomaskexp;
|
|
Gtk::Frame* const gradFramemask;
|
|
Adjuster* const strmaskexp;
|
|
Adjuster* const angmaskexp;
|
|
CurveEditorGroup* const mask2expCurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskexpshape;
|
|
|
|
sigc::connection expMethodConn, exnoiseMethodConn, inversexConn, showmaskexpMethodConn, showmaskexpMethodConninv, enaExpMaskConn, enaExpMaskaftConn;
|
|
|
|
public:
|
|
LocallabExposure();
|
|
~LocallabExposure();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void expMethodChanged();
|
|
void exnoiseMethodChanged();
|
|
void inversexChanged();
|
|
void showmaskexpMethodChanged();
|
|
void showmaskexpMethodChangedinv();
|
|
void enaExpMaskChanged();
|
|
void enaExpMaskaftChanged();
|
|
|
|
void updateExposureGUI1();
|
|
void updateExposureGUI2();
|
|
void updateExposureGUI3();
|
|
};
|
|
|
|
/* ==== LocallabShadow ==== */
|
|
class LocallabShadow:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
// Shadow highlight specific widgets
|
|
MyComboBoxText* const shMethod;
|
|
const std::array<Adjuster*, 5> multipliersh;
|
|
Adjuster* const detailSH;
|
|
Adjuster* const highlights;
|
|
Adjuster* const h_tonalwidth;
|
|
Adjuster* const shadows;
|
|
Adjuster* const s_tonalwidth;
|
|
Adjuster* const sh_radius;
|
|
Adjuster* const sensihs;
|
|
Adjuster* const blurSHde;
|
|
Gtk::Frame* const gamFrame;
|
|
Adjuster* const gamSH;
|
|
Adjuster* const sloSH;
|
|
MyExpander* const expgradsh;
|
|
Adjuster* const strSH;
|
|
Adjuster* const angSH;
|
|
Gtk::CheckButton* const inverssh;
|
|
MyExpander* const expmasksh;
|
|
MyComboBoxText* const showmaskSHMethod;
|
|
MyComboBoxText* const showmaskSHMethodinv;
|
|
Gtk::CheckButton* const enaSHMask;
|
|
CurveEditorGroup* const maskSHCurveEditorG;
|
|
FlatCurveEditor* const CCmaskSHshape;
|
|
FlatCurveEditor* const LLmaskSHshape;
|
|
FlatCurveEditor* const HHmaskSHshape;
|
|
Adjuster* const blendmaskSH;
|
|
Adjuster* const radmaskSH;
|
|
Adjuster* const lapmaskSH;
|
|
Adjuster* const chromaskSH;
|
|
Adjuster* const gammaskSH;
|
|
Adjuster* const slomaskSH;
|
|
CurveEditorGroup* const mask2SHCurveEditorG;
|
|
DiagonalCurveEditor* const LmaskSHshape;
|
|
Gtk::Frame* const fatSHFrame;
|
|
Adjuster* const fatamountSH;
|
|
Adjuster* const fatanchorSH;
|
|
|
|
sigc::connection shMethodConn, inversshConn, showmaskSHMethodConn, showmaskSHMethodConninv, enaSHMaskConn;
|
|
|
|
public:
|
|
LocallabShadow();
|
|
~LocallabShadow();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void shMethodChanged();
|
|
void inversshChanged();
|
|
void showmaskSHMethodChanged();
|
|
void showmaskSHMethodChangedinv();
|
|
void enaSHMaskChanged();
|
|
|
|
void updateShadowGUI1();
|
|
void updateShadowGUI2();
|
|
};
|
|
|
|
/* ==== LocallabVibrance ==== */
|
|
class LocallabVibrance:
|
|
public Gtk::VBox,
|
|
public LocallabTool,
|
|
public ThresholdAdjusterListener,
|
|
public ThresholdCurveProvider
|
|
{
|
|
private:
|
|
// Vibrance specific widgets
|
|
Adjuster* const saturated;
|
|
Adjuster* const pastels;
|
|
Adjuster* const warm;
|
|
ThresholdAdjuster* const psThreshold;
|
|
Gtk::CheckButton* const protectSkins;
|
|
Gtk::CheckButton* const avoidColorShift;
|
|
Gtk::CheckButton* const pastSatTog;
|
|
Adjuster* const sensiv;
|
|
CurveEditorGroup* const curveEditorGG;
|
|
DiagonalCurveEditor* const skinTonesCurve;
|
|
MyExpander* const expgradvib;
|
|
Adjuster* const strvib;
|
|
Adjuster* const strvibab;
|
|
Adjuster* const strvibh;
|
|
Adjuster* const angvib;
|
|
MyExpander* const expmaskvib;
|
|
MyComboBoxText* const showmaskvibMethod;
|
|
Gtk::CheckButton* const enavibMask;
|
|
CurveEditorGroup* const maskvibCurveEditorG;
|
|
FlatCurveEditor* const CCmaskvibshape;
|
|
FlatCurveEditor* const LLmaskvibshape;
|
|
FlatCurveEditor* const HHmaskvibshape;
|
|
Adjuster* const blendmaskvib;
|
|
Adjuster* const radmaskvib;
|
|
Adjuster* const lapmaskvib;
|
|
Adjuster* const chromaskvib;
|
|
Adjuster* const gammaskvib;
|
|
Adjuster* const slomaskvib;
|
|
CurveEditorGroup* const mask2vibCurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskvibshape;
|
|
|
|
sigc::connection pskinsConn, ashiftConn, pastsattogConn, showmaskvibMethodConn, enavibMaskConn;
|
|
|
|
public:
|
|
LocallabVibrance();
|
|
~LocallabVibrance();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottom, double newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottomLeft, double newTopLeft, double newBottomRight, double newTopRight) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottom, int newTop) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottomLeft, int newTopLeft, int newBottomRight, int newTopRight) override {}; // Not used
|
|
void adjusterChanged2(ThresholdAdjuster* a, int newBottomL, int newTopL, int newBottomR, int newTopR) override {}; // Not used
|
|
std::vector<double> getCurvePoints(ThresholdSelector* tAdjuster) const override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void protectskins_toggled();
|
|
void avoidcolorshift_toggled();
|
|
void pastsattog_toggled();
|
|
void showmaskvibMethodChanged();
|
|
void enavibMaskChanged();
|
|
|
|
void updateVibranceGUI();
|
|
};
|
|
|
|
/* ==== LocallabSoft ==== */
|
|
class LocallabSoft:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
// Soft light specific widgets
|
|
MyComboBoxText* const softMethod;
|
|
Gtk::HBox* const ctboxsoftmethod;
|
|
MyComboBoxText* const showmasksoftMethod;
|
|
Adjuster* const streng;
|
|
Adjuster* const laplace;
|
|
Adjuster* const sensisf;
|
|
|
|
sigc::connection softMethodConn, showmasksoftMethodConn;
|
|
|
|
public:
|
|
LocallabSoft();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void softMethodChanged();
|
|
void showmasksoftMethodChanged();
|
|
|
|
void updateSoftGUI();
|
|
};
|
|
|
|
/* ==== LocallabBlur ==== */
|
|
class LocallabBlur:
|
|
public Gtk::VBox,
|
|
public LocallabTool,
|
|
public ThresholdAdjusterListener
|
|
{
|
|
private:
|
|
// Blur & Noise specific widgets
|
|
MyExpander* const expblnoise;
|
|
MyComboBoxText* const blMethod;
|
|
Gtk::CheckButton* const fftwbl;
|
|
Adjuster* const radius;
|
|
Adjuster* const strength;
|
|
Gtk::Frame* const grainFrame;
|
|
Adjuster* const isogr;
|
|
Adjuster* const strengr;
|
|
Adjuster* const scalegr;
|
|
MyComboBoxText* const medMethod;
|
|
Adjuster* const itera;
|
|
Adjuster* const guidbl;
|
|
Adjuster* const strbl;
|
|
Adjuster* const epsbl;
|
|
Adjuster* const sensibn;
|
|
MyComboBoxText* const blurMethod;
|
|
MyComboBoxText* const chroMethod;
|
|
Gtk::CheckButton* const activlum;
|
|
MyExpander* const expdenoise;
|
|
CurveEditorGroup* const LocalcurveEditorwavden;
|
|
FlatCurveEditor* const wavshapeden;
|
|
Adjuster* const noiselumf0;
|
|
Adjuster* const noiselumf;
|
|
Adjuster* const noiselumf2;
|
|
Adjuster* const noiselumc;
|
|
Adjuster* const noiselumdetail;
|
|
Adjuster* const noiselequal;
|
|
Adjuster* const noisechrof;
|
|
Adjuster* const noisechroc;
|
|
Adjuster* const noisechrodetail;
|
|
Adjuster* const detailthr;
|
|
Adjuster* const adjblur;
|
|
Adjuster* const bilateral;
|
|
Adjuster* const sensiden;
|
|
MyExpander* const expmaskbl;
|
|
MyComboBoxText* const showmaskblMethod;
|
|
MyComboBoxText* const showmaskblMethodtyp;
|
|
Gtk::CheckButton* const enablMask;
|
|
CurveEditorGroup* const maskblCurveEditorG;
|
|
FlatCurveEditor* const CCmaskblshape;
|
|
FlatCurveEditor* const LLmaskblshape;
|
|
FlatCurveEditor* const HHmaskblshape;
|
|
Adjuster* const strumaskbl;
|
|
Gtk::CheckButton* const toolbl;
|
|
Adjuster* const blendmaskbl;
|
|
Adjuster* const radmaskbl;
|
|
Adjuster* const lapmaskbl;
|
|
Adjuster* const chromaskbl;
|
|
Adjuster* const gammaskbl;
|
|
Adjuster* const slomaskbl;
|
|
Adjuster* const shadmaskbl;
|
|
Adjuster* const shadmaskblsha;
|
|
CurveEditorGroup* const mask2blCurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskblshape;
|
|
CurveEditorGroup* const mask2blCurveEditorGwav;
|
|
FlatCurveEditor* const LLmaskblshapewav;
|
|
ThresholdAdjuster* const csThresholdblur;
|
|
|
|
sigc::connection blMethodConn, fftwblConn, medMethodConn, blurMethodConn, chroMethodConn, activlumConn, showmaskblMethodConn, showmaskblMethodtypConn, enablMaskConn, toolblConn;
|
|
|
|
public:
|
|
LocallabBlur();
|
|
~LocallabBlur();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottom, double newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottomLeft, double newTopLeft, double newBottomRight, double newTopRight) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottom, int newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottomLeft, int newTopLeft, int newBottomRight, int newTopRight) override {}; // Not used
|
|
void adjusterChanged2(ThresholdAdjuster* a, int newBottomL, int newTopL, int newBottomR, int newTopR) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void blMethodChanged();
|
|
void fftwblChanged();
|
|
void medMethodChanged();
|
|
void blurMethodChanged();
|
|
void chroMethodChanged();
|
|
void activlumChanged();
|
|
void showmaskblMethodChanged();
|
|
void showmaskblMethodtypChanged();
|
|
void enablMaskChanged();
|
|
void toolblChanged();
|
|
|
|
void updateBlurGUI();
|
|
};
|
|
|
|
/* ==== LocallabTone ==== */
|
|
class LocallabTone:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
// Tone Mapping specific widgets
|
|
Adjuster* const amount;
|
|
Adjuster* const stren;
|
|
Gtk::CheckButton* const equiltm;
|
|
Adjuster* const gamma;
|
|
Adjuster* const satur;
|
|
Adjuster* const estop;
|
|
Adjuster* const scaltm;
|
|
Adjuster* const rewei;
|
|
Adjuster* const softradiustm;
|
|
Adjuster* const sensitm;
|
|
MyExpander* const expmasktm;
|
|
MyComboBoxText* const showmasktmMethod;
|
|
Gtk::CheckButton* const enatmMask;
|
|
Gtk::CheckButton* const enatmMaskaft;
|
|
CurveEditorGroup* const masktmCurveEditorG;
|
|
FlatCurveEditor* const CCmasktmshape;
|
|
FlatCurveEditor* const LLmasktmshape;
|
|
FlatCurveEditor* const HHmasktmshape;
|
|
Adjuster* const blendmasktm;
|
|
Adjuster* const lapmasktm;
|
|
Adjuster* const radmasktm;
|
|
Adjuster* const chromasktm;
|
|
Adjuster* const gammasktm;
|
|
Adjuster* const slomasktm;
|
|
CurveEditorGroup* const mask2tmCurveEditorG;
|
|
DiagonalCurveEditor* const Lmasktmshape;
|
|
|
|
sigc::connection equiltmConn, showmasktmMethodConn, enatmMaskConn, enatmMaskaftConn;
|
|
|
|
public:
|
|
LocallabTone();
|
|
~LocallabTone();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void equiltmChanged();
|
|
void showmasktmMethodChanged();
|
|
void enatmMaskChanged();
|
|
void enatmMaskaftChanged();
|
|
};
|
|
|
|
/* ==== LocallabRetinex ==== */
|
|
class LocallabRetinex:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
// Retinex specific widgets
|
|
Adjuster* const dehaz;
|
|
Adjuster* const depth;
|
|
Gtk::CheckButton* const lumonly;
|
|
Gtk::Frame* const retiFrame;
|
|
Adjuster* const str;
|
|
Gtk::CheckButton* const loglin;
|
|
Adjuster* const sensih;
|
|
Gtk::Frame* const retitoolFrame;
|
|
MyComboBoxText* const retinexMethod;
|
|
Gtk::CheckButton* const fftwreti;
|
|
Gtk::CheckButton* const equilret;
|
|
Adjuster* const neigh;
|
|
Adjuster* const vart;
|
|
Adjuster* const scalereti;
|
|
Adjuster* const limd;
|
|
Adjuster* const offs;
|
|
MyExpander* const expretitools;
|
|
Adjuster* const chrrt;
|
|
Adjuster* const darkness;
|
|
Adjuster* const lightnessreti;
|
|
Adjuster* const cliptm;
|
|
Adjuster* const softradiusret;
|
|
CurveEditorGroup* const LocalcurveEditortransT;
|
|
FlatCurveEditor* const cTtransshape;
|
|
Gtk::Label* const mMLabels;
|
|
Gtk::Label* const transLabels;
|
|
Gtk::Label* const transLabels2;
|
|
CurveEditorGroup* const LocalcurveEditorgainT;
|
|
FlatCurveEditor* const cTgainshape;
|
|
MyExpander* const expmaskreti;
|
|
MyComboBoxText* const showmaskretiMethod;
|
|
Gtk::CheckButton* const enaretiMask;
|
|
Gtk::CheckButton* const enaretiMasktmap;
|
|
CurveEditorGroup* const maskretiCurveEditorG;
|
|
FlatCurveEditor* const CCmaskretishape;
|
|
FlatCurveEditor* const LLmaskretishape;
|
|
FlatCurveEditor* const HHmaskretishape;
|
|
Adjuster* const blendmaskreti;
|
|
Adjuster* const radmaskreti;
|
|
Adjuster* const lapmaskreti;
|
|
Adjuster* const chromaskreti;
|
|
Adjuster* const gammaskreti;
|
|
Adjuster* const slomaskreti;
|
|
CurveEditorGroup* const mask2retiCurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskretishape;
|
|
Gtk::CheckButton* const inversret;
|
|
|
|
sigc::connection lumonlyConn, loglinConn, retinexMethodConn, fftwretiConn, equilretConn, showmaskretiMethodConn, enaretiMaskConn, enaretiMasktmapConn, inversretConn;
|
|
|
|
public:
|
|
LocallabRetinex();
|
|
~LocallabRetinex();
|
|
|
|
void updateMinMax(const double cdma, const double cdmin, const double mini, const double maxi, const double Tmean, const double Tsigma, const double Tmin, const double Tmax);
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void lumonlyChanged();
|
|
void loglinChanged();
|
|
void retinexMethodChanged();
|
|
void fftwretiChanged();
|
|
void equilretChanged();
|
|
void showmaskretiMethodChanged();
|
|
void enaretiMaskChanged();
|
|
void enaretiMasktmapChanged();
|
|
void inversretChanged();
|
|
|
|
void updateRetinexGUI1();
|
|
void updateRetinexGUI2();
|
|
void updateRetinexGUI3();
|
|
};
|
|
|
|
/* ==== LocallabSharp ==== */
|
|
class LocallabSharp:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
Adjuster* const sharcontrast;
|
|
Adjuster* const sharblur;
|
|
Adjuster* const sharamount;
|
|
Adjuster* const shardamping;
|
|
Adjuster* const shariter;
|
|
Adjuster* const sharradius;
|
|
Adjuster* const sensisha;
|
|
Gtk::CheckButton* const inverssha;
|
|
MyComboBoxText* const showmasksharMethod;
|
|
|
|
sigc::connection inversshaConn, showmasksharMethodConn;
|
|
|
|
public:
|
|
LocallabSharp();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void inversshaChanged();
|
|
void showmasksharMethodChanged();
|
|
};
|
|
|
|
/* ==== LocallabContrast ==== */
|
|
class LocallabContrast:
|
|
public Gtk::VBox,
|
|
public LocallabTool,
|
|
public ThresholdAdjusterListener
|
|
{
|
|
private:
|
|
MyComboBoxText* const localcontMethod;
|
|
Adjuster* const lcradius;
|
|
Adjuster* const lcamount;
|
|
Adjuster* const lcdarkness;
|
|
Adjuster* const lclightness;
|
|
Gtk::Frame* const contFrame;
|
|
Adjuster* const sigmalc;
|
|
CurveEditorGroup* const LocalcurveEditorwav;
|
|
FlatCurveEditor* const wavshape;
|
|
Adjuster* const levelwav;
|
|
ThresholdAdjuster* const csThreshold;
|
|
MyExpander* const expresidpyr;
|
|
Adjuster* const residcont;
|
|
Adjuster* const residchro;
|
|
Adjuster* const residsha;
|
|
Adjuster* const residshathr;
|
|
Adjuster* const residhi;
|
|
Adjuster* const residhithr;
|
|
Adjuster* const sensilc;
|
|
Gtk::Frame* const clariFrame;
|
|
Adjuster* const clarilres;
|
|
Adjuster* const claricres;
|
|
Adjuster* const clarisoft;
|
|
Gtk::CheckButton* const origlc;
|
|
MyExpander* const expcontrastpyr;
|
|
Gtk::CheckButton* const wavgradl;
|
|
Adjuster* const sigmalc2;
|
|
Adjuster* const strwav;
|
|
Adjuster* const angwav;
|
|
Gtk::CheckButton* const wavedg;
|
|
Adjuster* const strengthw;
|
|
Adjuster* const sigmaed;
|
|
CurveEditorGroup* const LocalcurveEditorwavedg;
|
|
FlatCurveEditor* const wavshapeedg;
|
|
Adjuster* const gradw;
|
|
Gtk::CheckButton* const waveshow;
|
|
ToolParamBlock* const edgsBoxshow;
|
|
Adjuster* const radiusw;
|
|
Adjuster* const detailw;
|
|
MyComboBoxText* const localedgMethod;
|
|
Adjuster* const tloww;
|
|
Adjuster* const thigw;
|
|
Adjuster* const edgw;
|
|
Adjuster* const basew;
|
|
MyComboBoxText* const localneiMethod;
|
|
Gtk::CheckButton* const wavblur;
|
|
Adjuster* const levelblur;
|
|
Adjuster* const sigmabl;
|
|
Adjuster* const chromablu;
|
|
CurveEditorGroup* const LocalcurveEditorwavlev;
|
|
FlatCurveEditor* const wavshapelev;
|
|
Adjuster* const residblur;
|
|
Gtk::CheckButton* const blurlc;
|
|
MyExpander* const expcontrastpyr2;
|
|
Gtk::CheckButton* const wavcont;
|
|
Adjuster* const sigma;
|
|
Adjuster* const offset;
|
|
Adjuster* const chromalev;
|
|
CurveEditorGroup* const LocalcurveEditorwavcon;
|
|
FlatCurveEditor* const wavshapecon;
|
|
Gtk::CheckButton* const wavcompre;
|
|
CurveEditorGroup* const LocalcurveEditorwavcompre;
|
|
FlatCurveEditor* const wavshapecompre;
|
|
Adjuster* const sigmadr;
|
|
Adjuster* const threswav;
|
|
Adjuster* const residcomp;
|
|
Gtk::CheckButton* const wavcomp;
|
|
Adjuster* const sigmadc;
|
|
Adjuster* const deltad;
|
|
CurveEditorGroup* const LocalcurveEditorwavcomp;
|
|
FlatCurveEditor* const wavshapecomp;
|
|
Adjuster* const fatres;
|
|
Gtk::CheckButton* const fftwlc;
|
|
MyExpander* const expmasklc;
|
|
MyComboBoxText* const showmasklcMethod;
|
|
Gtk::CheckButton* const enalcMask;
|
|
CurveEditorGroup* const masklcCurveEditorG;
|
|
FlatCurveEditor* const CCmasklcshape;
|
|
FlatCurveEditor* const LLmasklcshape;
|
|
FlatCurveEditor* const HHmasklcshape;
|
|
Adjuster* const blendmasklc;
|
|
Adjuster* const radmasklc;
|
|
Adjuster* const chromasklc;
|
|
CurveEditorGroup* const mask2lcCurveEditorG;
|
|
DiagonalCurveEditor* const Lmasklcshape;
|
|
|
|
sigc::connection localcontMethodConn, origlcConn, wavgradlConn, wavedgConn, localedgMethodConn, waveshowConn, localneiMethodConn, wavblurConn, blurlcConn, wavcontConn, wavcompreConn, wavcompConn, fftwlcConn, showmasklcMethodConn, enalcMaskConn;
|
|
|
|
public:
|
|
LocallabContrast();
|
|
~LocallabContrast();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottom, double newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottomLeft, double newTopLeft, double newBottomRight, double newTopRight) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottom, int newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottomLeft, int newTopLeft, int newBottomRight, int newTopRight) override {}; // Not used
|
|
void adjusterChanged2(ThresholdAdjuster* a, int newBottomL, int newTopL, int newBottomR, int newTopR) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void localcontMethodChanged();
|
|
void origlcChanged();
|
|
void wavgradlChanged();
|
|
void wavedgChanged();
|
|
void localedgMethodChanged();
|
|
void waveshowChanged();
|
|
void localneiMethodChanged();
|
|
void wavblurChanged();
|
|
void blurlcChanged();
|
|
void wavcontChanged();
|
|
void wavcompreChanged();
|
|
void wavcompChanged();
|
|
void fftwlcChanged();
|
|
void showmasklcMethodChanged();
|
|
void enalcMaskChanged();
|
|
|
|
void updateContrastGUI1();
|
|
void updateContrastGUI2();
|
|
void updateContrastGUI3();
|
|
};
|
|
|
|
/* ==== LocallabCBDL ==== */
|
|
class LocallabCBDL:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
const std::array<Adjuster*, 6> multiplier;
|
|
Gtk::Frame* const levFrame;
|
|
Adjuster* const chromacbdl;
|
|
Adjuster* const threshold;
|
|
Adjuster* const clarityml;
|
|
Adjuster* const contresid;
|
|
Adjuster* const softradiuscb;
|
|
Adjuster* const sensicb;
|
|
MyExpander* const expmaskcb;
|
|
MyComboBoxText* const showmaskcbMethod;
|
|
Gtk::CheckButton* const enacbMask;
|
|
CurveEditorGroup* const maskcbCurveEditorG;
|
|
FlatCurveEditor* const CCmaskcbshape;
|
|
FlatCurveEditor* const LLmaskcbshape;
|
|
FlatCurveEditor* const HHmaskcbshape;
|
|
Adjuster* const blendmaskcb;
|
|
Adjuster* const radmaskcb;
|
|
Adjuster* const lapmaskcb;
|
|
Adjuster* const chromaskcb;
|
|
Adjuster* const gammaskcb;
|
|
Adjuster* const slomaskcb;
|
|
CurveEditorGroup* const mask2cbCurveEditorG;
|
|
DiagonalCurveEditor* const Lmaskcbshape;
|
|
|
|
sigc::connection showmaskcbMethodConn, enacbMaskConn;
|
|
|
|
Gtk::Button* const lumacontrastMinusButton;
|
|
Gtk::Button* const lumaneutralButton;
|
|
Gtk::Button* const lumacontrastPlusButton;
|
|
|
|
sigc::connection lumacontrastMinusPressedConn, lumaneutralPressedConn, lumacontrastPlusPressedConn;
|
|
|
|
public:
|
|
LocallabCBDL();
|
|
~LocallabCBDL();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void setDefaultExpanderVisibility() override;
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
|
|
void showmaskcbMethodChanged();
|
|
void enacbMaskChanged();
|
|
|
|
void lumacontrastMinusPressed();
|
|
void lumaneutralPressed();
|
|
void lumacontrastPlusPressed();
|
|
};
|
|
|
|
/* ==== LocallabLog ==== */
|
|
class LocallabLog:
|
|
public Gtk::VBox,
|
|
public LocallabTool
|
|
{
|
|
private:
|
|
Gtk::ToggleButton* const autocompute;
|
|
Gtk::Frame* const logPFrame;
|
|
Adjuster* const blackEv;
|
|
Adjuster* const whiteEv;
|
|
Gtk::CheckButton* const fullimage;
|
|
Gtk::CheckButton* const Autogray;
|
|
Adjuster* const sourceGray;
|
|
Adjuster* const targetGray;
|
|
Adjuster* const detail;
|
|
Adjuster* const baselog;
|
|
Adjuster* const sensilog;
|
|
Adjuster* const strlog;
|
|
Adjuster* const anglog;
|
|
|
|
sigc::connection autoconn, fullimageConn, AutograyConn;
|
|
|
|
public:
|
|
LocallabLog();
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
|
|
void updateAutocompute(const float blackev, const float whiteev, const float sourceg, const float targetg);
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
|
|
void autocomputeToggled();
|
|
void fullimageChanged();
|
|
void AutograyChanged();
|
|
|
|
void updateLogGUI();
|
|
};
|
|
|
|
|
|
/* ==== LocallabMask ==== */
|
|
class LocallabMask:
|
|
public Gtk::VBox,
|
|
public LocallabTool,
|
|
public ThresholdAdjusterListener
|
|
{
|
|
private:
|
|
Adjuster* const sensimask;
|
|
Adjuster* const blendmask;
|
|
Adjuster* const blendmaskab;
|
|
Adjuster* const softradiusmask;
|
|
|
|
MyComboBoxText* const showmask_Method;
|
|
Gtk::CheckButton* const enamask;
|
|
CurveEditorGroup* const mask_CurveEditorG;
|
|
FlatCurveEditor* const CCmask_shape;
|
|
FlatCurveEditor* const LLmask_shape;
|
|
FlatCurveEditor* const HHmask_shape;
|
|
Gtk::Frame* const struFrame;
|
|
Adjuster* const strumaskmask;
|
|
Gtk::CheckButton* const toolmask;
|
|
Gtk::Frame* const blurFrame;
|
|
Gtk::CheckButton* const fftmask;
|
|
Adjuster* const contmask;
|
|
Adjuster* const blurmask;
|
|
|
|
Adjuster* const radmask;
|
|
Adjuster* const lapmask;
|
|
Adjuster* const chromask;
|
|
Adjuster* const gammask;
|
|
Adjuster* const slopmask;
|
|
Adjuster* const shadmask;
|
|
CurveEditorGroup* const mask_HCurveEditorG;
|
|
FlatCurveEditor* const HHhmask_shape;
|
|
CurveEditorGroup* const mask2CurveEditorG;
|
|
DiagonalCurveEditor* const Lmask_shape;
|
|
CurveEditorGroup* const mask2CurveEditorGwav;
|
|
FlatCurveEditor* const LLmask_shapewav;
|
|
ThresholdAdjuster* const csThresholdmask;
|
|
Gtk::Frame* const gradFramemask;
|
|
Adjuster* const str_mask;
|
|
Adjuster* const ang_mask;
|
|
|
|
sigc::connection showmask_MethodConn, enamaskConn, toolmaskConn, fftmaskConn;
|
|
|
|
public:
|
|
LocallabMask();
|
|
~LocallabMask();
|
|
|
|
bool isMaskViewActive() override;
|
|
void resetMaskView() override;
|
|
void getMaskView(int &colorMask, int &colorMaskinv, int &expMask, int &expMaskinv, int &shMask, int &shMaskinv, int &vibMask, int &softMask, int &blMask, int &tmMask, int &retiMask, int &sharMask, int &lcMask, int &cbMask, int &maskMask) override;
|
|
|
|
void updateAdviceTooltips(const bool showTooltips) override;
|
|
|
|
void disableListener() override;
|
|
void enableListener() override;
|
|
void read(const rtengine::procparams::ProcParams* pp, const ParamsEdited* pedited = nullptr) override;
|
|
void write(rtengine::procparams::ProcParams* pp, ParamsEdited* pedited = nullptr) override;
|
|
void setDefaults(const rtengine::procparams::ProcParams* defParams, const ParamsEdited* pedited = nullptr) override;
|
|
void adjusterChanged(Adjuster* a, double newval) override;
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottom, double newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, double newBottomLeft, double newTopLeft, double newBottomRight, double newTopRight) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottom, int newTop) override {}; // Not used
|
|
void adjusterChanged(ThresholdAdjuster* a, int newBottomLeft, int newTopLeft, int newBottomRight, int newTopRight) override {}; // Not used
|
|
void adjusterChanged2(ThresholdAdjuster* a, int newBottomL, int newTopL, int newBottomR, int newTopR) override;
|
|
void curveChanged(CurveEditor* ce) override;
|
|
|
|
|
|
private:
|
|
void enabledChanged() override;
|
|
void showmask_MethodChanged();
|
|
void enamaskChanged();
|
|
void toolmaskChanged();
|
|
void convertParamToNormal() override;
|
|
void updateGUIToMode(const modeType new_type) override;
|
|
void fftmaskChanged();
|
|
void updatemaskGUI3();
|
|
void updateMaskBackground(const double normChromar, const double normLumar, const double normHuer) override;
|
|
};
|
|
|
|
|
|
#endif
|