opencv3/C++關(guān)于移動對象的輪廓的跟蹤詳解
更新時間:2019年12月11日 15:08:01 作者:阿卡蒂奧
今天小編就為大家分享一篇opencv3/C++關(guān)于移動對象的輪廓的跟蹤詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
使用opencv提供的背景去除算法(KNN或高斯混合模型GMM)去除背景,然后將獲取的目標二值化后通過篩選目標輪廓獲得目標位置。
#include<opencv2/opencv.hpp>
using namespace cv;
//基于移動對象的輪廓的跟蹤
int main()
{
Mat frame;
bool flag = true;
VideoCapture capture;
capture.open(0);
if (!capture.isOpened())
{
printf("can not open ......\n");
return -1;
}
namedWindow("mask", WINDOW_AUTOSIZE);
namedWindow("output", WINDOW_AUTOSIZE);
Ptr<BackgroundSubtractor> pKNN = createBackgroundSubtractorKNN();
//Ptr<BackgroundSubtractor> pMOG2 = createBackgroundSubtractorMOG2();
while (capture.read(frame))
{
Mat KNNMask;
std::vector<std::vector<Point>>contours;
pKNN->apply(frame, KNNMask);
//(*pMOG2).apply(frame, mogMask);
threshold(KNNMask, KNNMask, 100, 255, THRESH_BINARY);
Mat kernel = getStructuringElement(MORPH_RECT, Size(3, 3));
morphologyEx(KNNMask, KNNMask, MORPH_OPEN, kernel, Point(-1,-1));
findContours(KNNMask, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE, Point(0,0));
for (int i = 0; i < contours.size(); i++)
{
//輪廓面積
double area = contourArea(contours[i]);
//輪廓外接矩陣
Rect rect = boundingRect(contours[i]);
if (area < 500 || rect.width < 50 || rect.height < 50) continue;
rectangle(frame, rect, Scalar(0,255,255),2);
putText(frame, "Target", Point(rect.x, rect.y), CV_FONT_NORMAL, FONT_HERSHEY_PLAIN, Scalar(0,255,0),2,8);
}
imshow("mask",KNNMask);
imshow("output",frame);
waitKey(1);
}
return 0;
}


以上這篇opencv3/C++關(guān)于移動對象的輪廓的跟蹤詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- C++ opencv實現(xiàn)車道線識別
- 基于OpenCV和C++ 實現(xiàn)圖片旋轉(zhuǎn)
- OpenCV實現(xiàn)車牌字符分割(C++)
- OpenCV實現(xiàn)車牌定位(C++)
- C++ opencv ffmpeg圖片序列化實現(xiàn)代碼解析
- C++&&Opencv實現(xiàn)控制臺字符動畫的方法
- C++使用opencv處理兩張圖片的幀差
- win10環(huán)境下C++ vs2015編譯opencv249的教程
- C++使用OpenCV實現(xiàn)證件照藍底換成白底功能(或其他顏色如紅色)詳解
- opencv3/C++ 實現(xiàn)SURF特征檢測
- c++ 基于opencv 識別、定位二維碼
相關(guān)文章
C語言 數(shù)據(jù)結(jié)構(gòu)之中序二叉樹實例詳解
這篇文章主要介紹了C語言 數(shù)據(jù)結(jié)構(gòu)之中序二叉樹實例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01
C語言通過深度優(yōu)先搜索來解電梯問題和N皇后問題的示例
深度優(yōu)先搜索即是對一個新發(fā)現(xiàn)的節(jié)點上如果還關(guān)聯(lián)未探測到的邊,就沿此邊探測下去,直到發(fā)現(xiàn)從原點可達的所有點為止,這里我們就來展示C語言通過深度優(yōu)先搜索來解電梯問題和N皇后問題的示例2016-06-06

