added a more flexible way of managing ProcEvents

modifying the global ProcEvent enum and refreshmap array is not needed
anymore. You can now register new events dynamically, using a ProcEventMapper
instance. See rtgui/localcontrast.cc for an example.

Hopefully this solves the problem of recurring merge conflicts when different
devs add different proc events
This commit is contained in:
Alberto Griggio
2017-12-19 13:46:19 +01:00
parent a2bd8acac9
commit c166e0a7ed
12 changed files with 215 additions and 23 deletions

View File

@@ -725,11 +725,11 @@ HISTORY_MSG_490;HDR TM - Amount
HISTORY_MSG_491;White Balance HISTORY_MSG_491;White Balance
HISTORY_MSG_492;RGB Curves HISTORY_MSG_492;RGB Curves
HISTORY_MSG_493;L*a*b* Adjustments HISTORY_MSG_493;L*a*b* Adjustments
HISTORY_MSG_494;Local Contrast HISTORY_MSG_LOCALCONTRAST_ENABLED;Local Contrast
HISTORY_MSG_495;Local Contrast - Radius HISTORY_MSG_LOCALCONTRAST_RADIUS;Local Contrast - Radius
HISTORY_MSG_496;Local Contrast - Amount HISTORY_MSG_LOCALCONTRAST_AMOUNT;Local Contrast - Amount
HISTORY_MSG_497;Local Contrast - Darkness HISTORY_MSG_LOCALCONTRAST_DARKNESS;Local Contrast - Darkness
HISTORY_MSG_498;Local Contrast - Lightness HISTORY_MSG_LOCALCONTRAST_LIGHTNESS;Local Contrast - Lightness
HISTORY_NEWSNAPSHOT;Add HISTORY_NEWSNAPSHOT;Add
HISTORY_NEWSNAPSHOT_TOOLTIP;Shortcut: <b>Alt-s</b> HISTORY_NEWSNAPSHOT_TOOLTIP;Shortcut: <b>Alt-s</b>
HISTORY_SNAPSHOT;Snapshot HISTORY_SNAPSHOT;Snapshot

View File

@@ -1378,7 +1378,8 @@ ProcParams* ImProcCoordinator::beginUpdateParams ()
void ImProcCoordinator::endUpdateParams (ProcEvent change) void ImProcCoordinator::endUpdateParams (ProcEvent change)
{ {
endUpdateParams ( refreshmap[ (int)change] ); int action = RefreshMapper::getInstance()->getAction(change);
endUpdateParams(action);
} }
void ImProcCoordinator::endUpdateParams (int changeFlags) void ImProcCoordinator::endUpdateParams (int changeFlags)

View File

@@ -26,7 +26,7 @@ namespace rtengine
// Aligned so the first entry starts on line 30 // Aligned so the first entry starts on line 30
enum ProcEvent { enum ProcEventCode {
EvPhotoLoaded = 0, EvPhotoLoaded = 0,
EvProfileLoaded = 1, EvProfileLoaded = 1,
EvProfileChanged = 2, EvProfileChanged = 2,
@@ -520,15 +520,31 @@ enum ProcEvent {
EvWBEnabled = 490, EvWBEnabled = 490,
EvRGBEnabled = 491, EvRGBEnabled = 491,
EvLEnabled = 492, EvLEnabled = 492,
EvLocalContrastEnabled = 493,
EvLocalContrastRadius = 494,
EvLocalContrastAmount = 495,
EvLocalContrastDarkness = 496,
EvLocalContrastLightness = 497,
NUMOFEVENTS NUMOFEVENTS
}; };
class ProcEvent {
public:
ProcEvent(): code_(0) {}
ProcEvent(ProcEventCode code): code_(code) {}
explicit ProcEvent(int code): code_(code) {}
operator int() { return code_; }
private:
int code_;
};
inline bool operator==(ProcEvent a, ProcEvent b) { return int(a) == int(b); }
inline bool operator==(ProcEvent a, ProcEventCode b) { return int(a) == int(b); }
inline bool operator==(ProcEventCode a, ProcEvent b) { return int(a) == int(b); }
inline bool operator!=(ProcEvent a, ProcEvent b) { return int(a) != int(b); }
inline bool operator!=(ProcEvent a, ProcEventCode b) { return int(a) != int(b); }
inline bool operator!=(ProcEventCode a, ProcEvent b) { return int(a) != int(b); }
} }
#endif #endif

View File

