Merge from 'dev'
This commit is contained in:
@@ -32,7 +32,7 @@
|
||||
|
||||
using namespace rtengine::procparams;
|
||||
|
||||
ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favoritePanelSW(nullptr), hasChanged (false), editDataProvider (nullptr)
|
||||
ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favoritePanelSW(nullptr), hasChanged (false), editDataProvider (nullptr), photoLoadedOnce(false)
|
||||
{
|
||||
|
||||
favoritePanel = Gtk::manage (new ToolVBox ());
|
||||
@@ -42,6 +42,7 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
transformPanel = Gtk::manage (new ToolVBox ());
|
||||
rawPanel = Gtk::manage (new ToolVBox ());
|
||||
advancedPanel = Gtk::manage (new ToolVBox ());
|
||||
locallabPanel = Gtk::manage(new ToolVBox());
|
||||
|
||||
coarse = Gtk::manage (new CoarsePanel ());
|
||||
toneCurve = Gtk::manage (new ToneCurve ());
|
||||
@@ -52,50 +53,52 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
epd = Gtk::manage (new EdgePreservingDecompositionUI ());
|
||||
sharpening = Gtk::manage (new Sharpening ());
|
||||
localContrast = Gtk::manage(new LocalContrast());
|
||||
sharpenEdge = Gtk::manage (new SharpenEdge ());
|
||||
sharpenMicro = Gtk::manage (new SharpenMicro ());
|
||||
lcurve = Gtk::manage (new LCurve ());
|
||||
rgbcurves = Gtk::manage (new RGBCurves ());
|
||||
colortoning = Gtk::manage (new ColorToning ());
|
||||
lensgeom = Gtk::manage (new LensGeometry ());
|
||||
lensProf = Gtk::manage (new LensProfilePanel ());
|
||||
distortion = Gtk::manage (new Distortion ());
|
||||
rotate = Gtk::manage (new Rotate ());
|
||||
vibrance = Gtk::manage (new Vibrance ());
|
||||
colorappearance = Gtk::manage (new ColorAppearance ());
|
||||
whitebalance = Gtk::manage (new WhiteBalance ());
|
||||
vignetting = Gtk::manage (new Vignetting ());
|
||||
retinex = Gtk::manage (new Retinex ());
|
||||
gradient = Gtk::manage (new Gradient ());
|
||||
pcvignette = Gtk::manage (new PCVignette ());
|
||||
perspective = Gtk::manage (new PerspCorrection ());
|
||||
cacorrection = Gtk::manage (new CACorrection ());
|
||||
chmixer = Gtk::manage (new ChMixer ());
|
||||
blackwhite = Gtk::manage (new BlackWhite ());
|
||||
resize = Gtk::manage (new Resize ());
|
||||
prsharpening = Gtk::manage (new PrSharpening());
|
||||
crop = Gtk::manage (new Crop ());
|
||||
icm = Gtk::manage (new ICMPanel ());
|
||||
sharpenEdge = Gtk::manage(new SharpenEdge());
|
||||
sharpenMicro = Gtk::manage(new SharpenMicro());
|
||||
lcurve = Gtk::manage(new LCurve());
|
||||
rgbcurves = Gtk::manage(new RGBCurves());
|
||||
colortoning = Gtk::manage(new ColorToning());
|
||||
lensgeom = Gtk::manage(new LensGeometry());
|
||||
lensProf = Gtk::manage(new LensProfilePanel());
|
||||
distortion = Gtk::manage(new Distortion());
|
||||
rotate = Gtk::manage(new Rotate());
|
||||
vibrance = Gtk::manage(new Vibrance());
|
||||
colorappearance = Gtk::manage(new ColorAppearance());
|
||||
whitebalance = Gtk::manage(new WhiteBalance());
|
||||
vignetting = Gtk::manage(new Vignetting());
|
||||
retinex = Gtk::manage(new Retinex());
|
||||
gradient = Gtk::manage(new Gradient());
|
||||
locallab = Gtk::manage(new Locallab());
|
||||
pcvignette = Gtk::manage(new PCVignette());
|
||||
perspective = Gtk::manage(new PerspCorrection());
|
||||
cacorrection = Gtk::manage(new CACorrection());
|
||||
chmixer = Gtk::manage(new ChMixer());
|
||||
blackwhite = Gtk::manage(new BlackWhite());
|
||||
resize = Gtk::manage(new Resize());
|
||||
prsharpening = Gtk::manage(new PrSharpening());
|
||||
crop = Gtk::manage(new Crop());
|
||||
icm = Gtk::manage(new ICMPanel());
|
||||
metadata = Gtk::manage(new MetaDataPanel());
|
||||
wavelet = Gtk::manage (new Wavelet ());
|
||||
dirpyrequalizer = Gtk::manage (new DirPyrEqualizer ());
|
||||
hsvequalizer = Gtk::manage (new HSVEqualizer ());
|
||||
filmSimulation = Gtk::manage (new FilmSimulation ());
|
||||
wavelet = Gtk::manage(new Wavelet());
|
||||
dirpyrequalizer = Gtk::manage(new DirPyrEqualizer());
|
||||
hsvequalizer = Gtk::manage(new HSVEqualizer());
|
||||
filmSimulation = Gtk::manage(new FilmSimulation());
|
||||
softlight = Gtk::manage(new SoftLight());
|
||||
dehaze = Gtk::manage(new Dehaze());
|
||||
sensorbayer = Gtk::manage (new SensorBayer ());
|
||||
sensorxtrans = Gtk::manage (new SensorXTrans ());
|
||||
bayerprocess = Gtk::manage (new BayerProcess ());
|
||||
xtransprocess = Gtk::manage (new XTransProcess ());
|
||||
bayerpreprocess = Gtk::manage (new BayerPreProcess ());
|
||||
preprocess = Gtk::manage (new PreProcess ());
|
||||
darkframe = Gtk::manage (new DarkFrame ());
|
||||
flatfield = Gtk::manage (new FlatField ());
|
||||
rawcacorrection = Gtk::manage (new RAWCACorr ());
|
||||
rawexposure = Gtk::manage (new RAWExposure ());
|
||||
bayerrawexposure = Gtk::manage (new BayerRAWExposure ());
|
||||
xtransrawexposure = Gtk::manage (new XTransRAWExposure ());
|
||||
fattal = Gtk::manage (new FattalToneMapping ());
|
||||
sensorbayer = Gtk::manage(new SensorBayer());
|
||||
sensorxtrans = Gtk::manage(new SensorXTrans());
|
||||
bayerprocess = Gtk::manage(new BayerProcess());
|
||||
xtransprocess = Gtk::manage(new XTransProcess());
|
||||
bayerpreprocess = Gtk::manage(new BayerPreProcess());
|
||||
preprocess = Gtk::manage(new PreProcess());
|
||||
darkframe = Gtk::manage(new DarkFrame());
|
||||
flatfield = Gtk::manage(new FlatField());
|
||||
rawcacorrection = Gtk::manage(new RAWCACorr());
|
||||
rawexposure = Gtk::manage(new RAWExposure());
|
||||
preprocessWB = Gtk::manage (new PreprocessWB ());
|
||||
bayerrawexposure = Gtk::manage(new BayerRAWExposure());
|
||||
xtransrawexposure = Gtk::manage(new XTransRAWExposure());
|
||||
fattal = Gtk::manage(new FattalToneMapping());
|
||||
filmNegative = Gtk::manage (new FilmNegative ());
|
||||
pdSharpening = Gtk::manage (new PdSharpening());
|
||||
// So Demosaic, Line noise filter, Green Equilibration, Ca-Correction (garder le nom de section identique!) and Black-Level will be moved in a "Bayer sensor" tool,
|
||||
@@ -136,6 +139,8 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
addfavoritePanel (detailsPanel, dirpyrequalizer);
|
||||
addfavoritePanel (detailsPanel, dehaze);
|
||||
addfavoritePanel (advancedPanel, wavelet);
|
||||
addfavoritePanel(locallabPanel, locallab);
|
||||
|
||||
addfavoritePanel (transformPanel, crop);
|
||||
addfavoritePanel (transformPanel, resize);
|
||||
addPanel (resize->getPackBox(), prsharpening, 2);
|
||||
@@ -156,6 +161,7 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
addfavoritePanel (sensorxtrans->getPackBox(), xtransprocess, 2);
|
||||
addfavoritePanel (sensorxtrans->getPackBox(), xtransrawexposure, 2);
|
||||
addfavoritePanel (rawPanel, rawexposure);
|
||||
addfavoritePanel (rawPanel, preprocessWB);
|
||||
addfavoritePanel (rawPanel, preprocess);
|
||||
addfavoritePanel (rawPanel, darkframe);
|
||||
addfavoritePanel (rawPanel, flatfield);
|
||||
@@ -173,25 +179,24 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
toolPanels.push_back (coarse);
|
||||
toolPanels.push_back(metadata);
|
||||
|
||||
toolPanelNotebook = new Gtk::Notebook ();
|
||||
toolPanelNotebook->set_name ("ToolPanelNotebook");
|
||||
|
||||
toolPanelNotebook = new Gtk::Notebook();
|
||||
toolPanelNotebook->set_name("ToolPanelNotebook");
|
||||
exposurePanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
detailsPanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
colorPanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
transformPanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
rawPanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
advancedPanelSW = Gtk::manage (new MyScrolledWindow ());
|
||||
locallabPanelSW = Gtk::manage(new MyScrolledWindow());
|
||||
|
||||
// load panel endings
|
||||
for (int i = 0; i < 7; i++) {
|
||||
for (int i = 0; i < 8; i++) {
|
||||
vbPanelEnd[i] = Gtk::manage (new Gtk::VBox ());
|
||||
imgPanelEnd[i] = Gtk::manage (new RTImage ("ornament1.png"));
|
||||
imgPanelEnd[i]->show ();
|
||||
vbPanelEnd[i]->pack_start (*imgPanelEnd[i], Gtk::PACK_SHRINK);
|
||||
imgPanelEnd[i]->show();
|
||||
vbPanelEnd[i]->pack_start(*imgPanelEnd[i], Gtk::PACK_SHRINK);
|
||||
vbPanelEnd[i]->show_all();
|
||||
}
|
||||
|
||||
if(favoriteCount > 0) {
|
||||
favoritePanelSW = Gtk::manage(new MyScrolledWindow());
|
||||
favoritePanelSW->add(*favoritePanel);
|
||||
@@ -216,6 +221,10 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
advancedPanel->pack_start (*Gtk::manage (new Gtk::HSeparator), Gtk::PACK_SHRINK, 0);
|
||||
advancedPanel->pack_start (*vbPanelEnd[6], Gtk::PACK_SHRINK, 0);
|
||||
|
||||
locallabPanelSW->add(*locallabPanel);
|
||||
locallabPanel->pack_start(*Gtk::manage(new Gtk::HSeparator), Gtk::PACK_SHRINK, 0);
|
||||
locallabPanel->pack_start(*vbPanelEnd[7], Gtk::PACK_SHRINK, 4);
|
||||
|
||||
transformPanelSW->add (*transformPanel);
|
||||
transformPanel->pack_start (*Gtk::manage (new Gtk::HSeparator), Gtk::PACK_SHRINK, 0);
|
||||
transformPanel->pack_start (*vbPanelEnd[4], Gtk::PACK_SHRINK, 4);
|
||||
@@ -229,10 +238,11 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
toiD = Gtk::manage (new TextOrIcon ("detail.png", M ("MAIN_TAB_DETAIL"), M ("MAIN_TAB_DETAIL_TOOLTIP")));
|
||||
toiC = Gtk::manage (new TextOrIcon ("color-circles.png", M ("MAIN_TAB_COLOR"), M ("MAIN_TAB_COLOR_TOOLTIP")));
|
||||
toiW = Gtk::manage (new TextOrIcon ("atom.png", M ("MAIN_TAB_ADVANCED"), M ("MAIN_TAB_ADVANCED_TOOLTIP")));
|
||||
toiL = Gtk::manage(new TextOrIcon("hand-open.png", M("MAIN_TAB_LOCALLAB"), M("MAIN_TAB_LOCALLAB_TOOLTIP")));
|
||||
|
||||
toiT = Gtk::manage (new TextOrIcon ("transform.png", M ("MAIN_TAB_TRANSFORM"), M ("MAIN_TAB_TRANSFORM_TOOLTIP")));
|
||||
toiR = Gtk::manage (new TextOrIcon ("bayer.png", M ("MAIN_TAB_RAW"), M ("MAIN_TAB_RAW_TOOLTIP")));
|
||||
toiM = Gtk::manage (new TextOrIcon ("metadata.png", M ("MAIN_TAB_METADATA"), M ("MAIN_TAB_METADATA_TOOLTIP")));
|
||||
|
||||
if (favoritePanelSW) {
|
||||
toolPanelNotebook->append_page (*favoritePanelSW, *toiF);
|
||||
}
|
||||
@@ -240,46 +250,78 @@ ToolPanelCoordinator::ToolPanelCoordinator (bool batch) : ipc (nullptr), favorit
|
||||
toolPanelNotebook->append_page (*detailsPanelSW, *toiD);
|
||||
toolPanelNotebook->append_page (*colorPanelSW, *toiC);
|
||||
toolPanelNotebook->append_page (*advancedPanelSW, *toiW);
|
||||
|
||||
// Locallab notebook is hidden in batch mode
|
||||
if (!batch) {
|
||||
toolPanelNotebook->append_page(*locallabPanelSW, *toiL);
|
||||
}
|
||||
|
||||
toolPanelNotebook->append_page (*transformPanelSW, *toiT);
|
||||
toolPanelNotebook->append_page (*rawPanelSW, *toiR);
|
||||
toolPanelNotebook->append_page (*metadata, *toiM);
|
||||
|
||||
toolPanelNotebook->set_current_page (0);
|
||||
toolPanelNotebook->set_scrollable();
|
||||
toolPanelNotebook->show_all();
|
||||
|
||||
toolPanelNotebook->set_scrollable ();
|
||||
toolPanelNotebook->show_all ();
|
||||
notebookconn = toolPanelNotebook->signal_switch_page().connect(
|
||||
sigc::mem_fun(*this, &ToolPanelCoordinator::notebookPageChanged));
|
||||
|
||||
for (auto toolPanel : toolPanels) {
|
||||
toolPanel->setListener (this);
|
||||
// In batch mode, notebookPageChanged method is blocked because it's useless to display spots
|
||||
if (batch) {
|
||||
notebookconn.block(true);
|
||||
}
|
||||
|
||||
whitebalance->setWBProvider (this);
|
||||
whitebalance->setSpotWBListener (this);
|
||||
darkframe->setDFProvider (this);
|
||||
flatfield->setFFProvider (this);
|
||||
lensgeom->setLensGeomListener (this);
|
||||
rotate->setLensGeomListener (this);
|
||||
perspective->setLensGeomListener (this);
|
||||
distortion->setLensGeomListener (this);
|
||||
crop->setCropPanelListener (this);
|
||||
icm->setICMPanelListener (this);
|
||||
for (auto toolPanel : toolPanels) {
|
||||
toolPanel->setListener(this);
|
||||
}
|
||||
|
||||
whitebalance->setWBProvider(this);
|
||||
whitebalance->setSpotWBListener(this);
|
||||
darkframe->setDFProvider(this);
|
||||
flatfield->setFFProvider(this);
|
||||
lensgeom->setLensGeomListener(this);
|
||||
rotate->setLensGeomListener(this);
|
||||
perspective->setLensGeomListener(this);
|
||||
distortion->setLensGeomListener(this);
|
||||
crop->setCropPanelListener(this);
|
||||
icm->setICMPanelListener(this);
|
||||
filmNegative->setFilmNegProvider (this);
|
||||
|
||||
toolBar = new ToolBar ();
|
||||
toolBar->setToolBarListener (this);
|
||||
toolBar = new ToolBar();
|
||||
toolBar->setToolBarListener(this);
|
||||
|
||||
prevPage = toolPanelNotebook->get_nth_page(0);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::addPanel (Gtk::Box* where, FoldableToolPanel* panel, int level)
|
||||
void ToolPanelCoordinator::notebookPageChanged(Gtk::Widget* page, guint page_num)
|
||||
{
|
||||
// Locallab spot curves are set visible if at least one photo has been loaded (to avoid
|
||||
// segfault) and locallab panel is active
|
||||
if (photoLoadedOnce) {
|
||||
if (page == locallabPanelSW) {
|
||||
toolBar->blockEditDeactivation(); // Avoid edit tool deactivation when Locallab page is active (except if pressing other tools button)
|
||||
locallab->subscribe();
|
||||
}
|
||||
|
||||
if (prevPage == locallabPanelSW) { // To deactivate Locallab only when switching from Locallab page
|
||||
toolBar->blockEditDeactivation(false);
|
||||
locallab->unsubscribe();
|
||||
}
|
||||
|
||||
prevPage = page;
|
||||
}
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::addPanel(Gtk::Box* where, FoldableToolPanel* panel, int level)
|
||||
{
|
||||
|
||||
panel->setParent (where);
|
||||
panel->setLevel (level);
|
||||
panel->setParent(where);
|
||||
panel->setLevel(level);
|
||||
|
||||
expList.push_back (panel->getExpander());
|
||||
where->pack_start (*panel->getExpander(), false, false);
|
||||
toolPanels.push_back (panel);
|
||||
expList.push_back(panel->getExpander());
|
||||
where->pack_start(*panel->getExpander(), false, false);
|
||||
toolPanels.push_back(panel);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::addfavoritePanel (Gtk::Box* where, FoldableToolPanel* panel, int level)
|
||||
{
|
||||
auto name = panel->getToolName();
|
||||
@@ -296,13 +338,17 @@ ToolPanelCoordinator::~ToolPanelCoordinator ()
|
||||
{
|
||||
idle_register.destroy();
|
||||
|
||||
closeImage ();
|
||||
closeImage();
|
||||
|
||||
// When deleting toolPanelNotebook, pages removal activates notebookPageChanged function
|
||||
// which is responsible of segfault if listener isn't deactivated before
|
||||
notebookconn.block(true);
|
||||
|
||||
delete toolPanelNotebook;
|
||||
delete toolBar;
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXtrans, bool isMono)
|
||||
void ToolPanelCoordinator::imageTypeChanged(bool isRaw, bool isBayer, bool isXtrans, bool isMono)
|
||||
{
|
||||
if (isRaw) {
|
||||
if (isBayer) {
|
||||
@@ -325,8 +371,7 @@ void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXt
|
||||
return false;
|
||||
}
|
||||
);
|
||||
}
|
||||
else if (isXtrans) {
|
||||
} else if (isXtrans) {
|
||||
idle_register.add(
|
||||
[this]() -> bool
|
||||
{
|
||||
@@ -346,8 +391,7 @@ void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXt
|
||||
return false;
|
||||
}
|
||||
);
|
||||
}
|
||||
else if (isMono) {
|
||||
} else if (isMono) {
|
||||
idle_register.add(
|
||||
[this]() -> bool
|
||||
{
|
||||
@@ -359,6 +403,7 @@ void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXt
|
||||
sensorxtrans->FoldableToolPanel::hide();
|
||||
xtransprocess->FoldableToolPanel::hide();
|
||||
xtransrawexposure->FoldableToolPanel::hide();
|
||||
preprocessWB->FoldableToolPanel::hide();
|
||||
preprocess->FoldableToolPanel::hide();
|
||||
flatfield->FoldableToolPanel::show();
|
||||
filmNegative->FoldableToolPanel::hide();
|
||||
@@ -379,6 +424,7 @@ void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXt
|
||||
sensorxtrans->FoldableToolPanel::hide();
|
||||
xtransprocess->FoldableToolPanel::hide();
|
||||
xtransrawexposure->FoldableToolPanel::hide();
|
||||
preprocessWB->FoldableToolPanel::hide();
|
||||
preprocess->FoldableToolPanel::hide();
|
||||
flatfield->FoldableToolPanel::hide();
|
||||
filmNegative->FoldableToolPanel::hide();
|
||||
@@ -400,6 +446,7 @@ void ToolPanelCoordinator::imageTypeChanged (bool isRaw, bool isBayer, bool isXt
|
||||
sensorxtrans->FoldableToolPanel::hide();
|
||||
xtransprocess->FoldableToolPanel::hide();
|
||||
xtransrawexposure->FoldableToolPanel::hide();
|
||||
preprocessWB->FoldableToolPanel::hide();
|
||||
preprocess->FoldableToolPanel::hide();
|
||||
flatfield->FoldableToolPanel::hide();
|
||||
filmNegative->FoldableToolPanel::hide();
|
||||
@@ -421,18 +468,18 @@ void ToolPanelCoordinator::panelChanged(const rtengine::ProcEvent& event, const
|
||||
|
||||
int changeFlags = rtengine::RefreshMapper::getInstance()->getAction(event);
|
||||
|
||||
ProcParams* params = ipc->beginUpdateParams ();
|
||||
ProcParams* params = ipc->beginUpdateParams();
|
||||
|
||||
for (auto toolPanel : toolPanels) {
|
||||
toolPanel->write (params);
|
||||
toolPanel->write(params);
|
||||
}
|
||||
|
||||
// Compensate rotation on flip
|
||||
if (event == rtengine::EvCTHFlip || event == rtengine::EvCTVFlip) {
|
||||
if (fabs (params->rotate.degree) > 0.001) {
|
||||
if (fabs(params->rotate.degree) > 0.001) {
|
||||
params->rotate.degree *= -1;
|
||||
changeFlags |= rtengine::RefreshMapper::getInstance()->getAction(rtengine::EvROTDegree);
|
||||
rotate->read (params);
|
||||
rotate->read(params);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -450,34 +497,78 @@ void ToolPanelCoordinator::panelChanged(const rtengine::ProcEvent& event, const
|
||||
if (event == rtengine::EvPhotoLoaded || event == rtengine::EvProfileChanged || event == rtengine::EvHistoryBrowsed || event == rtengine::EvCTRotate) {
|
||||
// updating the "on preview" geometry
|
||||
int fw, fh;
|
||||
ipc->getInitialImage()->getImageSource()->getFullSize (fw, fh, tr);
|
||||
gradient->updateGeometry (params->gradient.centerX, params->gradient.centerY, params->gradient.feather, params->gradient.degree, fw, fh);
|
||||
ipc->getInitialImage()->getImageSource()->getFullSize(fw, fh, tr);
|
||||
gradient->updateGeometry(params->gradient.centerX, params->gradient.centerY, params->gradient.feather, params->gradient.degree, fw, fh);
|
||||
}
|
||||
|
||||
// some transformations make the crop change for convenience
|
||||
if (event == rtengine::EvCTHFlip) {
|
||||
crop->hFlipCrop ();
|
||||
crop->write (params);
|
||||
crop->hFlipCrop();
|
||||
crop->write(params);
|
||||
} else if (event == rtengine::EvCTVFlip) {
|
||||
crop->vFlipCrop ();
|
||||
crop->write (params);
|
||||
crop->vFlipCrop();
|
||||
crop->write(params);
|
||||
} else if (event == rtengine::EvCTRotate) {
|
||||
crop->rotateCrop (params->coarse.rotate, params->coarse.hflip, params->coarse.vflip);
|
||||
crop->write (params);
|
||||
resize->update (params->crop.enabled, params->crop.w, params->crop.h, ipc->getFullWidth(), ipc->getFullHeight());
|
||||
resize->write (params);
|
||||
crop->rotateCrop(params->coarse.rotate, params->coarse.hflip, params->coarse.vflip);
|
||||
crop->write(params);
|
||||
resize->update(params->crop.enabled, params->crop.w, params->crop.h, ipc->getFullWidth(), ipc->getFullHeight());
|
||||
resize->write(params);
|
||||
} else if (event == rtengine::EvCrop) {
|
||||
resize->update (params->crop.enabled, params->crop.w, params->crop.h);
|
||||
resize->write (params);
|
||||
resize->update(params->crop.enabled, params->crop.w, params->crop.h);
|
||||
resize->write(params);
|
||||
}
|
||||
|
||||
ipc->endUpdateParams (changeFlags); // starts the IPC processing
|
||||
/*
|
||||
* Manage Locallab mask visibility:
|
||||
* - Mask preview is updated when choosing a mask preview method
|
||||
* - Mask preview is also updated when modifying (to avoid hiding a potentially visible mask combobox):
|
||||
* - Color&Light invers
|
||||
* - Exposure inversex
|
||||
* - Shadow Highlight inverssh
|
||||
* - Soft Light softMethod
|
||||
* - Mask preview is stopped when creating, deleting or selecting a spot
|
||||
* - Mask preview is also stopped when removing a spot or resetting all mask visibility
|
||||
*/
|
||||
if (event == rtengine::EvlocallabshowmaskMethod) {
|
||||
const Locallab::llMaskVisibility maskStruc = locallab->getMaskVisibility();
|
||||
ipc->setLocallabMaskVisibility(maskStruc.previewDeltaE, maskStruc.colorMask, maskStruc.colorMaskinv, maskStruc.expMask, maskStruc.expMaskinv,
|
||||
maskStruc.SHMask, maskStruc.SHMaskinv, maskStruc.vibMask, maskStruc.softMask,
|
||||
maskStruc.blMask, maskStruc.tmMask, maskStruc.retiMask, maskStruc.sharMask,
|
||||
maskStruc.lcMask, maskStruc.cbMask);
|
||||
} else if (event == rtengine::EvLocallabSpotCreated || event == rtengine::EvLocallabSpotSelectedWithMask ||
|
||||
event == rtengine::EvLocallabSpotDeleted || event == rtengine::Evlocallabshowreset ||
|
||||
event == rtengine::EvlocallabToolRemovedWithRefresh) {
|
||||
locallab->resetMaskVisibility();
|
||||
ipc->setLocallabMaskVisibility(false, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
|
||||
}
|
||||
|
||||
ipc->endUpdateParams(changeFlags); // starts the IPC processing
|
||||
|
||||
hasChanged = true;
|
||||
|
||||
for (auto paramcListener : paramcListeners) {
|
||||
paramcListener->procParamsChanged (params, event, descr);
|
||||
paramcListener->procParamsChanged(params, event, descr);
|
||||
}
|
||||
|
||||
// Locallab spot curves are set visible if at least one photo has been loaded (to avoid
|
||||
// segfault) and locallab panel is active
|
||||
// When a new photo is loaded, Locallab spot curves need to be set visible again
|
||||
const auto func =
|
||||
[this]() -> bool
|
||||
{
|
||||
if (photoLoadedOnce && (toolPanelNotebook->get_nth_page(toolPanelNotebook->get_current_page()) == locallabPanelSW)) {
|
||||
locallab->subscribe();
|
||||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
if (event == rtengine::EvPhotoLoaded) {
|
||||
idle_register.add(func);
|
||||
}
|
||||
|
||||
photoLoadedOnce = true;
|
||||
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::profileChange(
|
||||
@@ -494,7 +585,7 @@ void ToolPanelCoordinator::profileChange(
|
||||
return;
|
||||
}
|
||||
|
||||
ProcParams *params = ipc->beginUpdateParams ();
|
||||
ProcParams *params = ipc->beginUpdateParams();
|
||||
ProcParams *mergedParams = new ProcParams();
|
||||
|
||||
// Copy the current params as default values for the fusion
|
||||
@@ -507,17 +598,17 @@ void ToolPanelCoordinator::profileChange(
|
||||
}
|
||||
|
||||
// And apply the partial profile nparams to mergedParams
|
||||
nparams->applyTo (mergedParams, fromLastSave);
|
||||
nparams->applyTo(mergedParams, fromLastSave);
|
||||
|
||||
// Derive the effective changes, if it's a profile change, to prevent slow RAW rerendering if not necessary
|
||||
bool filterRawRefresh = false;
|
||||
|
||||
if (event != rtengine::EvPhotoLoaded) {
|
||||
ParamsEdited pe (true);
|
||||
std::vector<rtengine::procparams::ProcParams> lParams (2);
|
||||
ParamsEdited pe(true);
|
||||
std::vector<rtengine::procparams::ProcParams> lParams(2);
|
||||
lParams[0] = *params;
|
||||
lParams[1] = *mergedParams;
|
||||
pe.initFrom (lParams);
|
||||
pe.initFrom(lParams);
|
||||
|
||||
filterRawRefresh = pe.raw.isUnchanged() && pe.lensProf.isUnchanged() && pe.retinex.isUnchanged() && pe.filmNegative.isUnchanged() && pe.pdsharpening.isUnchanged();
|
||||
}
|
||||
@@ -536,35 +627,61 @@ void ToolPanelCoordinator::profileChange(
|
||||
}
|
||||
|
||||
// trimming overflowing cropped area
|
||||
ipc->getInitialImage()->getImageSource()->getFullSize (fw, fh, tr);
|
||||
crop->trim (params, fw, fh);
|
||||
ipc->getInitialImage()->getImageSource()->getFullSize(fw, fh, tr);
|
||||
crop->trim(params, fw, fh);
|
||||
|
||||
// updating the GUI with updated values
|
||||
for (auto toolPanel : toolPanels) {
|
||||
toolPanel->read (params);
|
||||
toolPanel->read(params);
|
||||
|
||||
if (event == rtengine::EvPhotoLoaded || event == rtengine::EvProfileChanged) {
|
||||
toolPanel->autoOpenCurve();
|
||||
|
||||
// For Locallab, reset tool expanders visibility only when a photo or profile is loaded
|
||||
locallab->openAllTools();
|
||||
}
|
||||
}
|
||||
|
||||
if (event == rtengine::EvPhotoLoaded || event == rtengine::EvProfileChanged || event == rtengine::EvHistoryBrowsed || event == rtengine::EvCTRotate) {
|
||||
// updating the "on preview" geometry
|
||||
gradient->updateGeometry (params->gradient.centerX, params->gradient.centerY, params->gradient.feather, params->gradient.degree, fw, fh);
|
||||
gradient->updateGeometry(params->gradient.centerX, params->gradient.centerY, params->gradient.feather, params->gradient.degree, fw, fh);
|
||||
}
|
||||
|
||||
// Reset Locallab mask visibility
|
||||
locallab->resetMaskVisibility();
|
||||
ipc->setLocallabMaskVisibility(false, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
|
||||
|
||||
// start the IPC processing
|
||||
if (filterRawRefresh) {
|
||||
ipc->endUpdateParams ( rtengine::RefreshMapper::getInstance()->getAction(event) & ALLNORAW );
|
||||
ipc->endUpdateParams(rtengine::RefreshMapper::getInstance()->getAction(event) & ALLNORAW);
|
||||
} else {
|
||||
ipc->endUpdateParams (event);
|
||||
ipc->endUpdateParams(event);
|
||||
}
|
||||
|
||||
hasChanged = event != rtengine::EvProfileChangeNotification;
|
||||
|
||||
for (auto paramcListener : paramcListeners) {
|
||||
paramcListener->procParamsChanged (params, event, descr);
|
||||
paramcListener->procParamsChanged(params, event, descr);
|
||||
}
|
||||
|
||||
// Locallab spot curves are set visible if at least one photo has been loaded (to avoid
|
||||
// segfault) and locallab panel is active
|
||||
// When a new photo is loaded, Locallab spot curves need to be set visible again
|
||||
const auto func =
|
||||
[this]() -> bool
|
||||
{
|
||||
if (photoLoadedOnce && (toolPanelNotebook->get_nth_page(toolPanelNotebook->get_current_page()) == locallabPanelSW)) {
|
||||
locallab->subscribe();
|
||||
}
|
||||
|
||||
return false;
|
||||
};
|
||||
|
||||
if (event == rtengine::EvPhotoLoaded) {
|
||||
idle_register.add(func);
|
||||
}
|
||||
|
||||
photoLoadedOnce = true;
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::setDefaults(const ProcParams* defparams)
|
||||
@@ -576,60 +693,61 @@ void ToolPanelCoordinator::setDefaults(const ProcParams* defparams)
|
||||
}
|
||||
}
|
||||
|
||||
CropGUIListener* ToolPanelCoordinator::getCropGUIListener ()
|
||||
CropGUIListener* ToolPanelCoordinator::getCropGUIListener()
|
||||
{
|
||||
|
||||
return crop;
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::initImage (rtengine::StagedImageProcessor* ipc_, bool raw)
|
||||
void ToolPanelCoordinator::initImage(rtengine::StagedImageProcessor* ipc_, bool raw)
|
||||
{
|
||||
|
||||
ipc = ipc_;
|
||||
toneCurve->disableListener ();
|
||||
toneCurve->enableAll ();
|
||||
toneCurve->enableListener ();
|
||||
toneCurve->disableListener();
|
||||
toneCurve->enableAll();
|
||||
toneCurve->enableListener();
|
||||
|
||||
if (ipc) {
|
||||
const rtengine::FramesMetaData* pMetaData = ipc->getInitialImage()->getMetaData();
|
||||
metadata->setImageData(pMetaData);
|
||||
|
||||
ipc->setAutoExpListener (toneCurve);
|
||||
ipc->setAutoCamListener (colorappearance);
|
||||
ipc->setAutoBWListener (blackwhite);
|
||||
ipc->setFrameCountListener (bayerprocess);
|
||||
ipc->setAutoExpListener(toneCurve);
|
||||
ipc->setAutoCamListener(colorappearance);
|
||||
ipc->setAutoBWListener(blackwhite);
|
||||
ipc->setFrameCountListener(bayerprocess);
|
||||
ipc->setFlatFieldAutoClipListener (flatfield);
|
||||
ipc->setBayerAutoContrastListener (bayerprocess);
|
||||
ipc->setXtransAutoContrastListener (xtransprocess);
|
||||
ipc->setpdSharpenAutoContrastListener (pdSharpening);
|
||||
ipc->setpdSharpenAutoRadiusListener (pdSharpening);
|
||||
ipc->setAutoWBListener (whitebalance);
|
||||
ipc->setAutoColorTonListener (colortoning);
|
||||
ipc->setAutoChromaListener (dirpyrdenoise);
|
||||
ipc->setWaveletListener (wavelet);
|
||||
ipc->setRetinexListener (retinex);
|
||||
ipc->setSizeListener (crop);
|
||||
ipc->setSizeListener (resize);
|
||||
ipc->setImageTypeListener (this);
|
||||
ipc->setAutoWBListener(whitebalance);
|
||||
ipc->setAutoColorTonListener(colortoning);
|
||||
ipc->setAutoChromaListener(dirpyrdenoise);
|
||||
ipc->setWaveletListener(wavelet);
|
||||
ipc->setRetinexListener(retinex);
|
||||
ipc->setSizeListener(crop);
|
||||
ipc->setSizeListener(resize);
|
||||
ipc->setLocallabListener(locallab);
|
||||
ipc->setImageTypeListener(this);
|
||||
ipc->setFilmNegListener (filmNegative);
|
||||
flatfield->setShortcutPath (Glib::path_get_dirname (ipc->getInitialImage()->getFileName()));
|
||||
flatfield->setShortcutPath(Glib::path_get_dirname(ipc->getInitialImage()->getFileName()));
|
||||
|
||||
icm->setRawMeta (raw, (const rtengine::FramesData*)pMetaData);
|
||||
lensProf->setRawMeta (raw, pMetaData);
|
||||
perspective->setMetadata (pMetaData);
|
||||
icm->setRawMeta(raw, (const rtengine::FramesData*)pMetaData);
|
||||
lensProf->setRawMeta(raw, pMetaData);
|
||||
perspective->setMetadata(pMetaData);
|
||||
}
|
||||
|
||||
|
||||
toneCurve->setRaw (raw);
|
||||
toneCurve->setRaw(raw);
|
||||
hasChanged = true;
|
||||
}
|
||||
|
||||
|
||||
void ToolPanelCoordinator::closeImage ()
|
||||
void ToolPanelCoordinator::closeImage()
|
||||
{
|
||||
|
||||
if (ipc) {
|
||||
ipc->stopProcessing ();
|
||||
ipc->stopProcessing();
|
||||
ipc = nullptr;
|
||||
}
|
||||
}
|
||||
@@ -685,33 +803,40 @@ void ToolPanelCoordinator::updateToolState()
|
||||
}
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::readOptions ()
|
||||
void ToolPanelCoordinator::readOptions()
|
||||
{
|
||||
|
||||
crop->readOptions ();
|
||||
crop->readOptions();
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::writeOptions ()
|
||||
void ToolPanelCoordinator::writeOptions()
|
||||
{
|
||||
|
||||
crop->writeOptions ();
|
||||
crop->writeOptions();
|
||||
|
||||
if (options.autoSaveTpOpen) {
|
||||
writeToolExpandedStatus (options.tpOpen);
|
||||
writeToolExpandedStatus(options.tpOpen);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void ToolPanelCoordinator::writeToolExpandedStatus (std::vector<int> &tpOpen)
|
||||
void ToolPanelCoordinator::writeToolExpandedStatus(std::vector<int> &tpOpen)
|
||||
{
|
||||
tpOpen.clear ();
|
||||
tpOpen.clear();
|
||||
|
||||
for (size_t i = 0; i < expList.size(); i++) {
|
||||
tpOpen.push_back (expList.at (i)->get_expanded ());
|
||||
tpOpen.push_back(expList.at(i)->get_expanded());
|
||||
}
|
||||
|
||||
wavelet->writeOptions (tpOpen);
|
||||
retinex->writeOptions (tpOpen);
|
||||
wavelet->writeOptions(tpOpen);
|
||||
retinex->writeOptions(tpOpen);
|
||||
|
||||
}
|
||||
|
||||
|
||||
void ToolPanelCoordinator::updateShowtooltipVisibility (bool showtooltip)
|
||||
{
|
||||
locallab->updateShowtooltipVisibility(showtooltip);
|
||||
}
|
||||
|
||||
|
||||
@@ -722,15 +847,15 @@ void ToolPanelCoordinator::spotWBselected(int x, int y, Thumbnail* thm)
|
||||
}
|
||||
|
||||
// toolBar->setTool (TOOL_HAND);
|
||||
int rect = whitebalance->getSize ();
|
||||
int rect = whitebalance->getSize();
|
||||
int ww = ipc->getFullWidth();
|
||||
int hh = ipc->getFullHeight();
|
||||
|
||||
if (x - rect > 0 && y - rect > 0 && x + rect < ww && y + rect < hh) {
|
||||
double temp;
|
||||
double green;
|
||||
ipc->getSpotWB (x, y, rect, temp, green);
|
||||
whitebalance->setWB (temp, green);
|
||||
ipc->getSpotWB(x, y, rect, temp, green);
|
||||
whitebalance->setWB(temp, green);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -739,7 +864,8 @@ void ToolPanelCoordinator::sharpMaskSelected(bool sharpMask)
|
||||
if (!ipc) {
|
||||
return;
|
||||
}
|
||||
ipc->beginUpdateParams ();
|
||||
|
||||
ipc->beginUpdateParams();
|
||||
ipc->endUpdateParams (ipc->setSharpMask(sharpMask));
|
||||
}
|
||||
|
||||
@@ -780,7 +906,7 @@ CropGUIListener* ToolPanelCoordinator::startCropEditing(Thumbnail* thm)
|
||||
return crop;
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::autoCropRequested ()
|
||||
void ToolPanelCoordinator::autoCropRequested()
|
||||
{
|
||||
|
||||
if (!ipc) {
|
||||
@@ -788,12 +914,12 @@ void ToolPanelCoordinator::autoCropRequested ()
|
||||
}
|
||||
|
||||
int x1, y1, x2, y2, w, h;
|
||||
ipc->getAutoCrop (crop->getRatio(), x1, y1, w, h);
|
||||
ipc->getAutoCrop(crop->getRatio(), x1, y1, w, h);
|
||||
x2 = x1 + w - 1;
|
||||
y2 = y1 + h - 1;
|
||||
crop->cropInit (x1, y1, w, h);
|
||||
crop->cropResized (x1, y1, x2, y2);
|
||||
crop->cropManipReady ();
|
||||
crop->cropInit(x1, y1, w, h);
|
||||
crop->cropResized(x1, y1, x2, y2);
|
||||
crop->cropManipReady();
|
||||
}
|
||||
|
||||
rtengine::RawImage* ToolPanelCoordinator::getDF()
|
||||
@@ -807,11 +933,11 @@ rtengine::RawImage* ToolPanelCoordinator::getDF()
|
||||
if (imd) {
|
||||
int iso = imd->getISOSpeed();
|
||||
double shutter = imd->getShutterSpeed();
|
||||
std::string maker ( imd->getMake() );
|
||||
std::string model ( imd->getModel() );
|
||||
std::string maker(imd->getMake());
|
||||
std::string model(imd->getModel());
|
||||
time_t timestamp = imd->getDateTimeAsTS();
|
||||
|
||||
return rtengine::dfm.searchDarkFrame ( maker, model, iso, shutter, timestamp);
|
||||
return rtengine::dfm.searchDarkFrame(maker, model, iso, shutter, timestamp);
|
||||
}
|
||||
|
||||
return nullptr;
|
||||
@@ -830,12 +956,12 @@ rtengine::RawImage* ToolPanelCoordinator::getFF()
|
||||
// double shutter = imd->getShutterSpeed(); temporarily removed because unused
|
||||
double aperture = imd->getFNumber();
|
||||
double focallength = imd->getFocalLen();
|
||||
std::string maker ( imd->getMake() );
|
||||
std::string model ( imd->getModel() );
|
||||
std::string lens ( imd->getLens() );
|
||||
std::string maker(imd->getMake());
|
||||
std::string model(imd->getModel());
|
||||
std::string lens(imd->getLens());
|
||||
time_t timestamp = imd->getDateTimeAsTS();
|
||||
|
||||
return rtengine::ffm.searchFlatField ( maker, model, lens, focallength, aperture, timestamp);
|
||||
return rtengine::ffm.searchFlatField(maker, model, lens, focallength, aperture, timestamp);
|
||||
}
|
||||
|
||||
return nullptr;
|
||||
@@ -850,14 +976,14 @@ Glib::ustring ToolPanelCoordinator::GetCurrentImageFilePath()
|
||||
return ipc->getInitialImage()->getFileName();
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::straightenRequested ()
|
||||
void ToolPanelCoordinator::straightenRequested()
|
||||
{
|
||||
|
||||
if (!ipc) {
|
||||
return;
|
||||
}
|
||||
|
||||
toolBar->setTool (TMStraighten);
|
||||
toolBar->setTool(TMStraighten);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::autoPerspRequested (bool corr_pitch, bool corr_yaw, double& rot, double& pitch, double& yaw, const rtengine::ControlLine *lines, size_t line_count)
|
||||
@@ -880,13 +1006,13 @@ void ToolPanelCoordinator::autoPerspRequested (bool corr_pitch, bool corr_yaw, d
|
||||
yaw = res.yaw;
|
||||
}
|
||||
|
||||
double ToolPanelCoordinator::autoDistorRequested ()
|
||||
double ToolPanelCoordinator::autoDistorRequested()
|
||||
{
|
||||
if (!ipc) {
|
||||
return 0.0;
|
||||
}
|
||||
|
||||
return rtengine::ImProcFunctions::getAutoDistor (ipc->getInitialImage()->getFileName(), 400);
|
||||
return rtengine::ImProcFunctions::getAutoDistor(ipc->getInitialImage()->getFileName(), 400);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::updateTransformPreviewRequested(rtengine::ProcEvent event, bool render_perspective)
|
||||
@@ -899,30 +1025,30 @@ void ToolPanelCoordinator::updateTransformPreviewRequested(rtengine::ProcEvent e
|
||||
ipc->endUpdateParams(event);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::spotWBRequested (int size)
|
||||
void ToolPanelCoordinator::spotWBRequested(int size)
|
||||
{
|
||||
|
||||
if (!ipc) {
|
||||
return;
|
||||
}
|
||||
|
||||
toolBar->setTool (TMSpotWB);
|
||||
toolBar->setTool(TMSpotWB);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::cropSelectRequested ()
|
||||
void ToolPanelCoordinator::cropSelectRequested()
|
||||
{
|
||||
|
||||
if (!ipc) {
|
||||
return;
|
||||
}
|
||||
|
||||
toolBar->setTool (TMCropSelect);
|
||||
toolBar->setTool(TMCropSelect);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::saveInputICCReference(const Glib::ustring& fname, bool apply_wb)
|
||||
{
|
||||
if (ipc) {
|
||||
ipc->saveInputICCReference (fname, apply_wb);
|
||||
ipc->saveInputICCReference(fname, apply_wb);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -946,7 +1072,7 @@ void ToolPanelCoordinator::updateCurveBackgroundHistogram(
|
||||
retinex->updateCurveBackgroundHistogram(histToneCurve, histLCurve, histCCurve, histLCAM, histCCAM, histRed, histGreen, histBlue, histLuma, histLRETI);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::foldAllButOne (Gtk::Box* parent, FoldableToolPanel* openedSection)
|
||||
void ToolPanelCoordinator::foldAllButOne(Gtk::Box* parent, FoldableToolPanel* openedSection)
|
||||
{
|
||||
|
||||
for (auto toolPanel : toolPanels) {
|
||||
@@ -956,10 +1082,10 @@ void ToolPanelCoordinator::foldAllButOne (Gtk::Box* parent, FoldableToolPanel* o
|
||||
if (currentTP->getParent() == parent) {
|
||||
// Section in the same tab, we unfold it if it's not the one that has been clicked
|
||||
if (currentTP != openedSection) {
|
||||
currentTP->setExpanded (false);
|
||||
currentTP->setExpanded(false);
|
||||
} else {
|
||||
if (!currentTP->getExpanded()) {
|
||||
currentTP->setExpanded (true);
|
||||
currentTP->setExpanded(true);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -967,7 +1093,7 @@ void ToolPanelCoordinator::foldAllButOne (Gtk::Box* parent, FoldableToolPanel* o
|
||||
}
|
||||
}
|
||||
|
||||
bool ToolPanelCoordinator::handleShortcutKey (GdkEventKey* event)
|
||||
bool ToolPanelCoordinator::handleShortcutKey(GdkEventKey* event)
|
||||
{
|
||||
|
||||
//bool ctrl = event->state & GDK_CONTROL_MASK; temporarily removed because unused
|
||||
@@ -983,31 +1109,35 @@ bool ToolPanelCoordinator::handleShortcutKey (GdkEventKey* event)
|
||||
return true;
|
||||
|
||||
case GDK_KEY_e:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*exposurePanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*exposurePanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_d:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*detailsPanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*detailsPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_c:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*colorPanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*colorPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_t:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*transformPanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*transformPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_r:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*rawPanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*rawPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_a:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*advancedPanelSW));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*advancedPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_o:
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*locallabPanelSW));
|
||||
return true;
|
||||
|
||||
case GDK_KEY_m:
|
||||
toolPanelNotebook->set_current_page (toolPanelNotebook->page_num (*metadata));
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(*metadata));
|
||||
return true;
|
||||
}
|
||||
}
|
||||
@@ -1015,7 +1145,7 @@ bool ToolPanelCoordinator::handleShortcutKey (GdkEventKey* event)
|
||||
return false;
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::updateVScrollbars (bool hide)
|
||||
void ToolPanelCoordinator::updateVScrollbars(bool hide)
|
||||
{
|
||||
GThreadLock lock; // All GUI access from idle_add callbacks or separate thread HAVE to be protected
|
||||
Gtk::PolicyType policy = hide ? Gtk::POLICY_NEVER : Gtk::POLICY_AUTOMATIC;
|
||||
@@ -1028,20 +1158,24 @@ void ToolPanelCoordinator::updateVScrollbars (bool hide)
|
||||
transformPanelSW->set_policy (Gtk::POLICY_AUTOMATIC, policy);
|
||||
rawPanelSW->set_policy (Gtk::POLICY_AUTOMATIC, policy);
|
||||
advancedPanelSW->set_policy (Gtk::POLICY_AUTOMATIC, policy);
|
||||
locallabPanelSW->set_policy(Gtk::POLICY_AUTOMATIC, policy);
|
||||
|
||||
|
||||
for (auto currExp : expList) {
|
||||
currExp->updateVScrollbars (hide);
|
||||
currExp->updateVScrollbars(hide);
|
||||
}
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::updateTPVScrollbar (bool hide)
|
||||
|
||||
void ToolPanelCoordinator::updateTPVScrollbar(bool hide)
|
||||
{
|
||||
updateVScrollbars (hide);
|
||||
updateVScrollbars(hide);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::toolSelected (ToolMode tool)
|
||||
void ToolPanelCoordinator::toolSelected(ToolMode tool)
|
||||
{
|
||||
GThreadLock lock; // All GUI access from idle_add callbacks or separate thread HAVE to be protected
|
||||
notebookconn.block(true); // "signal_switch_page" event is blocked to avoid unsubscribing Locallab (allows a correct behavior when switching to another tool using toolbar)
|
||||
|
||||
auto checkFavorite = [this](FoldableToolPanel* tool) {
|
||||
for (auto fav : favorites) {
|
||||
@@ -1054,18 +1188,23 @@ void ToolPanelCoordinator::toolSelected (ToolMode tool)
|
||||
|
||||
switch (tool) {
|
||||
case TMCropSelect: {
|
||||
toolBar->blockEditDeactivation(false); // To allow deactivating Locallab when switching to another tool using toolbar
|
||||
crop->setExpanded(true);
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(checkFavorite(crop) ? *favoritePanelSW : *transformPanelSW));
|
||||
prevPage = toolPanelNotebook->get_nth_page(toolPanelNotebook->get_current_page()); // Updating prevPage as "signal_switch_page" event
|
||||
break;
|
||||
}
|
||||
|
||||
case TMSpotWB: {
|
||||
toolBar->blockEditDeactivation(false); // To allow deactivating Locallab when switching to another tool using toolbar
|
||||
whitebalance->setExpanded(true);
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(checkFavorite(whitebalance) ? *favoritePanelSW : *colorPanelSW));
|
||||
prevPage = toolPanelNotebook->get_nth_page(toolPanelNotebook->get_current_page()); // Updating prevPage as "signal_switch_page" event
|
||||
break;
|
||||
}
|
||||
|
||||
case TMStraighten: {
|
||||
toolBar->blockEditDeactivation(false); // To allow deactivating Locallab when switching to another tool using toolbar
|
||||
rotate->setExpanded(true);
|
||||
bool isFavorite = checkFavorite(rotate);
|
||||
if (!isFavorite) {
|
||||
@@ -1073,33 +1212,36 @@ void ToolPanelCoordinator::toolSelected (ToolMode tool)
|
||||
lensgeom->setExpanded(true);
|
||||
}
|
||||
toolPanelNotebook->set_current_page(toolPanelNotebook->page_num(isFavorite ? *favoritePanelSW : *transformPanelSW));
|
||||
prevPage = toolPanelNotebook->get_nth_page(toolPanelNotebook->get_current_page()); // Updating prevPage as "signal_switch_page" event
|
||||
break;
|
||||
}
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
notebookconn.block(false);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::editModeSwitchedOff ()
|
||||
void ToolPanelCoordinator::editModeSwitchedOff()
|
||||
{
|
||||
if (editDataProvider) {
|
||||
editDataProvider->switchOffEditMode();
|
||||
}
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::dirSelected (const Glib::ustring& dirname, const Glib::ustring& openfile)
|
||||
void ToolPanelCoordinator::dirSelected(const Glib::ustring& dirname, const Glib::ustring& openfile)
|
||||
{
|
||||
|
||||
flatfield->setShortcutPath (dirname);
|
||||
flatfield->setShortcutPath(dirname);
|
||||
}
|
||||
|
||||
void ToolPanelCoordinator::setEditProvider (EditDataProvider *provider)
|
||||
void ToolPanelCoordinator::setEditProvider(EditDataProvider *provider)
|
||||
{
|
||||
editDataProvider = provider;
|
||||
|
||||
for (size_t i = 0; i < toolPanels.size(); i++) {
|
||||
toolPanels.at (i)->setEditProvider (provider);
|
||||
toolPanels.at(i)->setEditProvider(provider);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user