亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

opencv3/C++關(guān)于移動(dòng)對象的輪廓的跟蹤詳解

 更新時(shí)間:2019年12月11日 15:08:01   作者:阿卡蒂奧  
今天小編就為大家分享一篇opencv3/C++關(guān)于移動(dòng)對象的輪廓的跟蹤詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

使用opencv提供的背景去除算法(KNN或高斯混合模型GMM)去除背景,然后將獲取的目標(biāo)二值化后通過篩選目標(biāo)輪廓獲得目標(biāo)位置。

#include<opencv2/opencv.hpp>
using namespace cv;
//基于移動(dòng)對象的輪廓的跟蹤
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)對象的輪廓的跟蹤詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論