/*****************************************************************************
* Module descriptor
*****************************************************************************/
-vlc_module_begin();
- set_description( N_("OpenCV face detection example filter") );
- set_shortname( N_( "OpenCV example" ));
- set_capability( "opencv example", 1 );
- add_shortcut( "opencv_example" );
+vlc_module_begin ()
+ set_description( N_("OpenCV face detection example filter") )
+ set_shortname( N_( "OpenCV example" ))
+ set_capability( "opencv example", 1 )
+ add_shortcut( "opencv_example" )
- set_category( CAT_VIDEO );
- set_subcategory( SUBCAT_VIDEO_VFILTER2 );
- set_callbacks( OpenFilter, CloseFilter );
+ set_category( CAT_VIDEO )
+ set_subcategory( SUBCAT_VIDEO_VFILTER2 )
+ set_callbacks( OpenFilter, CloseFilter )
add_string( "opencv-haarcascade-file", "c:\\haarcascade_frontalface_alt.xml", NULL,
N_("Haar cascade filename"),
N_("Name of XML file containing Haar cascade description"), false);
-vlc_module_end();
+vlc_module_end ()
/*****************************************************************************
* OpenFilter: probe the filter and return score
char* filename = config_GetPsz( p_filter, "opencv-haarcascade-file" );
p_filter->p_sys->p_cascade = (CvHaarClassifierCascade*)cvLoad( filename, 0, 0, 0 );
p_filter->p_sys->p_storage = cvCreateMemStorage(0);
+ free( filename );
return VLC_SUCCESS;
}
}
if (faces && (faces->total > 0)) //raise the video filter event
- var_Change( p_filter->p_libvlc, VIDEO_FILTER_EVENT_VARIABLE, VLC_VAR_TRIGGER_CALLBACKS, NULL, NULL );
+ var_TriggerCallback( p_filter->p_libvlc, VIDEO_FILTER_EVENT_VARIABLE );
}
else
msg_Err( p_filter, "No cascade - is opencv-haarcascade-file valid?" );