X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fcolour_conversion.h;h=580374623cf9d29f5b2fb4a3c6f10178f3f4270d;hb=79af506328e80ad84cbe0dddaf2e1a21d4df1fe8;hp=dbc6c9d9d970ac11f22e5a7ab4744d8f0e26f5f4;hpb=cf8e0e9e26dbaefab768000ebc1655b34ad11105;p=dcpomatic.git diff --git a/src/lib/colour_conversion.h b/src/lib/colour_conversion.h index dbc6c9d9d..580374623 100644 --- a/src/lib/colour_conversion.h +++ b/src/lib/colour_conversion.h @@ -25,49 +25,54 @@ #undef check #endif +#include #include -#include -#include -#include namespace xmlpp { class Node; } -class ColourConversion +class ColourConversion : public dcp::ColourConversion { public: ColourConversion (); - ColourConversion (double, bool, double const matrix[3][3], double); - ColourConversion (cxml::NodePtr); + ColourConversion (dcp::ColourConversion); + ColourConversion (cxml::NodePtr, int version); virtual void as_xml (xmlpp::Node *) const; std::string identifier () const; boost::optional preset () const; - static boost::optional from_xml (cxml::NodePtr); - - double input_gamma; - bool input_gamma_linearised; - boost::numeric::ublas::matrix matrix; - double output_gamma; + static boost::optional from_xml (cxml::NodePtr, int version); }; class PresetColourConversion { public: PresetColourConversion (); - PresetColourConversion (std::string, double, bool, double const matrix[3][3], double); - PresetColourConversion (cxml::NodePtr); - - void as_xml (xmlpp::Node *) const; + PresetColourConversion (std::string n, std::string i, dcp::ColourConversion); + PresetColourConversion (cxml::NodePtr node, int version); - std::string name; ColourConversion conversion; + std::string name; + /** an internal short (non-internationalised) name for this preset */ + std::string id; + + static std::vector all () { + return _presets; + } + + static PresetColourConversion from_id (std::string id); + + static void setup_colour_conversion_presets (); + +private: + static std::vector _presets; }; bool operator== (ColourConversion const &, ColourConversion const &); bool operator!= (ColourConversion const &, ColourConversion const &); +bool operator== (PresetColourConversion const &, PresetColourConversion const &); #endif