2 Copyright (C) 2013 Carl Hetherington <cth@carlh.net>
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef DCPOMATIC_COLOUR_CONVERSION_H
21 #define DCPOMATIC_COLOUR_CONVERSION_H
23 #include <boost/utility.hpp>
24 #include <boost/optional.hpp>
25 #include <boost/numeric/ublas/matrix.hpp>
35 class ColourConversion
39 ColourConversion (double, bool, double const matrix[3][3], double);
40 ColourConversion (boost::shared_ptr<cxml::Node>);
42 virtual void as_xml (xmlpp::Node *) const;
44 boost::optional<size_t> preset () const;
47 bool input_gamma_linearised;
48 boost::numeric::ublas::matrix<double> matrix;
52 class PresetColourConversion
55 PresetColourConversion ();
56 PresetColourConversion (std::string, double, bool, double const matrix[3][3], double);
57 PresetColourConversion (boost::shared_ptr<cxml::Node>);
59 void as_xml (xmlpp::Node *) const;
62 ColourConversion conversion;
65 bool operator== (ColourConversion const &, ColourConversion const &);
66 bool operator!= (ColourConversion const &, ColourConversion const &);