@@ -519,11 +519,48 @@ int refreshmap[rtengine::NUMOFEVENTS] = {
HDR, // EvTMFattalAmount HDR, // EvTMFattalAmount
ALLNORAW, // EvWBEnabled ALLNORAW, // EvWBEnabled
RGBCURVE, // EvRGBEnabled RGBCURVE, // EvRGBEnabled
LUMINANCECURVE, // EvLEnabled LUMINANCECURVE // EvLEnabled
RGBCURVE, // EvLocalContastEnabled
RGBCURVE, // EvLocalContrastRadius
RGBCURVE, // EvLocalContrastAmount
RGBCURVE, // EvLocalContrastDarkness
RGBCURVE // EvLocalContrastLightness
}; };
namespace rtengine {
RefreshMapper::RefreshMapper():
next_event_(rtengine::NUMOFEVENTS)
{
for (int event = 0; event < rtengine::NUMOFEVENTS; ++event) {
actions_[event] = refreshmap[event];
}
}
ProcEvent RefreshMapper::newEvent()
{
return ProcEvent(++next_event_);
}
void RefreshMapper::mapEvent(ProcEvent event, int action)
{
actions_[event] = action;
}
int RefreshMapper::getAction(ProcEvent event) const
{
auto it = actions_.find(event);
if (it == actions_.end()) {
return 0;
} else {
return it->second;
}
}
RefreshMapper *RefreshMapper::getInstance()
{
static RefreshMapper instance;
return &instance;
}
} // namespace rtengine

View File

@@ -19,6 +19,9 @@
#ifndef __REFRESHMAP__ #ifndef __REFRESHMAP__
#define __REFRESHMAP__ #define __REFRESHMAP__
#include <unordered_map>
#include "procevents.h"
// Use M_VOID if you wish to update the proc params without updating the preview at all ! // Use M_VOID if you wish to update the proc params without updating the preview at all !
#define M_VOID (1<<17) #define M_VOID (1<<17)
// Use M_MINUPDATE if you wish to update the preview without modifying the image (think about it like a "refreshPreview") // Use M_MINUPDATE if you wish to update the preview without modifying the image (think about it like a "refreshPreview")
@@ -74,4 +77,23 @@
#define OUTPUTPROFILE M_MONITOR #define OUTPUTPROFILE M_MONITOR
extern int refreshmap[]; extern int refreshmap[];
namespace rtengine {
class RefreshMapper {
public:
static RefreshMapper *getInstance();
ProcEvent newEvent();
void mapEvent(ProcEvent event, int action);
int getAction(ProcEvent event) const;
private:
RefreshMapper();
int next_event_;
std::unordered_map<int, int> actions_;
};
} // namespace rtengine
#endif #endif

View File

@@ -149,6 +149,7 @@ set(NONCLISOURCEFILES
zoompanel.cc zoompanel.cc
fattaltonemap.cc fattaltonemap.cc
localcontrast.cc localcontrast.cc
eventmapper.cc
) )
include_directories(BEFORE "${CMAKE_CURRENT_BINARY_DIR}") include_directories(BEFORE "${CMAKE_CURRENT_BINARY_DIR}")

63
rtgui/eventmapper.cc Normal file
View File

@@ -0,0 +1,63 @@
/* -*- C++ -*-
*
* This file is part of RawTherapee.
*
* Copyright (c) 2017 Alberto Griggio <alberto.griggio@gmail.com>
*
* 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/>.
*/
#include "eventmapper.h"
ProcEventMapper::ProcEventMapper()
{
for (int event = 0; event < rtengine::NUMOFEVENTS; ++event) {
history_msgs_[event] = "HISTORY_MSG_" + std::to_string(event + 1);
}
}
ProcEventMapper *ProcEventMapper::getInstance()
{
static ProcEventMapper instance;
return &instance;
}
rtengine::ProcEvent ProcEventMapper::newEvent(int action, const std::string &history_msg)
{
rtengine::ProcEvent event = rtengine::RefreshMapper::getInstance()->newEvent();
rtengine::RefreshMapper::getInstance()->mapEvent(event, action);
if (history_msg.empty()) {
history_msgs_[event] = "HISTORY_MSG_" + std::to_string(event + 1);
} else {
history_msgs_[event] = history_msg;
}
return event;
}
const std::string &ProcEventMapper::getHistoryMsg(rtengine::ProcEvent event) const
{
static std::string empty;
auto it = history_msgs_.find(event);
if (it == history_msgs_.end()) {
return empty;
} else {
return it->second;
}
}

37
rtgui/eventmapper.h Normal file
View File

@@ -0,0 +1,37 @@
/* -*- C++ -*-
*
* This file is part of RawTherapee.
*
* Copyright (c) 2017 Alberto Griggio <alberto.griggio@gmail.com>
*
* 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/>.
*/
#pragma once
#include <string>
#include <unordered_map>
#include "../rtengine/refreshmap.h"
class ProcEventMapper {
public:
static ProcEventMapper *getInstance();
rtengine::ProcEvent newEvent(int action, const std::string &history_msg="");
const std::string &getHistoryMsg(rtengine::ProcEvent event) const;
private:
ProcEventMapper();
std::unordered_map<int, std::string> history_msgs_;
};

View File

