opencv3/C++关于移动对象的轮廓的跟踪详解

 更新时间:2019年12月11日 15:08:01   作者:阿卡蒂奥  
今天小编就为大家分享一篇opencv3/C++关于移动对象的轮廓的跟踪详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

使用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++关于移动对象的轮廓的跟踪详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • c语言实现输入一组数自动从大到小排列的实例代码

    c语言实现输入一组数自动从大到小排列的实例代码

    下面小编就为大家带来一篇c语言实现输入一组数自动从大到小排列的实例代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • C语言 深入浅出讲解指针的使用

    C语言 深入浅出讲解指针的使用

    指针是C语言中一个非常重要的概念,也是C语言的特色之一。使用指针可以对复杂数据进行处理,能对计算机的内存分配进行控制,在函数调用中使用指针还可以返回多个值
    2022-03-03
  • C语言手把手教你实现贪吃蛇AI(中)

    C语言手把手教你实现贪吃蛇AI(中)

    这篇文章主要为大家详细介绍了C语言手把手教你实现贪吃蛇AI的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C++泛型编程基本概念详解

    C++泛型编程基本概念详解

    这一篇介绍一下 C++ 编程中与面向对象并列的另一大分支——泛型编程,这一篇主要介绍函数模板、类模板和成员模板三大部分,需要的朋友可以参考下
    2021-08-08
  • c++常量详解

    c++常量详解

    常量是存放固定且不可变值的,一旦确定初始值则在程序其它地方不可改变, 所以const对象必须初始化。常量一般使用const关键字来修饰
    2017-06-06
  • C++中jsoncpp库和nlohmann-json库实现JSON与字符串类型转换

    C++中jsoncpp库和nlohmann-json库实现JSON与字符串类型转换

    jsoncpp是ROS自带的一个JSON库,它提供了一些函数来解析和生成JSON数据,在ROS中,可以使用jsoncpp库来实现JSON与字符串类型之间的转换,这篇文章主要介绍了jsoncpp库和nlohmann-json库实现JSON与字符串类型转换,需要的朋友可以参考下
    2023-08-08
  • C++的字符串分割函数的使用详解

    C++的字符串分割函数的使用详解

    本篇文章主要介绍了C++的字符串分割函数,主要用strtok、STL、Boost进行字符串分割,有需要的可以了解一下。
    2016-11-11
  • C语言数据类型转换实例代码

    C语言数据类型转换实例代码

    本文主要介绍C 语言数据类型转换,这里通过代码实例进行详解,这是C语言基础部分,需要的朋友可以参考下
    2016-07-07
  • 全排列算法的非递归实现与递归实现的方法(C++)

    全排列算法的非递归实现与递归实现的方法(C++)

    本篇文章是对全排列算法的非递归实现与递归实现的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++常用函数总结(algorithm 头文件)

    C++常用函数总结(algorithm 头文件)

    本文给大家详细介绍了algorithm 头文件中最常用的函数及其使用方法,当然这只是其中的一部分,algorithm 头文件中还有很多其他的函数,感兴趣的朋友一起看看吧
    2023-12-12

最新评论