summaryrefslogtreecommitdiffstats
path: root/ext/mpeg2enc/gstmpeg2encpicturereader.cc
diff options
context:
space:
mode:
authorRonald S. Bultje <rbultje@ronald.bitfreak.net>2003-12-11 21:07:25 +0000
committerRonald S. Bultje <rbultje@ronald.bitfreak.net>2003-12-11 21:07:25 +0000
commitaa9969dbcfca36106b6c9a37554221ecd621afd0 (patch)
treef33bca1153cf671732c60d901be37d55371c6cae /ext/mpeg2enc/gstmpeg2encpicturereader.cc
parent1c1767f82e5291dc0e49bb3283addde24184fcb4 (diff)
downloadgst-plugins-bad-aa9969dbcfca36106b6c9a37554221ecd621afd0.tar.gz
gst-plugins-bad-aa9969dbcfca36106b6c9a37554221ecd621afd0.tar.bz2
gst-plugins-bad-aa9969dbcfca36106b6c9a37554221ecd621afd0.zip
This is a first attempt at a wrapper for the lib'ified mpeg2enc of mjpegtools. Currently, there's a few release candi...
Original commit message from CVS: This is a first attempt at a wrapper for the lib'ified mpeg2enc of mjpegtools. Currently, there's a few release candidates for mjpegtools-1.6.2 available, but no stable version yet. I've made 4 small subclasses to wrap input, output, options and generic encoding model. The last .cc file is the GStreamer plugin element. Note that it doesn't actually work yet, I'm doing something wrong with header parsing and Andrew asked me to commit so he could help debugging that. Apart from that, we should soon be able to make top-quality MPEG encodes! :). mpeg2enc licensing is tricky, btw, I don't even want to start discussing that...
Diffstat (limited to 'ext/mpeg2enc/gstmpeg2encpicturereader.cc')
-rw-r--r--ext/mpeg2enc/gstmpeg2encpicturereader.cc129
1 files changed, 129 insertions, 0 deletions
diff --git a/ext/mpeg2enc/gstmpeg2encpicturereader.cc b/ext/mpeg2enc/gstmpeg2encpicturereader.cc
new file mode 100644
index 00000000..226acc8d
--- /dev/null
+++ b/ext/mpeg2enc/gstmpeg2encpicturereader.cc
@@ -0,0 +1,129 @@
+/* GStreamer mpeg2enc (mjpegtools) wrapper
+ * (c) 2003 Ronald Bultje <rbultje@ronald.bitfreak.net>
+ *
+ * gstmpeg2encpicturereader.cc: GStreamer/mpeg2enc input wrapper
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <encoderparams.hh>
+
+#include "gstmpeg2encpicturereader.hh"
+
+/*
+ * Class init stuff.
+ */
+
+GstMpeg2EncPictureReader::GstMpeg2EncPictureReader (GstPad *in_pad,
+ GstCaps *in_caps,
+ EncoderParams *params) :
+ PictureReader (*params)
+{
+ pad = in_pad;
+ caps = gst_caps_copy (in_caps);
+}
+
+GstMpeg2EncPictureReader::~GstMpeg2EncPictureReader ()
+{
+ gst_caps_unref (caps);
+}
+
+/*
+ * Get input picture parameters (width/height etc.).
+ */
+
+void
+GstMpeg2EncPictureReader::StreamPictureParams (MPEG2EncInVidParams &strm)
+{
+ gint width, height;
+ gfloat fps;
+
+ gst_caps_get (caps, "width", &width,
+ "height", &height,
+ "framerate", &fps, NULL);
+
+ strm.horizontal_size = width;
+ strm.vertical_size = height;
+ strm.frame_rate_code = mpeg_framerate_code (mpeg_conform_framerate (fps));
+ strm.interlacing_code = Y4M_ILACE_NONE;
+ strm.aspect_ratio_code = mpeg_guess_mpeg_aspect_code (2, y4m_sar_SQUARE,
+ strm.horizontal_size,
+ strm.vertical_size);
+
+ /* FIXME:
+ * strm.interlacing_code = y4m_si_get_interlace(&si);
+ * sar = y4m_si_get_sampleaspect(&si);
+ * strm.aspect_ratio_code =
+ * mpeg_guess_mpeg_aspect_code(2, sar,
+ * strm.horizontal_size,
+ * strm.vertical_size);
+ */
+}
+
+/*
+ * Read a frame.
+ */
+
+bool
+GstMpeg2EncPictureReader::LoadFrame ()
+{
+ GstData *data;
+ GstBuffer *buf = NULL;
+ gint i, x, y, n;
+ guint8 *frame;
+
+ do {
+ if (!(data = gst_pad_pull (pad))) {
+ return true;
+ } else if (GST_IS_EVENT (data)) {
+ if (GST_EVENT_TYPE (data) == GST_EVENT_EOS) {
+ gst_pad_event_default (pad, GST_EVENT (data));
+ return true;
+ }
+ gst_pad_event_default (pad, GST_EVENT (data));
+ } else {
+ buf = GST_BUFFER (data);
+ }
+ } while (!buf);
+
+ frame = GST_BUFFER_DATA (buf);
+ n = frames_read % input_imgs_buf_size;
+ x = encparams.horizontal_size;
+ y = encparams.vertical_size;
+
+ for (i = 0; i < y; i++) {
+ memcpy (input_imgs_buf[n][0]+i*encparams.phy_width, frame, x);
+ frame += x;
+ }
+ lum_mean[n] = LumMean (input_imgs_buf[n][0]);
+ x >>= 1;
+ y >>= 1;
+ for (i = 0; i < y; i++) {
+ memcpy (input_imgs_buf[n][1]+i*encparams.phy_chrom_width, frame, x);
+ frame += x;
+ }
+ for (i = 0; i < y; i++) {
+ memcpy (input_imgs_buf[n][2]+i*encparams.phy_chrom_width, frame, x);
+ frame += x;
+ }
+ gst_buffer_unref (buf);
+
+ return false;
+}