1 Star 0 Fork 0

lewlovehow / Learning-OpenCV-3_examples

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
Exercises_9_5.cpp 2.18 KB
一键复制 编辑 原始数据 按行查看 历史
jsxyhelu 提交于 2017-06-21 21:46 . Create Exercises_9_5.cpp
//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;
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/lewlovehow/Learning-OpenCV-3_examples.git
git@gitee.com:lewlovehow/Learning-OpenCV-3_examples.git
lewlovehow
Learning-OpenCV-3_examples
Learning-OpenCV-3_examples
master

搜索帮助

344bd9b3 5694891 D2dac590 5694891