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語言實現(xiàn)輸入一組數(shù)自動從大到小排列的實例代碼
下面小編就為大家?guī)硪黄猚語言實現(xiàn)輸入一組數(shù)自動從大到小排列的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09C++中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)的方法進行了詳細的分析介紹,需要的朋友參考下2013-05-05C++常用函數(shù)總結(jié)(algorithm 頭文件)
本文給大家詳細介紹了algorithm 頭文件中最常用的函數(shù)及其使用方法,當然這只是其中的一部分,algorithm 頭文件中還有很多其他的函數(shù),感興趣的朋友一起看看吧2023-12-12