2 Copyright (C) 2010 Paul Davis
3 Author: Robin Gareus <robin@gareus.org>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef __ardour_transcode_ffmpeg_h__
21 #define __ardour_transcode_ffmpeg_h__
24 #include "ardour/types.h"
25 #include "system_exec.h"
27 /* TODO: use a namespace here ? */
30 std::string stream_id;
33 typedef std::vector<AudioStream> AudioStreams;
34 typedef std::map<std::string,std::string> FFSettings;
36 /** @class TranscodeFfmpeg
37 * @brief wrapper around ffmpeg and ffprobe command-line utils
39 * This class includes parsers for stdi/o communication with
40 * 'ffmpeg' and 'ffprobe' and provide an abstraction to
41 * transcode video-files and extract aufio tracks and query
44 class TranscodeFfmpeg : public sigc::trackable
45 , public PBD::ScopedConnectionList
49 /** instantiate a new transcoder. If a file-name is given, the file's
50 * attributes (fps, duration, geometry etc) are read.
52 * @param f path to the video-file to probe or use as input for
53 * \ref extract_audio and \ref transcode.
55 TranscodeFfmpeg (std::string f);
56 virtual ~TranscodeFfmpeg ();
57 /** transcode/import a video-file
58 * @param outfile full-path (incl. file-extension)
59 * @param outwidth video-width, \c <0 no scaling)
60 * @param outheight video-height \c <0 use aspect \c \ref outwidth /c / \c aspect-ratio
61 * @param kbitps video bitrate \c 0 calculate to use 0.7 bits per pixel on average
62 * @return \c true if the transcoder process was successfully started.
64 bool transcode (std::string, const int outwidth=0, const int outheight=0, const int kbitps =0);
65 /** Extract an audio track from the given input file to a new 32bit float little-endian PCM WAV file.
66 * @param outfile full-path (incl. file-extension) to .wav file to write
67 * @param samplerate target samplerate
68 * @param stream Stream-ID of the audio-track to extract
69 * specified as element-number in \ref get_audio().
70 * @return \c true if the transcoder process was successfully started.
72 bool extract_audio (std::string outfile, ARDOUR::framecnt_t samplerate, unsigned int stream=0);
73 /** transcode video and mux audio files into a new video-file.
74 * @param outfile full-path of output file to create (existing files are overwritten)
75 * @param inf_a filename of input audio-file
76 * @param inf_v filename of input video-file
77 * @param ffs additional command-line parameters for 'ffmpeg'. key/value pairs
78 * eg ffs["-vcodec"] = "mpeg4"
79 * @param meta additional meta-data results in -metadata "<key>"="<value>" command-line
81 * @param map if set to \c true stream mapping from input streams to output streams is set to use
82 * only the first available stream from the audio & video file (-map 0.0 -map 1.0).
83 * @return \c true if the encoder process was successfully started.
85 bool encode (std::string outfile, std::string inf_a, std::string inf_v, FFSettings ffs, FFSettings meta, bool map = true);
86 /** @return array with default encoder settings */
87 FFSettings default_encoder_settings ();
88 /** @return array with default meta data */
89 FFSettings default_meta_data ();
90 /** abort any running transcoding process */
93 * @return \c true if the input file was parsed correctly on class creation. */
94 bool probe_ok () { return probeok; }
95 /** @return \c true if the ffmpeg/ffparse executables are avail on this system */
96 bool ffexec_ok () { return ffexecok; }
98 /** signal emitted when ffmpeg reports progress updates
99 * during \ref encode \ref transcode and \ref extract_audio
100 * The parameters are current and last video-frame.
102 PBD::Signal2<void, ARDOUR::framecnt_t, ARDOUR::framecnt_t> Progress;
103 /** signal emitted when the transcoder process terminates. */
104 PBD::Signal0<void> Finished;
106 double get_fps () { return m_fps; }
107 double get_aspect () { return m_aspect; }
108 int get_width() { return m_width; }
109 int get_height() { return m_height; }
110 ARDOUR::framecnt_t get_duration() { return m_duration; }
111 std::string get_codec() { return m_codec; }
113 AudioStreams get_audio() { return m_audio; }
115 /** override file duration used with the \ref Progress signal.
116 * @param d duration in video-frames = length_in_seconds * get_fps()
118 void set_duration(ARDOUR::framecnt_t d) { m_duration = d; }
120 /* offset, lead-in/out are in seconds */
121 void set_avoffset(double av_offset) { m_avoffset = av_offset; }
122 void set_leadinout(double lead_in, double lead_out) { m_lead_in = lead_in; m_lead_out = lead_out; }
125 #if 1 /* tentative debug mode */
126 void set_debug (bool onoff) { debug_enable = onoff; }
136 ARDOUR::framecnt_t m_duration;
148 AudioStreams m_audio;
150 char *format_metadata (std::string, std::string);
151 void ffmpegparse_v (std::string d, size_t s);
152 void ffmpegparse_a (std::string d, size_t s);
153 void ffprobeparse (std::string d, size_t s);
155 std::string ffoutput;
157 std::string ffmpeg_exe;
158 std::string ffprobe_exe;
159 #if 1 /* tentative debug mode */
164 #endif /* __ardour_transcode_ffmpeg_h__ */