summaryrefslogtreecommitdiffstats
path: root/gst/avi
diff options
context:
space:
mode:
authorTim-Philipp Müller <tim@centricular.net>2005-11-15 12:16:00 +0000
committerTim-Philipp Müller <tim@centricular.net>2005-11-15 12:16:00 +0000
commit12aed9b96ef17ce97f4617e8c3db65b98f74d7bd (patch)
treea1d2e259f588bf730863dfe0e959f440d42ff229 /gst/avi
parent6ff59b2f6e36596ee6f347da307de9b61ff92bdd (diff)
gst/avi/gstavidemux.c: Invert DIB images again (see #132341).
Original commit message from CVS: * gst/avi/gstavidemux.c: (swap_line), (gst_avi_demux_invert), (gst_avi_demux_process_next_entry), (gst_avi_demux_stream_data): Invert DIB images again (see #132341).
Diffstat (limited to 'gst/avi')
-rw-r--r--gst/avi/gstavidemux.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/gst/avi/gstavidemux.c b/gst/avi/gstavidemux.c
index 20645432..0ae2fc2b 100644
--- a/gst/avi/gstavidemux.c
+++ b/gst/avi/gstavidemux.c
@@ -2048,6 +2048,37 @@ gst_avi_demux_handle_seek (GstAviDemux * avi, gboolean update)
}
+/*
+ * Invert DIB buffers... Takes existing buffer and
+ * returns either the buffer or a new one (with old
+ * one dereferenced).
+ */
+
+static inline void
+swap_line (guint8 * d1, guint8 * d2, guint8 * tmp, gint bytes)
+{
+ memcpy (tmp, d1, bytes);
+ memcpy (d1, d2, bytes);
+ memcpy (d2, tmp, bytes);
+}
+
+static GstBuffer *
+gst_avi_demux_invert (avi_stream_context * stream, GstBuffer * buf)
+{
+ buf = gst_buffer_make_writable (buf);
+ gint y, h = stream->strf.vids->height, w = stream->strf.vids->width;
+ guint8 *tmp = g_malloc (w);
+
+ for (y = 0; y < h / 2; y++) {
+ swap_line (GST_BUFFER_DATA (buf) + w * y,
+ GST_BUFFER_DATA (buf) + w * (h - 1 - y), tmp, w);
+ }
+
+ g_free (tmp);
+
+ return buf;
+}
+
static GstFlowReturn
gst_avi_demux_process_next_entry (GstAviDemux * avi)
{
@@ -2096,6 +2127,9 @@ gst_avi_demux_process_next_entry (GstAviDemux * avi)
avi->index_offset, entry->size, &buf)) != GST_FLOW_OK)
return res;
else {
+ if (stream->strh->fcc_handler == GST_MAKE_FOURCC ('D', 'I', 'B', ' ')) {
+ buf = gst_avi_demux_invert (stream, buf);
+ }
if (!(entry->flags & GST_RIFF_IF_KEYFRAME))
GST_BUFFER_FLAG_SET (buf, GST_BUFFER_FLAG_DELTA_UNIT);
GST_BUFFER_TIMESTAMP (buf) = entry->ts;
@@ -2175,6 +2209,10 @@ gst_avi_demux_stream_data (GstAviDemux * avi)
} else {
GstClockTime dur_ts;
+ if (stream->strh->fcc_handler == GST_MAKE_FOURCC ('D', 'I', 'B', ' ')) {
+ buf = gst_avi_demux_invert (stream, buf);
+ }
+
GST_BUFFER_TIMESTAMP (buf) = next_ts;
gst_pad_query (stream->pad, GST_QUERY_POSITION, &format, &dur_ts);
GST_BUFFER_DURATION (buf) = dur_ts - next_ts;