From 3a5b068428bcc2080908a01204411038225d3851 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 23 Jun 2017 11:57:50 +0100 Subject: Make xyz_to_xyz into a constructor of OpenJPEGImage where it makes more sense. --- src/openjpeg_image.cc | 26 ++++++++++++++++++++++++++ src/openjpeg_image.h | 3 +++ src/rgb_xyz.cc | 25 ------------------------- src/rgb_xyz.h | 2 -- 4 files changed, 29 insertions(+), 27 deletions(-) (limited to 'src') diff --git a/src/openjpeg_image.cc b/src/openjpeg_image.cc index cf9063a9..31889566 100644 --- a/src/openjpeg_image.cc +++ b/src/openjpeg_image.cc @@ -84,6 +84,32 @@ OpenJPEGImage::OpenJPEGImage (OpenJPEGImage const & other) * @param size Size for the frame in pixels. */ OpenJPEGImage::OpenJPEGImage (Size size) +{ + create (size); +} + +/** @param data_16 XYZ/RGB image data in packed 16:16:16, 48bpp with + * the 2-byte value for each component stored as little-endian. + */ +OpenJPEGImage::OpenJPEGImage (uint8_t const * data_16, dcp::Size size, int stride) +{ + create (size); + + int jn = 0; + for (int y = 0; y < size.height; ++y) { + uint16_t const * p = reinterpret_cast (data_16 + y * stride); + for (int x = 0; x < size.width; ++x) { + /* Truncate 16-bit to 12-bit */ + _opj_image->comps[0].data[jn] = *p++ >> 4; + _opj_image->comps[1].data[jn] = *p++ >> 4; + _opj_image->comps[2].data[jn] = *p++ >> 4; + ++jn; + } + } +} + +void +OpenJPEGImage::create (Size size) { opj_image_cmptparm_t cmptparm[3]; diff --git a/src/openjpeg_image.h b/src/openjpeg_image.h index fa83a8de..002e2a83 100644 --- a/src/openjpeg_image.h +++ b/src/openjpeg_image.h @@ -51,6 +51,7 @@ public: explicit OpenJPEGImage (opj_image_t *); explicit OpenJPEGImage (OpenJPEGImage const & other); explicit OpenJPEGImage (Size); + OpenJPEGImage (uint8_t const * in_16, dcp::Size size, int stride); ~OpenJPEGImage (); int* data (int) const; @@ -67,6 +68,8 @@ public: } private: + void create (Size size); + opj_image_t* _opj_image; ///< opj_image_t that we are managing }; diff --git a/src/rgb_xyz.cc b/src/rgb_xyz.cc index b4307756..d0774e7c 100644 --- a/src/rgb_xyz.cc +++ b/src/rgb_xyz.cc @@ -348,28 +348,3 @@ dcp::rgb_to_xyz ( return xyz; } - - -/** @param xyz_16 XYZ image data in packed 16:16:16, 48bpp, 16X, 16Y, - * 16Z, with the 2-byte value for each X/Y/Z component stored as - * little-endian. - */ -shared_ptr -dcp::xyz_to_xyz (uint8_t const * xyz_16, dcp::Size size, int stride) -{ - shared_ptr xyz_12 (new OpenJPEGImage (size)); - - int jn = 0; - for (int y = 0; y < size.height; ++y) { - uint16_t const * p = reinterpret_cast (xyz_16 + y * stride); - for (int x = 0; x < size.width; ++x) { - /* Truncate 16-bit to 12-bit */ - xyz_12->data(0)[jn] = *p++ >> 4; - xyz_12->data(1)[jn] = *p++ >> 4; - xyz_12->data(2)[jn] = *p++ >> 4; - ++jn; - } - } - - return xyz_12; -} diff --git a/src/rgb_xyz.h b/src/rgb_xyz.h index 907869af..fcd15cfd 100644 --- a/src/rgb_xyz.h +++ b/src/rgb_xyz.h @@ -66,8 +66,6 @@ extern boost::shared_ptr rgb_to_xyz ( boost::optional note = boost::optional () ); -extern boost::shared_ptr xyz_to_xyz (uint8_t const * xyz, dcp::Size size, int stride); - extern void combined_rgb_to_xyz (ColourConversion const & conversion, double* matrix); } -- cgit v1.2.3