forked from oreillymedia/Learning-OpenCV-3_examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Exercises_9_5.cpp
64 lines (59 loc) · 2.18 KB
/
Exercises_9_5.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//Exercises_9_5.cpp Exercises at end of Chapter 9
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
void help(const char **argv) {
cout << "\n\n"
<< "This program solves the Exercise 4、5 at the end of Chapter 9 \n"
<< "Call:\n"
<< argv[0] << " <path/image_name1>" << " <path/image_name2>\n\n"
<< "For example: ./" << argv[0] << " ../left.jpg "<< " ../left.jpg\n"
<< endl;
}
int main( int argc, const char** argv )
{
help(argv);
if(argc < 3) {
cout << "\nERROR: You had too few parameters.\n" << endl;
return -1;
}
Mat temp;
Mat temp2;
/************************************************************************/
/* 5. Create an outline of an object. Take a picture of a scene. Then, without moving
the camera, put a coffee cup in the scene and take a second picture. Load these
images and convert both to 8-bit grayscale images.
a. Take the absolute value of their difference. Display the result, which should
look like a noisy mask of a coffee mug.
b. Do a binary threshold of the resulting image using a level that preserves most
of the coffee mug but removes some of the noise. Display the result. The “on”
values should be set to 255.
c. Do a cv::MOP_OPEN on the image to further clean up noise.
d. Using the erosion operator and logical XOR function, turn the mask of the
coffee cup image into an outline of the coffee cup (only the edge pixels
remaining). */
/************************************************************************/
Mat matMug = imread(argv[1],IMREAD_GRAYSCALE);
Mat matNoMug = imread(argv[2],IMREAD_GRAYSCALE);
if (matMug.empty() || matNoMug.empty())
{
cout << "\nERROR: parameters is not a image name.\n" << endl;
return -1;
}
//a
absdiff(matMug,matNoMug,temp);
imshow("absolute value of mug ",temp);
//b
threshold(temp,temp,100,255,THRESH_OTSU);
imshow("a binary threshold",temp);
//c
morphologyEx(temp,temp,cv::MORPH_OPEN,Mat());
imshow("MORPH_OPEN",temp);
//d
erode(temp,temp,Mat());
matMug.copyTo(temp2,temp);
imshow("an outline of the coffee cup",temp2);
waitKey();
return 0;
}