#include <iostream>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
using namespace cv ;
using namespace std ;
Mat src; Mat src_gray;
int thresh = 100;
int max_thresh = 255;
RNG rng(12345);
void thresh_callback(int, void* );
int main( int, char** argv )
{
src = cv::imread("/Users/powenko/Desktop/apple.png");
if (src.empty())
{
cerr << "No image supplied ..." << endl;
return -1;
}
const char* source_window = "Source";
namedWindow( source_window, WINDOW_AUTOSIZE );
imshow( source_window, src );
createTrackbar( " erode thresh:", "Source", &thresh, max_thresh, thresh_callback );
thresh_callback( 0, 0 );
waitKey(0);
return(0);
}
void thresh_callback(int, void* )
{
Mat canny_output;
vector<vector<Point> > contours;
vector<Vec4i> hierarchy;
//kernel的形狀----矩形: MORPH_RECT 交叉形: MORPH_CROSS 椭圆形 : MORPH_ELLIPSE
Mat drawing;
if(thresh>0){
Mat element = getStructuringElement(MORPH_RECT, Size(thresh,thresh));
dilate(src, drawing, element);
}else{
drawing=src;
}
namedWindow( "Contours", WINDOW_AUTOSIZE );
imshow( "Contours", drawing );
}
