2 Copyright (C) 2012 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 #include "video_decoder.h"
28 using boost::shared_ptr;
29 using boost::optional;
31 VideoDecoder::VideoDecoder (shared_ptr<Film> f, DecodeOptions o)
34 , _last_source_time (0)
39 /** Called by subclasses to tell the world that some video data is ready.
40 * We find a subtitle then emit it for listeners.
41 * @param image frame to emit.
42 * @param t Time of the frame within the source, in seconds.
45 VideoDecoder::emit_video (shared_ptr<Image> image, double t)
47 shared_ptr<Subtitle> sub;
48 if (_timed_subtitle && _timed_subtitle->displayed_at (t)) {
49 sub = _timed_subtitle->subtitle ();
52 signal_video (image, false, sub);
53 _last_source_time = t;
56 /** Called by subclasses to repeat the last video frame that we
57 * passed to emit_video(). If emit_video hasn't yet been called,
58 * we will generate a black frame.
61 VideoDecoder::repeat_last_video ()
64 _last_image.reset (new SimpleImage (pixel_format(), native_size(), true));
65 _last_image->make_black ();
68 signal_video (_last_image, true, _last_subtitle);
71 /** Emit our signal to say that some video data is ready.
72 * @param image Video frame.
73 * @param same true if `image' is the same as the last one we emitted.
74 * @param sub Subtitle for this frame, or 0.
77 VideoDecoder::signal_video (shared_ptr<Image> image, bool same, shared_ptr<Subtitle> sub)
79 TIMING ("Decoder emits %1", _video_frame);
80 Video (image, same, sub);
87 /** Set up the current subtitle. This will be put onto frames that
88 * fit within its time specification. s may be 0 to say that there
89 * is no current subtitle.
90 * @param s New current subtitle, or 0.
93 VideoDecoder::emit_subtitle (shared_ptr<TimedSubtitle> s)
97 if (_timed_subtitle) {
98 Position const p = _timed_subtitle->subtitle()->position ();
99 _timed_subtitle->subtitle()->set_position (Position (p.x - _film->crop().left, p.y - _film->crop().top));
103 /** Set which stream of subtitles we should use from our source.
104 * @param s Stream to use.
107 VideoDecoder::set_subtitle_stream (shared_ptr<SubtitleStream> s)
109 _subtitle_stream = s;
113 VideoDecoder::set_progress (Job* j) const
117 if (_film->length()) {
118 j->set_progress (float (_video_frame) / _film->length().get());