@@ -20,6 +20,7 @@
#include "multilangmgr.h" #include "multilangmgr.h"
#include "rtimage.h" #include "rtimage.h"
#include "guiutils.h" #include "guiutils.h"
#include "eventmapper.h"
using namespace rtengine; using namespace rtengine;
using namespace rtengine::procparams; using namespace rtengine::procparams;
@@ -231,7 +232,7 @@ void History::procParamsChanged (ProcParams* params, ProcEvent ev, Glib::ustring
} }
// construct formatted list content // construct formatted list content
Glib::ustring text = M("HISTORY_MSG_" + std::to_string(ev + 1)); Glib::ustring text = M(ProcEventMapper::getInstance()->getHistoryMsg(ev));
Glib::RefPtr<Gtk::TreeSelection> selection = hTreeView->get_selection(); Glib::RefPtr<Gtk::TreeSelection> selection = hTreeView->get_selection();
Gtk::TreeModel::iterator iter = selection->get_selected(); Gtk::TreeModel::iterator iter = selection->get_selected();

View File

@@ -18,6 +18,7 @@
* along with RawTherapee. If not, see <http://www.gnu.org/licenses/>. * along with RawTherapee. If not, see <http://www.gnu.org/licenses/>.
*/ */
#include "localcontrast.h" #include "localcontrast.h"
#include "eventmapper.h"
#include <iomanip> #include <iomanip>
#include <cmath> #include <cmath>
@@ -26,6 +27,13 @@ using namespace rtengine::procparams;
LocalContrast::LocalContrast(): FoldableToolPanel(this, "localcontrast", M("TP_LOCALCONTRAST_LABEL"), false, true) LocalContrast::LocalContrast(): FoldableToolPanel(this, "localcontrast", M("TP_LOCALCONTRAST_LABEL"), false, true)
{ {
auto m = ProcEventMapper::getInstance();
EvLocalContrastEnabled = m->newEvent(RGBCURVE, "HISTORY_MSG_LOCALCONTRAST_ENABLED");
EvLocalContrastRadius = m->newEvent(RGBCURVE, "HISTORY_MSG_LOCALCONTRAST_RADIUS");
EvLocalContrastAmount = m->newEvent(RGBCURVE, "HISTORY_MSG_LOCALCONTRAST_AMOUNT");
EvLocalContrastDarkness = m->newEvent(RGBCURVE, "HISTORY_MSG_LOCALCONTRAST_DARKNESS");
EvLocalContrastLightness = m->newEvent(RGBCURVE, "HISTORY_MSG_LOCALCONTRAST_LIGHTNESS");
radius = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_RADIUS"), 3., 200., 1., 8.)); radius = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_RADIUS"), 3., 200., 1., 8.));
amount = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_AMOUNT"), 0., 1., 0.01, 0.2)); amount = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_AMOUNT"), 0., 1., 0.01, 0.2));
darkness = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_DARKNESS"), 0., 4., 0.1, 1.)); darkness = Gtk::manage(new Adjuster(M("TP_LOCALCONTRAST_DARKNESS"), 0., 4., 0.1, 1.));

View File

@@ -25,12 +25,18 @@
class LocalContrast: public ToolParamBlock, public AdjusterListener, public FoldableToolPanel class LocalContrast: public ToolParamBlock, public AdjusterListener, public FoldableToolPanel
{ {
protected: private:
Adjuster *radius; Adjuster *radius;
Adjuster *amount; Adjuster *amount;
Adjuster *darkness; Adjuster *darkness;
Adjuster *lightness; Adjuster *lightness;
rtengine::ProcEvent EvLocalContrastEnabled;
rtengine::ProcEvent EvLocalContrastRadius;
rtengine::ProcEvent EvLocalContrastAmount;
rtengine::ProcEvent EvLocalContrastDarkness;
rtengine::ProcEvent EvLocalContrastLightness;
public: public:
LocalContrast(); LocalContrast();

View File

@@ -315,7 +315,7 @@ void ToolPanelCoordinator::panelChanged (rtengine::ProcEvent event, const Glib::
return; return;
} }
int changeFlags = refreshmap[ (int)event]; int changeFlags = rtengine::RefreshMapper::getInstance()->getAction(event);
ProcParams* params = ipc->beginUpdateParams (); ProcParams* params = ipc->beginUpdateParams ();
@@ -327,7 +327,7 @@ void ToolPanelCoordinator::panelChanged (rtengine::ProcEvent event, const Glib::
if (event == rtengine::EvCTHFlip || event == rtengine::EvCTVFlip) { 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; params->rotate.degree *= -1;
changeFlags |= refreshmap[ (int)rtengine::EvROTDegree]; changeFlags |= rtengine::RefreshMapper::getInstance()->getAction(rtengine::EvROTDegree);
rotate->read (params); rotate->read (params);
} }
} }
@@ -446,7 +446,7 @@ void ToolPanelCoordinator::profileChange (const PartialProfile *nparams, rtengi
// start the IPC processing // start the IPC processing
if (filterRawRefresh) { if (filterRawRefresh) {
ipc->endUpdateParams ( refreshmap[ (int)event] & ALLNORAW ); ipc->endUpdateParams ( rtengine::RefreshMapper::getInstance()->getAction(event) & ALLNORAW );
} else { } else {
ipc->endUpdateParams (event); ipc->endUpdateParams (event);
} }