summaryrefslogtreecommitdiff
path: root/ext/mpeg2enc
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
parent1a787a0cb2fb2afa3bd7aa21ffac1465130699c2 (diff)
downloadgstreamer-plugins-bad-5b791c2ce5b905e8a0521732dc9c08f85551520d.tar.gz
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')
-rw-r--r--ext/mpeg2enc/gstmpeg2encoder.cc26
-rw-r--r--ext/mpeg2enc/gstmpeg2encpicturereader.cc32
-rw-r--r--ext/mpeg2enc/gstmpeg2encpicturereader.hh4
3 files changed, 54 insertions, 8 deletions
diff --git a/ext/mpeg2enc/gstmpeg2encoder.cc b/ext/mpeg2enc/gstmpeg2encoder.cc
index 866f63d8d..c8d1b3e0f 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 */
diff --git a/ext/mpeg2enc/gstmpeg2encpicturereader.cc b/ext/mpeg2enc/gstmpeg2encpicturereader.cc
index 9bc59edf7..57f95ccdd 100644
--- a/ext/mpeg2enc/gstmpeg2encpicturereader.cc
+++ b/ext/mpeg2enc/gstmpeg2encpicturereader.cc
@@ -25,6 +25,10 @@
#include <encoderparams.hh>
+#ifdef GST_MJPEGTOOLS_19x
+#include <imageplanes.hh>
+#endif
+
#include "gstmpeg2enc.hh"
#include "gstmpeg2encpicturereader.hh"
@@ -79,9 +83,17 @@ GstMpeg2EncPictureReader::StreamPictureParams (MPEG2EncInVidParams & strm)
*/
bool
-GstMpeg2EncPictureReader::LoadFrame ()
+#ifdef GST_MJPEGTOOLS_19x
+ GstMpeg2EncPictureReader::LoadFrame (ImagePlanes & image)
+#else
+ GstMpeg2EncPictureReader::LoadFrame ()
+#endif
{
- gint i, x, y, n;
+
+#ifndef GST_MJPEGTOOLS_19x
+ gint n;
+#endif
+ gint i, x, y;
guint8 *frame;
GstMpeg2enc *enc;
@@ -100,23 +112,39 @@ GstMpeg2EncPictureReader::LoadFrame ()
}
frame = GST_BUFFER_DATA (enc->buffer);
+#ifndef GST_MJPEGTOOLS_19x
n = frames_read % input_imgs_buf_size;
+#endif
x = encparams.horizontal_size;
y = encparams.vertical_size;
for (i = 0; i < y; i++) {
+#ifdef GST_MJPEGTOOLS_19x
+ memcpy (image.Plane (0) + i * encparams.phy_width, frame, x);
+#else
memcpy (input_imgs_buf[n][0] + i * encparams.phy_width, frame, x);
+#endif
frame += x;
}
+#ifndef GST_MJPEGTOOLS_19x
lum_mean[n] = LumMean (input_imgs_buf[n][0]);
+#endif
x >>= 1;
y >>= 1;
for (i = 0; i < y; i++) {
+#ifdef GST_MJPEGTOOLS_19x
+ memcpy (image.Plane (1) + i * encparams.phy_chrom_width, frame, x);
+#else
memcpy (input_imgs_buf[n][1] + i * encparams.phy_chrom_width, frame, x);
+#endif
frame += x;
}
for (i = 0; i < y; i++) {
+#ifdef GST_MJPEGTOOLS_19x
+ memcpy (image.Plane (2) + i * encparams.phy_chrom_width, frame, x);
+#else
memcpy (input_imgs_buf[n][2] + i * encparams.phy_chrom_width, frame, x);
+#endif
frame += x;
}
gst_buffer_unref (enc->buffer);
diff --git a/ext/mpeg2enc/gstmpeg2encpicturereader.hh b/ext/mpeg2enc/gstmpeg2encpicturereader.hh
index 7f6c9c3c3..89fb58d8e 100644
--- a/ext/mpeg2enc/gstmpeg2encpicturereader.hh
+++ b/ext/mpeg2enc/gstmpeg2encpicturereader.hh
@@ -37,7 +37,11 @@ public:
protected:
/* read a frame */
+#ifdef GST_MJPEGTOOLS_19x
+ bool LoadFrame (ImagePlanes &image);
+#else
bool LoadFrame ();
+#endif
private:
GstElement *element;