文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

OpenCV如何使用BSM统计视频中移动的对象

2023-07-05 04:56

关注

本文小编为大家详细介绍“OpenCV如何使用BSM统计视频中移动的对象”,内容详细,步骤清晰,细节处理妥当,希望这篇“OpenCV如何使用BSM统计视频中移动的对象”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1、概述

案例:使用BackgroundSubstractor实现视频中移动对象统计

实现步骤:

实例化VideoCapture

创建BackgroundSubstractor

while循环读取视频帧

使用BS->apply获取mask

对mask进行二值化及形态学操作

使用findContours执行轮廓发现

统计最大外接矩形

输出结果

ps:这个算法的抗干扰能力比较差,要相出正确的结果,必须要对frame进行预处理。或者提升视频的质量才行。不然只能得到一个错误的结果

2、代码示例

Move_Video_Object_Tracking::Move_Video_Object_Tracking(QWidget *parent)    : MyGraphicsView{parent}{    this->setWindowTitle("视频中移动对象统计");    QPushButton *btn = new QPushButton(this);    btn->setText("选择视频");    connect(btn,&QPushButton::clicked,[=](){        choiceVideo();    }); }  void Move_Video_Object_Tracking::choiceVideo(){    path = QFileDialog::getOpenFileName(this,"请选择视频","/Users/yangwei/Downloads/",tr("Image Files(*.mp4 *.avi)"));    qDebug()<<"视频路径:"<<path;    showMoveVideoObjectTracking(path.toStdString().c_str());} void Move_Video_Object_Tracking::showMoveVideoObjectTracking(const char* filePath){    VideoCapture capture;    capture.open(filePath);     if(!capture.isOpened()){        qDebug()<<"无法加载视频文件";        return;    }    Ptr<BackgroundSubtractor> mogSubstractor = createBackgroundSubtractorMOG2();    Mat frame,gauss,mask;    Mat kernel = getStructuringElement(MORPH_RECT,Size(3,3));    int count=0;    char text[8];    while(capture.read(frame)){        GaussianBlur(frame,gauss,Size(5,5),0,0);        mogSubstractor->apply(gauss,mask);//获取mask        threshold(mask,mask,0,255,THRESH_BINARY|cv::THRESH_OTSU);        //执行形态学操作        morphologyEx(mask,mask,MORPH_OPEN,kernel);        dilate(mask,mask,kernel,Point(-1,-1));        imshow("mask",mask);         //找到最大轮廓定位外接矩形        vector<vector<Point>> contours;        vector<Vec4i> heri;        //寻找最大外接矩形        findContours(mask,contours,RETR_EXTERNAL,CHAIN_APPROX_SIMPLE);        count = 0;        for(size_t i = 0;i<contours.size();i++){            double area = contourArea(contours[i]);            if(area<5000){                continue;            }            Rect rect = boundingRect(contours[i]);            qDebug()<<rect.width<<":"<<rect.height;            if (rect.width < 200 || rect.height < 100) continue;            count++;            rectangle(frame,rect,Scalar(0,0,255),3,8);            sprintf(text,"%d",count);            putText(frame,text,Point(rect.x+rect.width/2,rect.y+rect.height/2),FONT_ITALIC, FONT_HERSHEY_PLAIN,Scalar(0,255,0),2,8);        }          imshow("frame",frame);         int c = waitKey(1);        if(c==27){            break;        }    }    capture.release(); }

读到这里,这篇“OpenCV如何使用BSM统计视频中移动的对象”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