Sample code using Sobel and/or Scharr OpenCV functions to make a simple Edge Detector  
    
 
 
#include <iostream>
 
 
int main( 
int argc, 
char** argv )
 
{
                               "{@input   |lena.jpg|input image}"
                               "{ksize   k|1|ksize (hit 'K' to increase its value at run time)}"
                               "{scale   s|1|scale (hit 'S' to increase its value at run time)}"
                               "{delta   d|0|delta (hit 'D' to increase its value at run time)}"
                               "{help    h|false|show help message}");
 
  cout << "The sample uses Sobel or Scharr OpenCV functions for edge detection\n\n";
  cout << "\nPress 'ESC' to exit program.\nPress 'R' to reset values ( ksize will be -1 equal to Scharr function )";
 
  
  const String window_name = 
"Sobel Demo - Simple Edge Detector";
 
  int ksize = parser.
get<
int>(
"ksize");
 
  int scale = parser.
get<
int>(
"scale");
 
  int delta = parser.
get<
int>(
"delta");
 
 
  
  image = imread( samples::findFile( imageName ), IMREAD_COLOR ); 
 
  
  {
    printf("Error opening image: %s\n", imageName.c_str());
    return EXIT_FAILURE;
  }
 
  for (;;)
  {
    
    GaussianBlur(image, src, 
Size(3, 3), 0, 0, BORDER_DEFAULT);
 
    
    cvtColor(src, src_gray, COLOR_BGR2GRAY);
 
    Mat abs_grad_x, abs_grad_y;
 
 
    Sobel(src_gray, grad_x, ddepth, 1, 0, ksize, scale, delta, BORDER_DEFAULT);
 
    Sobel(src_gray, grad_y, ddepth, 0, 1, ksize, scale, delta, BORDER_DEFAULT);
 
    
    convertScaleAbs(grad_x, abs_grad_x);
    convertScaleAbs(grad_y, abs_grad_y);
 
    addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 0, grad);
 
    imshow(window_name, grad);
    char key = (char)waitKey(0);
 
    if(key == 27)
    {
      return EXIT_SUCCESS;
    }
 
    if (key == 'k' || key == 'K')
    {
      ksize = ksize < 30 ? ksize+2 : -1;
    }
 
    if (key == 's' || key == 'S')
    {
      scale++;
    }
 
    if (key == 'd' || key == 'D')
    {
      delta++;
    }
 
    if (key == 'r' || key == 'R')
    {
      scale =  1;
      ksize = -1;
      delta =  0;
    }
  }
  return EXIT_SUCCESS;
}
Designed for command line parsing.
Definition utility.hpp:890
T get(const String &name, bool space_delete=true) const
Access arguments by name.
Definition utility.hpp:956
void printMessage() const
Print help message.
n-dimensional dense array class
Definition mat.hpp:938
bool empty() const
Returns true if the array has no elements.
Template class for specifying the size of an image or rectangle.
Definition types.hpp:338
std::string String
Definition cvstd.hpp:151
#define CV_16S
Definition interface.h:57
int main(int argc, char *argv[])
Definition highgui_qt.cpp:3