X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fcombiner.cc;h=ca68ef68afb7d11a9834fd6f0f340226c4507e09;hb=f385ef03e5ea27519a31c0839447735a7fba0602;hp=12ce4a96e289b6c09da748808f28dac6ed629526;hpb=2f7180555f2d8b727bde21613fc2474bb4f7664c;p=dcpomatic.git diff --git a/src/lib/combiner.cc b/src/lib/combiner.cc index 12ce4a96e..ca68ef68a 100644 --- a/src/lib/combiner.cc +++ b/src/lib/combiner.cc @@ -22,8 +22,7 @@ using boost::shared_ptr; -Combiner::Combiner (shared_ptr log) - : VideoProcessor (log) +Combiner::Combiner () { } @@ -33,9 +32,9 @@ Combiner::Combiner (shared_ptr log) * @param image Frame image. */ void -Combiner::process_video (shared_ptr image, bool, shared_ptr) +Combiner::process_video (shared_ptr image, bool, Time) { - _image = image; + _image.reset (new SimpleImage (image)); } /** Process video for the right half of the frame. @@ -43,25 +42,24 @@ Combiner::process_video (shared_ptr image, bool, shared_ptr) * @param sub Subtitle (which will be put onto the whole frame) */ void -Combiner::process_video_b (shared_ptr image, bool, shared_ptr sub) +Combiner::process_video_b (shared_ptr image, bool, Time t) { /* Copy the right half of this image into our _image */ /* XXX: this should probably be in the Image class */ for (int i = 0; i < image->components(); ++i) { int const line_size = image->line_size()[i]; int const half_line_size = line_size / 2; - int const stride = image->stride()[i]; uint8_t* p = _image->data()[i]; uint8_t* q = image->data()[i]; for (int j = 0; j < image->lines (i); ++j) { memcpy (p + half_line_size, q + half_line_size, half_line_size); - p += stride; - q += stride; + p += _image->stride()[i]; + q += image->stride()[i]; } } - Video (_image, false, sub); + Video (_image, false, t); _image.reset (); }