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_PLAYER_H
21 #define DCPOMATIC_PLAYER_H
24 #include <boost/shared_ptr.hpp>
25 #include <boost/enable_shared_from_this.hpp>
30 #include "audio_merger.h"
31 #include "audio_content.h"
42 * @brief A class which can `play' a Playlist; emitting its audio and video.
45 class Player : public boost::enable_shared_from_this<Player>, public boost::noncopyable
48 Player (boost::shared_ptr<const Film>, boost::shared_ptr<const Playlist>);
50 void disable_video ();
51 void disable_audio ();
54 void seek (Time, bool);
56 Time video_position () const {
57 return _video_position;
60 void set_video_container_size (libdcp::Size);
62 /** Emitted when a video frame is ready.
63 * First parameter is the video image.
64 * Second parameter is the eye(s) that should see this image.
65 * Third parameter is true if the image is the same as the last one that was emitted.
66 * Fourth parameter is the time.
68 boost::signals2::signal<void (boost::shared_ptr<const Image>, Eyes, bool, Time)> Video;
70 /** Emitted when some audio data is ready */
71 boost::signals2::signal<void (boost::shared_ptr<const AudioBuffers>, Time)> Audio;
73 /** Emitted when something has changed such that if we went back and emitted
74 * the last frame again it would look different. This is not emitted after
77 * The parameter is true if these signals are currently likely to be frequent.
79 boost::signals2::signal<void (bool)> Changed;
82 friend class PlayerWrapper;
84 void process_video (boost::weak_ptr<Piece>, boost::shared_ptr<const Image>, Eyes, bool, VideoContent::Frame);
85 void process_audio (boost::weak_ptr<Piece>, boost::shared_ptr<const AudioBuffers>, AudioContent::Frame);
86 void process_subtitle (boost::weak_ptr<Piece>, boost::shared_ptr<Image>, dcpomatic::Rect<double>, Time, Time);
88 void playlist_changed ();
89 void content_changed (boost::weak_ptr<Content>, int, bool);
90 void do_seek (Time, bool);
93 void emit_silence (OutputAudioFrame);
94 boost::shared_ptr<Resampler> resampler (boost::shared_ptr<AudioContent>, bool);
95 void film_changed (Film::Property);
96 void update_subtitle ();
98 boost::shared_ptr<const Film> _film;
99 boost::shared_ptr<const Playlist> _playlist;
104 /** Our pieces are ready to go; if this is false the pieces must be (re-)created before they are used */
105 bool _have_valid_pieces;
106 std::list<boost::shared_ptr<Piece> > _pieces;
108 /** The time after the last video that we emitted */
109 Time _video_position;
110 /** The time after the last audio that we emitted */
111 Time _audio_position;
113 AudioMerger<Time, AudioContent::Frame> _audio_merger;
115 libdcp::Size _video_container_size;
116 boost::shared_ptr<Image> _black_frame;
117 std::map<boost::shared_ptr<AudioContent>, boost::shared_ptr<Resampler> > _resamplers;
120 boost::weak_ptr<Piece> piece;
121 boost::shared_ptr<Image> image;
122 dcpomatic::Rect<double> rect;
128 boost::shared_ptr<Image> image;
129 Position<int> position;
134 #ifdef DCPOMATIC_DEBUG
135 boost::shared_ptr<Content> _last_video;