summaryrefslogtreecommitdiff
path: root/ext/opencv
diff options
context:
space:
mode:
authorNicolas Dufresne <nicolas.dufresne@collabora.com>2016-12-01 21:43:04 -0500
committerNicolas Dufresne <nicolas.dufresne@collabora.com>2016-12-01 21:56:09 -0500
commit50e0165ea89a7292977edbc651c05947d2afa23e (patch)
tree8aee01f94706b24ea4077cc92fc61bc3a1a892bd /ext/opencv
parent02b20f6158a859bed3aec066d740333c3e868585 (diff)
downloadgstreamer-plugins-bad-50e0165ea89a7292977edbc651c05947d2afa23e.tar.gz
cvlaplace: Remove redundant CAPS event handler
There is already a cv_set_caps() implemented, so just do the entire work there. https://bugzilla.gnome.org/show_bug.cgi?id=775377
Diffstat (limited to 'ext/opencv')
-rw-r--r--ext/opencv/gstcvlaplace.cpp61
1 files changed, 8 insertions, 53 deletions
diff --git a/ext/opencv/gstcvlaplace.cpp b/ext/opencv/gstcvlaplace.cpp
index c8293bdf0..865a965d6 100644
--- a/ext/opencv/gstcvlaplace.cpp
+++ b/ext/opencv/gstcvlaplace.cpp
@@ -103,9 +103,6 @@ static void gst_cv_laplace_set_property (GObject * object, guint prop_id,
static void gst_cv_laplace_get_property (GObject * object, guint prop_id,
GValue * value, GParamSpec * pspec);
-static gboolean gst_cv_laplace_handle_sink_event (GstPad * pad,
- GstObject * parent, GstEvent * event);
-
static GstFlowReturn gst_cv_laplace_transform (GstOpencvVideoFilter * filter,
GstBuffer * buf, IplImage * img, GstBuffer * outbuf, IplImage * outimg);
@@ -177,9 +174,6 @@ gst_cv_laplace_class_init (GstCvLaplaceClass * klass)
static void
gst_cv_laplace_init (GstCvLaplace * filter)
{
- gst_pad_set_event_function (GST_BASE_TRANSFORM_SINK_PAD (filter),
- GST_DEBUG_FUNCPTR (gst_cv_laplace_handle_sink_event));
-
filter->aperture_size = DEFAULT_APERTURE_SIZE;
filter->scale = DEFAULT_SCALE_FACTOR;
filter->shift = DEFAULT_SHIFT;
@@ -196,12 +190,18 @@ gst_cv_laplace_cv_set_caps (GstOpencvVideoFilter * trans, gint in_width,
{
GstCvLaplace *filter = GST_CV_LAPLACE (trans);
- if (filter->intermediary_img) {
- cvReleaseImage (&filter->intermediary_img);
+ if (filter->intermediary_img != NULL) {
+ cvReleaseImage (&filter->intermediary_img);
+ cvReleaseImage (&filter->CLaplace);
+ cvReleaseImage (&filter->cvGray);
+ cvReleaseImage (&filter->Laplace);
}
+ filter->CLaplace = cvCreateImage (cvSize (in_width, in_height), IPL_DEPTH_8U, in_channels);
filter->intermediary_img =
cvCreateImage (cvSize (out_width, out_height), IPL_DEPTH_16S, 1);
+ filter->cvGray = cvCreateImage (cvSize (in_width, in_height), IPL_DEPTH_8U, 1);
+ filter->Laplace = cvCreateImage (cvSize (in_width, in_height), IPL_DEPTH_8U, 1);
return TRUE;
}
@@ -262,51 +262,6 @@ gst_cv_laplace_get_property (GObject * object, guint prop_id,
}
}
-static gboolean
-gst_cv_laplace_handle_sink_event (GstPad * pad, GstObject * parent,
- GstEvent * event)
-{
- GstCvLaplace *filter;
- gint width, height;
- GstStructure *structure;
- gboolean res = TRUE;
-
- filter = GST_CV_LAPLACE (parent);
-
- switch (GST_EVENT_TYPE (event)) {
- case GST_EVENT_CAPS:
- {
- GstCaps *caps;
- gst_event_parse_caps (event, &caps);
-
- structure = gst_caps_get_structure (caps, 0);
- gst_structure_get_int (structure, "width", &width);
- gst_structure_get_int (structure, "height", &height);
-
- if (filter->intermediary_img != NULL) {
- cvReleaseImage (&filter->intermediary_img);
- cvReleaseImage (&filter->CLaplace);
- cvReleaseImage (&filter->cvGray);
- cvReleaseImage (&filter->Laplace);
- }
-
- filter->CLaplace =
- cvCreateImage (cvSize (width, height), IPL_DEPTH_8U, 3);
- filter->intermediary_img =
- cvCreateImage (cvSize (width, height), IPL_DEPTH_16S, 1);
- filter->cvGray = cvCreateImage (cvSize (width, height), IPL_DEPTH_8U, 1);
- filter->Laplace = cvCreateImage (cvSize (width, height), IPL_DEPTH_8U, 1);
- break;
- }
- default:
- break;
- }
-
- res = gst_pad_event_default (pad, parent, event);
-
- return res;
-}
-
static GstFlowReturn
gst_cv_laplace_transform (GstOpencvVideoFilter * base, GstBuffer * buf,
IplImage * img, GstBuffer * outbuf, IplImage * outimg)