mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.6 KiB
67 lines
1.6 KiB
/** |
|
* @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; |
|
}
|
|
|