summaryrefslogtreecommitdiffstats
path: root/ext/mpeg2enc/gstmpeg2encoder.cc
diff options
context:
space:
mode:
authorSebastian Dröge <slomo@circular-chaos.org>2008-01-27 07:32:19 +0000
committerSebastian Dröge <slomo@circular-chaos.org>2008-01-27 07:32:19 +0000
commit5b791c2ce5b905e8a0521732dc9c08f85551520d (patch)
tree39d56595dfc1a6e419d75890d09455e6d62a817c /ext/mpeg2enc/gstmpeg2encoder.cc
parent1a787a0cb2fb2afa3bd7aa21ffac1465130699c2 (diff)
downloadgst-plugins-bad-5b791c2ce5b905e8a0521732dc9c08f85551520d.tar.gz
gst-plugins-bad-5b791c2ce5b905e8a0521732dc9c08f85551520d.tar.bz2
gst-plugins-bad-5b791c2ce5b905e8a0521732dc9c08f85551520d.zip
Add support for building against mjpegtools 1.9 while keeping compatiblity with older versions.
Original commit message from CVS: Based on a patch by: Hans de Goede <j dot w dot r dot degoede at hhs dot nl> * configure.ac: * ext/mpeg2enc/gstmpeg2encoder.cc: * ext/mpeg2enc/gstmpeg2encpicturereader.cc: * ext/mpeg2enc/gstmpeg2encpicturereader.hh: Add support for building against mjpegtools 1.9 while keeping compatiblity with older versions.
Diffstat (limited to 'ext/mpeg2enc/gstmpeg2encoder.cc')
-rw-r--r--ext/mpeg2enc/gstmpeg2encoder.cc26
1 files changed, 20 insertions, 6 deletions
diff --git a/ext/mpeg2enc/gstmpeg2encoder.cc b/ext/mpeg2enc/gstmpeg2encoder.cc
index 866f63d8..c8d1b3e0 100644
--- a/ext/mpeg2enc/gstmpeg2encoder.cc
+++ b/ext/mpeg2enc/gstmpeg2encoder.cc
@@ -26,7 +26,11 @@
#include <mpegconsts.h>
#include <quantize.hh>
+#ifdef GST_MJPEGTOOLS_19x
+#include <ontheflyratectl.hh>
+#else
#include <ratectl.hh>
+#endif
#include <seqencoder.hh>
#include <mpeg2coder.hh>
@@ -53,19 +57,18 @@ GstMpeg2Encoder::~GstMpeg2Encoder ()
gst_object_unref (element);
}
-gboolean GstMpeg2Encoder::setup ()
+gboolean
+GstMpeg2Encoder::setup ()
{
- MPEG2EncInVidParams
- strm;
- GstMpeg2enc *
- enc;
+ MPEG2EncInVidParams strm;
+ GstMpeg2enc *enc;
enc = GST_MPEG2ENC (element);
/* I/O */
reader = new GstMpeg2EncPictureReader (element, caps, &parms);
reader->StreamPictureParams (strm);
-#ifdef GST_MJPEGTOOLS_18x
+#if defined(GST_MJPEGTOOLS_18x) && !defined(GST_MJPEGTOOLS_19x)
/* chain thread caters for reading, do not need another thread for this */
options.allow_parallel_read = FALSE;
#endif
@@ -76,11 +79,22 @@ gboolean GstMpeg2Encoder::setup ()
/* encoding internals */
quantizer = new Quantizer (parms);
+#ifdef GST_MJPEGTOOLS_19x
+ pass1ratectl = new OnTheFlyPass1 (parms);
+ pass2ratectl = new OnTheFlyPass2 (parms);
+#else
bitrate_controller = new OnTheFlyRateCtl (parms);
+#endif
+
#ifdef GST_MJPEGTOOLS_18x
/* sequencer */
+# ifdef GST_MJPEGTOOLS_19x
+ seqencoder = new SeqEncoder (parms, *reader, *quantizer,
+ *writer, *pass1ratectl, *pass2ratectl);
+# else
seqencoder = new SeqEncoder (parms, *reader, *quantizer,
*writer, *bitrate_controller);
+# endif
#else
coder = new MPEG2Coder (parms, *writer);
/* sequencer */