/* * This file is part of RawTherapee. * * Copyright (c) 2004-2010 Gabor Horvath * * 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 . */ #ifndef _CLIPBOARD_ #define _CLIPBOARD_ #include #include "../rtengine/rtengine.h" #include "../rtengine/procparams.h" #include "paramsedited.h" #include "myflatcurve.h" #include "mydiagonalcurve.h" class Clipboard { bool _hasIPTC; rtengine::procparams::IPTCPairs iptc; rtengine::procparams::PartialProfile partProfile; DiagonalCurveType hasDiagonalCurveDataType; FlatCurveType hasFlatCurveDataType; std::vector diagonalCurve; std::vector flatCurve; public: void setIPTC (const rtengine::procparams::IPTCPairs& iptcc) { iptc = iptcc; _hasIPTC = true; } const rtengine::procparams::IPTCPairs& getIPTC () { return iptc; } bool hasIPTC () { return _hasIPTC; } void setPartialProfile (const rtengine::procparams::PartialProfile& pprofile); const rtengine::procparams::PartialProfile& getPartialProfile () { return partProfile; }; void setProcParams (const rtengine::procparams::ProcParams& pparams); const rtengine::procparams::ProcParams& getProcParams () { return *partProfile.pparams; } const ParamsEdited& getParamsEdited () { return *partProfile.pedited; } bool hasProcParams () { return partProfile.pparams; } bool hasPEdited () { return partProfile.pedited; } void setDiagonalCurveData (std::vector& p, DiagonalCurveType type ) { diagonalCurve = p; hasDiagonalCurveDataType = type; return; } const std::vector & getDiagonalCurveData () { return diagonalCurve; } DiagonalCurveType hasDiagonalCurveData () { return hasDiagonalCurveDataType; } void setFlatCurveData (std::vector& p, FlatCurveType type ) { flatCurve = p; hasFlatCurveDataType = type; return; } const std::vector & getFlatCurveData () { return flatCurve; } FlatCurveType hasFlatCurveData () { return hasFlatCurveDataType; } Clipboard (); ~Clipboard (); }; extern Clipboard clipboard; #endif