From: Carl Hetherington Date: Thu, 11 Aug 2022 20:44:57 +0000 (+0200) Subject: Allow convert_to_xyz() to take any image. X-Git-Url: https://git.carlh.net/gitweb/?a=commitdiff_plain;h=83401fffc9f7bfea8c167ecbeec0949e22d76548;p=dcpomatic.git Allow convert_to_xyz() to take any image. --- diff --git a/src/lib/dcp_video.cc b/src/lib/dcp_video.cc index e49777265..52b9d5a03 100644 --- a/src/lib/dcp_video.cc +++ b/src/lib/dcp_video.cc @@ -114,7 +114,8 @@ DCPVideo::encode_locally () const int const minimum_size = 16384; LOG_DEBUG_ENCODE("Using minimum frame size %1", minimum_size); - auto xyz = _frame->convert_to_xyz(boost::bind(&Log::dcp_log, dcpomatic_log.get(), _1, _2)); + auto frame_image = _frame->image(bind(&PlayerVideo::keep_xyz_or_rgb, _1), VideoRange::FULL, false); + auto xyz = _frame->convert_to_xyz(frame_image, boost::bind(&Log::dcp_log, dcpomatic_log.get(), _1, _2)); int noise_amount = 2; int pixel_skip = 16; while (true) { @@ -139,7 +140,7 @@ DCPVideo::encode_locally () const * convert_to_xyz() again because compress_j2k() corrupts its xyz parameter. */ - xyz = _frame->convert_to_xyz(boost::bind(&Log::dcp_log, dcpomatic_log.get(), _1, _2)); + xyz = _frame->convert_to_xyz(frame_image, boost::bind(&Log::dcp_log, dcpomatic_log.get(), _1, _2)); auto size = xyz->size (); auto pixels = size.width * size.height; dcpomatic::RNG rng(42); diff --git a/src/lib/player_video.cc b/src/lib/player_video.cc index 04aeffc29..385d26aac 100644 --- a/src/lib/player_video.cc +++ b/src/lib/player_video.cc @@ -382,19 +382,18 @@ PlayerVideo::reset_metadata (shared_ptr film, dcp::Size player_video shared_ptr -PlayerVideo::convert_to_xyz(dcp::NoteHandler note) const +PlayerVideo::convert_to_xyz(shared_ptr image, dcp::NoteHandler note) const { - auto frame_image = image(bind(&PlayerVideo::keep_xyz_or_rgb, _1), VideoRange::FULL, false); if (colour_conversion()) { return dcp::rgb_to_xyz ( - frame_image->data()[0], - frame_image->size(), - frame_image->stride()[0], + image->data()[0], + image->size(), + image->stride()[0], colour_conversion().get(), note ); } else { - return make_shared(frame_image->data()[0], frame_image->size(), frame_image->stride()[0]); + return make_shared(image->data()[0], image->size(), image->stride()[0]); } } diff --git a/src/lib/player_video.h b/src/lib/player_video.h index 731c1a695..9c1c064a5 100644 --- a/src/lib/player_video.h +++ b/src/lib/player_video.h @@ -90,7 +90,7 @@ public: bool has_j2k () const; std::shared_ptr j2k () const; - std::shared_ptr convert_to_xyz(dcp::NoteHandler note) const; + std::shared_ptr convert_to_xyz(std::shared_ptr image, dcp::NoteHandler note) const; Eyes eyes () const {