opencv3/C++關(guān)于移動(dòng)對(duì)象的輪廓的跟蹤詳解
使用opencv提供的背景去除算法(KNN或高斯混合模型GMM)去除背景,然后將獲取的目標(biāo)二值化后通過(guò)篩選目標(biāo)輪廓獲得目標(biāo)位置。
#include<opencv2/opencv.hpp>
using namespace cv;
//基于移動(dòng)對(duì)象的輪廓的跟蹤
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)于移動(dòng)對(duì)象的輪廓的跟蹤詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- C++ opencv實(shí)現(xiàn)車(chē)道線識(shí)別
- 基于OpenCV和C++ 實(shí)現(xiàn)圖片旋轉(zhuǎn)
- OpenCV實(shí)現(xiàn)車(chē)牌字符分割(C++)
- OpenCV實(shí)現(xiàn)車(chē)牌定位(C++)
- C++ opencv ffmpeg圖片序列化實(shí)現(xiàn)代碼解析
- C++&&Opencv實(shí)現(xiàn)控制臺(tái)字符動(dòng)畫(huà)的方法
- C++使用opencv處理兩張圖片的幀差
- win10環(huán)境下C++ vs2015編譯opencv249的教程
- C++使用OpenCV實(shí)現(xiàn)證件照藍(lán)底換成白底功能(或其他顏色如紅色)詳解
- opencv3/C++ 實(shí)現(xiàn)SURF特征檢測(cè)
- c++ 基于opencv 識(shí)別、定位二維碼
相關(guān)文章
c語(yǔ)言實(shí)現(xiàn)輸入一組數(shù)自動(dòng)從大到小排列的實(shí)例代碼
下面小編就為大家?guī)?lái)一篇c語(yǔ)言實(shí)現(xiàn)輸入一組數(shù)自動(dòng)從大到小排列的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
C語(yǔ)言手把手教你實(shí)現(xiàn)貪吃蛇AI(中)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言手把手教你實(shí)現(xiàn)貪吃蛇AI的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
C++中jsoncpp庫(kù)和nlohmann-json庫(kù)實(shí)現(xiàn)JSON與字符串類(lèi)型轉(zhuǎn)換
jsoncpp是ROS自帶的一個(gè)JSON庫(kù),它提供了一些函數(shù)來(lái)解析和生成JSON數(shù)據(jù),在ROS中,可以使用jsoncpp庫(kù)來(lái)實(shí)現(xiàn)JSON與字符串類(lèi)型之間的轉(zhuǎn)換,這篇文章主要介紹了jsoncpp庫(kù)和nlohmann-json庫(kù)實(shí)現(xiàn)JSON與字符串類(lèi)型轉(zhuǎn)換,需要的朋友可以參考下2023-08-08
C語(yǔ)言數(shù)據(jù)類(lèi)型轉(zhuǎn)換實(shí)例代碼
本文主要介紹C 語(yǔ)言數(shù)據(jù)類(lèi)型轉(zhuǎn)換,這里通過(guò)代碼實(shí)例進(jìn)行詳解,這是C語(yǔ)言基礎(chǔ)部分,需要的朋友可以參考下2016-07-07
全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
本篇文章是對(duì)全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C++常用函數(shù)總結(jié)(algorithm 頭文件)
本文給大家詳細(xì)介紹了algorithm 頭文件中最常用的函數(shù)及其使用方法,當(dāng)然這只是其中的一部分,algorithm 頭文件中還有很多其他的函數(shù),感興趣的朋友一起看看吧2023-12-12

