update for videofilter changes

This commit is contained in:
Wim Taymans 2011-12-21 23:51:30 +01:00
parent faab614276
commit 050099ce2d
2 changed files with 17 additions and 50 deletions

View file

@ -125,13 +125,12 @@ static void gst_zbar_set_property (GObject * object, guint prop_id,
static void gst_zbar_get_property (GObject * object, guint prop_id, static void gst_zbar_get_property (GObject * object, guint prop_id,
GValue * value, GParamSpec * pspec); GValue * value, GParamSpec * pspec);
static gboolean gst_zbar_set_caps (GstBaseTransform * base, GstCaps * incaps,
GstCaps * outcaps);
static GstFlowReturn gst_zbar_transform_ip (GstBaseTransform * transform,
GstBuffer * buf);
static gboolean gst_zbar_start (GstBaseTransform * base); static gboolean gst_zbar_start (GstBaseTransform * base);
static gboolean gst_zbar_stop (GstBaseTransform * base); static gboolean gst_zbar_stop (GstBaseTransform * base);
static GstFlowReturn gst_zbar_transform_frame_ip (GstVideoFilter * vfilter,
GstVideoFrame * frame);
#define gst_zbar_parent_class parent_class #define gst_zbar_parent_class parent_class
G_DEFINE_TYPE (GstZBar, gst_zbar, GST_TYPE_VIDEO_FILTER); G_DEFINE_TYPE (GstZBar, gst_zbar, GST_TYPE_VIDEO_FILTER);
@ -141,10 +140,12 @@ gst_zbar_class_init (GstZBarClass * g_class)
GObjectClass *gobject_class; GObjectClass *gobject_class;
GstElementClass *gstelement_class; GstElementClass *gstelement_class;
GstBaseTransformClass *trans_class; GstBaseTransformClass *trans_class;
GstVideoFilterClass *vfilter_class;
gobject_class = G_OBJECT_CLASS (g_class); gobject_class = G_OBJECT_CLASS (g_class);
gstelement_class = GST_ELEMENT_CLASS (g_class); gstelement_class = GST_ELEMENT_CLASS (g_class);
trans_class = GST_BASE_TRANSFORM_CLASS (g_class); trans_class = GST_BASE_TRANSFORM_CLASS (g_class);
vfilter_class = GST_VIDEO_FILTER_CLASS (g_class);
gobject_class->set_property = gst_zbar_set_property; gobject_class->set_property = gst_zbar_set_property;
gobject_class->get_property = gst_zbar_get_property; gobject_class->get_property = gst_zbar_get_property;
@ -172,10 +173,11 @@ gst_zbar_class_init (GstZBarClass * g_class)
gst_element_class_add_pad_template (gstelement_class, gst_element_class_add_pad_template (gstelement_class,
gst_static_pad_template_get (&gst_zbar_src_template)); gst_static_pad_template_get (&gst_zbar_src_template));
trans_class->set_caps = GST_DEBUG_FUNCPTR (gst_zbar_set_caps);
trans_class->transform_ip = GST_DEBUG_FUNCPTR (gst_zbar_transform_ip);
trans_class->start = GST_DEBUG_FUNCPTR (gst_zbar_start); trans_class->start = GST_DEBUG_FUNCPTR (gst_zbar_start);
trans_class->stop = GST_DEBUG_FUNCPTR (gst_zbar_stop); trans_class->stop = GST_DEBUG_FUNCPTR (gst_zbar_stop);
vfilter_class->transform_frame_ip =
GST_DEBUG_FUNCPTR (gst_zbar_transform_frame_ip);
} }
static void static void
@ -241,53 +243,26 @@ gst_zbar_get_property (GObject * object, guint prop_id, GValue * value,
} }
} }
static gboolean
gst_zbar_set_caps (GstBaseTransform * base, GstCaps * incaps, GstCaps * outcaps)
{
GstZBar *zbar = GST_ZBAR (base);
GstVideoInfo info;
GST_DEBUG_OBJECT (zbar,
"set_caps: in %" GST_PTR_FORMAT " out %" GST_PTR_FORMAT, incaps, outcaps);
if (!gst_video_info_from_caps (&info, incaps))
goto invalid_caps;
zbar->info = info;
return TRUE;
/* ERRORS */
invalid_caps:
{
GST_ERROR_OBJECT (zbar, "invalid caps received");
return FALSE;
}
}
static GstFlowReturn static GstFlowReturn
gst_zbar_transform_ip (GstBaseTransform * base, GstBuffer * outbuf) gst_zbar_transform_frame_ip (GstVideoFilter * vfilter, GstVideoFrame * frame)
{ {
GstZBar *zbar = GST_ZBAR (base); GstZBar *zbar = GST_ZBAR (vfilter);
gpointer data; gpointer data;
gint stride, height; gint stride, height;
zbar_image_t *image; zbar_image_t *image;
GstVideoFrame frame;
const zbar_symbol_t *symbol; const zbar_symbol_t *symbol;
int n; int n;
if (base->passthrough) if (GST_BASE_TRANSFORM (vfilter)->passthrough)
goto done; goto done;
gst_video_frame_map (&frame, &zbar->info, outbuf, GST_MAP_READ);
image = zbar_image_create (); image = zbar_image_create ();
/* all formats we support start with an 8-bit Y plane. zbar doesn't need /* all formats we support start with an 8-bit Y plane. zbar doesn't need
* to know about the chroma plane(s) */ * to know about the chroma plane(s) */
data = GST_VIDEO_FRAME_COMP_DATA (&frame, 0); data = GST_VIDEO_FRAME_COMP_DATA (frame, 0);
stride = GST_VIDEO_FRAME_COMP_STRIDE (&frame, 0); stride = GST_VIDEO_FRAME_COMP_STRIDE (frame, 0);
height = GST_VIDEO_FRAME_HEIGHT (&frame); height = GST_VIDEO_FRAME_HEIGHT (frame);
zbar_image_set_format (image, GST_MAKE_FOURCC ('Y', '8', '0', '0')); zbar_image_set_format (image, GST_MAKE_FOURCC ('Y', '8', '0', '0'));
zbar_image_set_size (image, stride, height); zbar_image_set_size (image, stride, height);
@ -317,7 +292,7 @@ gst_zbar_transform_ip (GstBaseTransform * base, GstBuffer * outbuf)
/* post a message */ /* post a message */
s = gst_structure_new ("barcode", s = gst_structure_new ("barcode",
"timestamp", G_TYPE_UINT64, GST_BUFFER_TIMESTAMP (outbuf), "timestamp", G_TYPE_UINT64, GST_BUFFER_TIMESTAMP (frame->buffer),
"type", G_TYPE_STRING, zbar_get_symbol_name (typ), "type", G_TYPE_STRING, zbar_get_symbol_name (typ),
"symbol", G_TYPE_STRING, data, "quality", G_TYPE_INT, quality, NULL); "symbol", G_TYPE_STRING, data, "quality", G_TYPE_INT, quality, NULL);
m = gst_message_new_element (GST_OBJECT (zbar), s); m = gst_message_new_element (GST_OBJECT (zbar), s);
@ -327,14 +302,11 @@ gst_zbar_transform_ip (GstBaseTransform * base, GstBuffer * outbuf)
out: out:
/* clean up */ /* clean up */
gst_video_frame_unmap (&frame);
zbar_image_scanner_recycle_image (zbar->scanner, image); zbar_image_scanner_recycle_image (zbar->scanner, image);
zbar_image_destroy (image); zbar_image_destroy (image);
done: done:
return GST_FLOW_OK; return GST_FLOW_OK;
/* ERRORS */
} }
static gboolean static gboolean
@ -342,8 +314,6 @@ gst_zbar_start (GstBaseTransform * base)
{ {
GstZBar *zbar = GST_ZBAR (base); GstZBar *zbar = GST_ZBAR (base);
gst_video_info_init (&zbar->info);
/* start the cache if enabled (e.g. for filtering dupes) */ /* start the cache if enabled (e.g. for filtering dupes) */
zbar_image_scanner_enable_cache (zbar->scanner, zbar->cache); zbar_image_scanner_enable_cache (zbar->scanner, zbar->cache);

View file

@ -21,8 +21,8 @@
#ifndef __GST_VIDEO_ZBAR_H__ #ifndef __GST_VIDEO_ZBAR_H__
#define __GST_VIDEO_ZBAR_H__ #define __GST_VIDEO_ZBAR_H__
#include <gst/video/gstvideofilter.h>
#include <gst/video/video.h> #include <gst/video/video.h>
#include <gst/video/gstvideofilter.h>
#include <zbar.h> #include <zbar.h>
G_BEGIN_DECLS G_BEGIN_DECLS
@ -51,9 +51,6 @@ struct _GstZBar
/*< private >*/ /*< private >*/
GstVideoFilter videofilter; GstVideoFilter videofilter;
/* format */
GstVideoInfo info;
/* properties */ /* properties */
gboolean message; gboolean message;
gboolean cache; gboolean cache;