opencv3/C++關(guān)于移動對象的輪廓的跟蹤詳解
更新時間:2019年12月11日 15:08:01 作者:阿卡蒂奧
今天小編就為大家分享一篇opencv3/C++關(guān)于移動對象的輪廓的跟蹤詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
使用opencv提供的背景去除算法(KNN或高斯混合模型GMM)去除背景,然后將獲取的目標(biāo)二值化后通過篩選目標(biāo)輪廓獲得目標(biāo)位置。
#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)證件照藍(lán)底換成白底功能(或其他顏色如紅色)詳解
- opencv3/C++ 實現(xiàn)SURF特征檢測
- c++ 基于opencv 識別、定位二維碼
相關(guān)文章
c語言實現(xiàn)輸入一組數(shù)自動從大到小排列的實例代碼
下面小編就為大家?guī)硪黄猚語言實現(xiàn)輸入一組數(shù)自動從大到小排列的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09
C++中jsoncpp庫和nlohmann-json庫實現(xiàn)JSON與字符串類型轉(zhuǎn)換
jsoncpp是ROS自帶的一個JSON庫,它提供了一些函數(shù)來解析和生成JSON數(shù)據(jù),在ROS中,可以使用jsoncpp庫來實現(xiàn)JSON與字符串類型之間的轉(zhuǎn)換,這篇文章主要介紹了jsoncpp庫和nlohmann-json庫實現(xiàn)JSON與字符串類型轉(zhuǎn)換,需要的朋友可以參考下2023-08-08
全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
本篇文章是對全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C++常用函數(shù)總結(jié)(algorithm 頭文件)
本文給大家詳細(xì)介紹了algorithm 頭文件中最常用的函數(shù)及其使用方法,當(dāng)然這只是其中的一部分,algorithm 頭文件中還有很多其他的函數(shù),感興趣的朋友一起看看吧2023-12-12

