中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

opencv3/C++關于移動對象的輪廓的跟蹤詳解

發布時間:2020-09-15 10:03:35 來源:腳本之家 閱讀:171 作者:阿卡蒂奧 欄目:編程語言

使用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++關于移動對象的輪廓的跟蹤詳解

opencv3/C++關于移動對象的輪廓的跟蹤詳解

以上這篇opencv3/C++關于移動對象的輪廓的跟蹤詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安宁市| 炉霍县| 元氏县| 伊通| 陵川县| 建始县| 永胜县| 修文县| 美姑县| 四会市| 韶关市| 营口市| 东城区| 新邵县| 抚顺市| 丁青县| 逊克县| 晋宁县| 松江区| 唐河县| 天柱县| 无锡市| 都江堰市| 黑河市| 荣昌县| 青海省| 怀宁县| 三明市| 五莲县| 德安县| 滁州市| 星子县| 长岭县| 青冈县| 尚义县| 油尖旺区| 柯坪县| 色达县| 上犹县| 清河县| 永福县|