/** * @file Laplace_Demo.cpp * @brief Sample code showing how to detect edges using the Laplace operator * @author OpenCV team */ #include "opencv2/imgproc.hpp" #include "opencv2/imgcodecs.hpp" #include "opencv2/highgui.hpp" using namespace cv; /** * @function main */ int main( int argc, char** argv ) { //![variables] // Declare the variables we are going to use Mat src, src_gray, dst; int kernel_size = 3; int scale = 1; int delta = 0; int ddepth = CV_16S; const char* window_name = "Laplace Demo"; //![variables] //![load] const char* imageName = argc >=2 ? argv[1] : "lena.jpg"; src = imread( samples::findFile( imageName ), IMREAD_COLOR ); // Load an image // Check if image is loaded fine if(src.empty()){ printf(" Error opening image\n"); printf(" Program Arguments: [image_name -- default lena.jpg] \n"); return -1; } //![load] //![reduce_noise] // Reduce noise by blurring with a Gaussian filter ( kernel size = 3 ) GaussianBlur( src, src, Size(3, 3), 0, 0, BORDER_DEFAULT ); //![reduce_noise] //![convert_to_gray] cvtColor( src, src_gray, COLOR_BGR2GRAY ); // Convert the image to grayscale //![convert_to_gray] /// Apply Laplace function Mat abs_dst; //![laplacian] Laplacian( src_gray, dst, ddepth, kernel_size, scale, delta, BORDER_DEFAULT ); //![laplacian] //![convert] // converting back to CV_8U convertScaleAbs( dst, abs_dst ); //![convert] //![display] imshow( window_name, abs_dst ); waitKey(0); //![display] return 0; }