Issue 2134: removed obsolete raw highlight preservation setting from GUI (still left in procparams for backwards compatilibility)
This commit is contained in:
115
rtengine/dcp.h
Normal file
115
rtengine/dcp.h
Normal file
@@ -0,0 +1,115 @@
|
||||
/*
|
||||
* This file is part of RawTherapee.
|
||||
*
|
||||
* Copyright (c) 2012 Oliver Duis <www.oliverduis.de>
|
||||
*
|
||||
* 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/>.
|
||||
*/
|
||||
|
||||
#ifndef _DCP_
|
||||
#define _DCP_
|
||||
|
||||
#include "imagefloat.h"
|
||||
#include "curves.h"
|
||||
#include "colortemp.h"
|
||||
#include "../rtgui/threadutils.h"
|
||||
#include <glibmm.h>
|
||||
#include <map>
|
||||
#include <string>
|
||||
|
||||
namespace rtengine {
|
||||
|
||||
class DCPProfile {
|
||||
struct HSBModify
|
||||
{
|
||||
float fHueShift;
|
||||
float fSatScale;
|
||||
float fValScale;
|
||||
};
|
||||
struct HSDTableInfo
|
||||
{
|
||||
int iHueDivisions, iSatDivisions, iValDivisions;
|
||||
int iHueStep, iValStep, iArrayCount;
|
||||
bool sRGBGamma;
|
||||
struct
|
||||
{
|
||||
float hScale, sScale, vScale;
|
||||
int maxHueIndex0, maxSatIndex0, maxValIndex0;
|
||||
int hueStep, valStep;
|
||||
} pc;
|
||||
};
|
||||
|
||||
double mColorMatrix1[3][3],mColorMatrix2[3][3];
|
||||
bool hasColorMatrix1, hasColorMatrix2, hasForwardMatrix1, hasForwardMatrix2, hasToneCurve, hasBaselineExposureOffset, willInterpolate;
|
||||
double mForwardMatrix1[3][3],mForwardMatrix2[3][3];
|
||||
double temperature1, temperature2;
|
||||
double baselineExposureOffset;
|
||||
HSBModify *aDeltas1,*aDeltas2,*aLookTable;
|
||||
HSDTableInfo DeltaInfo,LookInfo;
|
||||
short iLightSource1,iLightSource2;
|
||||
|
||||
AdobeToneCurve toneCurve;
|
||||
struct {
|
||||
double m2ProPhoto[3][3];
|
||||
double m2Work[3][3];
|
||||
bool alreadyProPhoto;
|
||||
bool useToneCurve;
|
||||
bool applyLookTable;
|
||||
float blScale;
|
||||
} applyState;
|
||||
|
||||
void dngref_XYCoord2Temperature(const double whiteXY[2], double *temp, double *tint) const;
|
||||
void dngref_FindXYZtoCamera(const double whiteXY[2], int preferredIlluminant, double (*xyzToCamera)[3]) const;
|
||||
void dngref_NeutralToXY(double neutral[3], int preferredIlluminant, double XY[2]) const;
|
||||
void MakeXYZCAM(ColorTemp &wb, double pre_mul[3], double camWbMatrix[3][3], int preferredIlluminant, double (*mXYZCAM)[3]) const;
|
||||
const HSBModify* MakeHueSatMap(ColorTemp &wb, int preferredIlluminant, HSBModify **deleteHandle) const;
|
||||
void HSDApply(const HSDTableInfo &ti, const HSBModify *tableBase, float &h, float &s, float &v) const;
|
||||
|
||||
public:
|
||||
DCPProfile(Glib::ustring fname, bool isRTProfile);
|
||||
~DCPProfile();
|
||||
|
||||
bool getHasToneCurve() { return hasToneCurve; }
|
||||
bool getHasLookTable() { return !!aLookTable; }
|
||||
bool getHasHueSatMap() { return !!aDeltas1; }
|
||||
bool getHasBaselineExposureOffset() { return hasBaselineExposureOffset; }
|
||||
void getIlluminants(int &i1, double &temp1, int &i2, double &temp2, bool &willInterpolate_) { i1 = iLightSource1; i2 = iLightSource2; temp1 = temperature1, temp2 = temperature2; willInterpolate_ = willInterpolate; };
|
||||
void Apply(Imagefloat *pImg, int preferredIlluminant, Glib::ustring workingSpace, ColorTemp &wb, double pre_mul[3], double camMatrix[3][3], bool useToneCurve=false, bool applyHueSatMap=true, bool applyLookTable=false) const;
|
||||
void setStep2ApplyState(Glib::ustring workingSpace, bool useToneCurve, bool applyLookTable, bool applyBaselineExposure);
|
||||
void step2ApplyTile(float *r, float *g, float *b, int width, int height, int tileWidth, float exp_scale) const;
|
||||
};
|
||||
|
||||
class DCPStore {
|
||||
MyMutex mtx;
|
||||
|
||||
// these contain standard profiles from RT. keys are all in uppercase, file path is value
|
||||
std::map<Glib::ustring, Glib::ustring> fileStdProfiles;
|
||||
|
||||
// Maps file name to profile as cache
|
||||
std::map<Glib::ustring, DCPProfile*> profileCache;
|
||||
|
||||
public:
|
||||
void init(Glib::ustring rtProfileDir);
|
||||
|
||||
bool isValidDCPFileName(Glib::ustring filename) const;
|
||||
|
||||
DCPProfile* getProfile(Glib::ustring filename, bool isRTProfile=false);
|
||||
DCPProfile* getStdProfile(Glib::ustring camShortName);
|
||||
|
||||
static DCPStore* getInstance();
|
||||
};
|
||||
|
||||
#define dcpStore DCPStore::getInstance()
|
||||
}
|
||||
#endif
|
Reference in New Issue
Block a user