QT--动态人流量监测系统


简介:

  • 本项目使用了百度AI的动态人流量监测api,以人体头肩为主要识别目标,适用于低空俯拍,出入口场景,可用于统计当前图像的锁定人数经过的人数

项目功能

  • 本项目分为相机模块图像识别模块

    • 相机模块

      • 使用了两个button复用、一个滑动条

      • 按下打开摄像头button,开始准备拍照,button变成关闭摄像头button,再点击就关闭摄像头。

      • 在打开摄像头之前,开始button是无法使用的。

      • 当打开摄像头后按下开始button,button变成停止button,同时开始拍摄照片,由于是动态监测人流量,所以抽祯频率为5fps,也就是每秒需要拍摄上传5张照片,第一打开需要连接网络,所以可能有些慢。

      • 滑动条在点击开始之前是无法使用的,当开始拍照后,可拖动滑动条切换窗口界面,进入监测界面

    • 图像识别模块

      • 图像识别模块可将相机模块拍摄的照片上传网络,进行人体识别,判断当前图片指定区域的人数、进入指定区域的人数,离开指定区域的人数

      • 将图片上传到网络上后可获得返回的人数数值和渲染图片,显示在监测界面

      • 图片中的人被锁定后会在人体头部出现矩形框

      • 左边框为指定区域

      • 画面左上角分别为总的锁定人数进入指定区域的总人数离开指定区域的总人数

      • 左下角为此次打开运行的人数

1. pro文件

QT       += core gui network multimedia multimediawidgets
//network 为HTTP通信必加
//multimedia multimediawidgets 为相机必加

2.widget.h文件

#ifndef WIDGET_H
#define WIDGET_H #include <QWidget>
#include <QCamera>
#include <QCameraViewfinder>
#include <QCameraImageCapture>
#include <QTimer>
#include <QNetworkAccessManager>
#include <QNetworkReply>
#include <QNetworkRequest>
#include <QJsonObject> namespace Ui {
class Widget;
} class Widget : public QWidget
{
Q_OBJECT public:
explicit Widget(QWidget *parent = nullptr);
~Widget(); public:
QTimer *timer;
QCamera *camera; //系统摄像头设备
QCameraViewfinder *finder; //摄像头取景器
QCameraImageCapture *capture; //截图部件
QImage Image; //保存照片
bool Switch; //开关
int Position; //保存滑动条值
QImage img ; //返回照片
int ins = ; //进入人数
int outs = ; //离开人数 void photo(); //拍照
void display(); //显示
void photograph(); //相机初始化
void cameraImageCaptured(int id, QImage image); //获得照片 /********************网络**************************************/
QNetworkAccessManager *manager; //网络访问管理器
QNetworkReply * reply; //网络回复
QNetworkRequest *requst; //网络请求
bool connection = false; void initialization(); //网络
void sendHTTP(); //发送请求 private slots:
void on_pushButton_clicked(); void on_pushButton_2_clicked(); void on_horizontalSlider_sliderMoved(int position); private:
Ui::Widget *ui;
}; #endif // WIDGET_H
3.widget.cpp文件
#include "widget.h"
#include "ui_widget.h"
#include <QBuffer>
#include <QByteArray>
#include <QImageReader>
#include <QJsonDocument>
#include <QJsonObject>
#include <QThread> Widget::Widget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Widget)
{
ui->setupUi(this); photograph(); //相机
initialization(); //网络 } Widget::~Widget()
{
delete ui;
} //网络
void Widget::initialization()
{
manager = new QNetworkAccessManager(this);
requst = new QNetworkRequest; QString request_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/body_tracking"; //填入百度AI的请求URL QString toke = "24.6878d2808d1dd6be2a3a760c82d0979a.2592000.1570716999.282335-17208954"; //填入百度AI的access_token,具体可看百度AI的文档 QString url = request_url + "?access_token=" + toke; //注意格式
requst->setUrl(QUrl(url));
requst->setHeader(QNetworkRequest::ContentTypeHeader,"application/x-www-form-urlencoded"); //头不能填错Content-Type
connect(manager,&QNetworkAccessManager::finished,this,
[=](QNetworkReply *reply)
{
QByteArray array = reply->readAll(); //获取信息
qDebug() << array;
QJsonObject json1 = QJsonDocument::fromJson(array).object();
QString image = json1.value("image").toString(); QByteArray ba; //解析返回渲染图
ba.append(image);
QByteArray ba1 = ba.fromBase64(ba); QBuffer buffer(&ba1);
buffer.open(QIODevice::ReadOnly);
QImageReader reader(&buffer,"jpg");
img = reader.read(); int person_num = json1.value("person_num").toInt();
QJsonObject object = json1.value("person_count").toObject();
qDebug() << object;
int in = object.value("in").toInt();
int out = object.value("out").toInt();
ins += in;
outs += out; QString str = "当前人数:" + QString::number(person_num); //返回人数
ui->label_2->setText(str);
QString str1 = "进入人数:" + QString::number(ins);
ui->label_3->setText(str1);
QString str2 = "离开人数:" + QString::number(outs);
ui->label_4->setText(str2); }); } //发送请求
void Widget::sendHTTP()
{
QByteArray ba;
QBuffer buf(&ba);
Image.save(&buf, "jpg"); QByteArray SendData = ""; SendData.append("&dynamic=true"); //封装发送信息
SendData.append("&case_id=1");
SendData.append("&case_init=false");
SendData.append("&image=");
SendData.append(ba.toBase64().toPercentEncoding());
SendData.append("&show=true");
SendData.append("&area=1,1,700,1,700,719,1,719");
qDebug() << SendData; manager->post(*requst,SendData); } //相机初始化
void Widget::photograph()
{
this->resize(,); //设置窗口大小 camera = new QCamera(this); //系统摄像头设备
finder = new QCameraViewfinder(this); //摄像头取景器部件
capture = new QCameraImageCapture(camera); //截图部件
timer = new QTimer(this); ui->verticalLayout->addWidget(finder); //在布局器上添加finder
ui->label->setMaximumSize(,); //设置照片初始化大小
ui->pushButton_2->setEnabled(false); Switch = false;
Position = ; connect(timer,&QTimer::timeout,this,&Widget::photo); //监听定时器
connect(capture,&QCameraImageCapture::imageCaptured,this,
&Widget::cameraImageCaptured); //图像捕获
capture->setCaptureDestination(QCameraImageCapture::CaptureToFile); //设置要捕获的对象
camera->setCaptureMode(QCamera::CaptureStillImage); //摄像机配置为静止帧捕获。
camera->setViewfinder(finder); //设置取景器
} //拍照
void Widget::photo()
{
capture->capture(); //拍照
sendHTTP();
display(); //显示
} //获得图像
void Widget::cameraImageCaptured(int id, QImage image)
{
Image = image;
} //打开摄像头
void Widget::on_pushButton_clicked()
{
if(!Switch)
{
camera->start(); //打开摄像头
ui->pushButton->setText("关闭摄像头");
ui->pushButton_2->setEnabled(true); //打开button
Switch = true;
}
else
{
camera->stop();
ui->pushButton->setText("打开摄像头");
ui->pushButton_2->setEnabled(false);
Switch = false;
// connection = false;
} } //定时拍照
void Widget::on_pushButton_2_clicked()
{
if(!timer->isActive())
{
timer->start();
ui->pushButton_2->setText("停止");
}
else
{
timer->stop();
ui->pushButton_2->setText("开始");
} } //滑动切换
void Widget::on_horizontalSlider_sliderMoved(int position)
{
Position = position;
display();
} //显示
void Widget::display()
{
ui->horizontalSlider->setMinimum();
ui->horizontalSlider->setMaximum(this->width());
ui->label->setMaximumSize(Position * (/),Position); QPixmap pixmap = QPixmap::fromImage(img );
QPixmap fitpixmap = pixmap.scaled(Position * (/),Position, Qt::KeepAspectRatio, Qt::SmoothTransformation); // 按比例缩放
ui->label->setPixmap(fitpixmap);
qDebug() << Position;
}

4.widget.ui文件

  • 左边的空为一个部局器

  • 右边的空内为一个label

  • 当前人数、进入人数、离开人数为三个label

5.注意

  • 有的版本的QT编译运行,在连接网络时会出现下列错误

    qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed1
  • QT5.13的目前我不知道如何解决

  • QT5.12的需要在QT安装目录下找到下列两个文件

  • 选择与自己编译器相同的文件,我的是64的,就选64的文件

  • 将找到的两个文件放入项目的可执行文件所在文件夹下,即bebug或release,再编译运行就可以了

6.工程源码

https://github.com/mahuifa/AI-person-flow-monitoring

QT--动态人流量监测系统的更多相关文章

  1. win环境下,用虚拟化工具打包Qt动态编译exe的过程(使用Enigma Virtual Box)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://goldlion.blog.51cto.com/4127613/834075 引子 ...

  2. Qt动态连接库/静态连接库创建与使用,QLibrary动态加载库

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt动态连接库/静态连接库创建与使用,QLibrary动态加载库     本文地址:https ...

  3. Qt元对象(Meta-Object)系统与反射

    反射 -在计算机科学中,反射是指计算机程序在运行时(Run time)可以访问.检测和修改它本身状态或行为的一种能力.[1]用比喻来说,反射就是程序在运行的时候能够“观察”并且修改自己的行为. 要注意 ...

  4. Security基础(五):部署Cacti监控平台、构建Cacti监测系统

    一.部署Cacti监控平台 目标: 本案例要求部署一台Cacti监控主机,并安装相关监控组件,为进一步执行具体的监控任务做准备: 安装net-snmp.net-snmp-utils 安装LAMP及相关 ...

  5. iNeuOS工业互联网操作系统,矿山动态产量计量系统和铁路车辆识别系统应用场景案例

    目       录 1.      概述... 2 2.      平台演示... 2 3.      矿山动态产量计量系统... 2 4.      铁路车辆识别系统... 4 1.   概述 iN ...

  6. 将Qt 动态链接生成的exe及依赖dll打包方法

    源地址:http://blog.csdn.net/ztz0223/article/details/8939341 将Qt 动态链接生成的exe及依赖dll打包方法 原文:http://www.qtcn ...

  7. C++框架_之Qt的窗口部件系统的详解-上

    C++框架_之Qt的窗口部件系统的详解-上 第一部分概述 第一次建立helloworld程序时,曾看到Qt Creator提供的默认基类只有QMainWindow.QWidget和QDialog三种. ...

  8. 嵌入式系统及应用课程设计——基于STM32的温湿度监测系统

    大三上学期期末总结,嗯,没错上学期,写在新学期开始,hhh. 上学期学了一门嵌入式系统及应用的课程,期末的课程设计题目是基于STM32的温湿度监测系统. 记得刚开始做课程设计的时候,听说先设计画出原理 ...

  9. 基于stm32的水质监测系统项目基础部分详细记录

    基于stm32的水质监测系统项目基础部分详细记录 软件环境:MDK5 硬件环境:STM32F103ZET6 开发板.颜色传感器.串口屏.串口打印机 搭建工程模板 在进行项目软件的撰写时,首先新建一个基 ...

随机推荐

  1. 数据库Oracle的子查询练习

    1.写一个查询显示与 Zlotkey 的 在同一部门的雇员的 last name和 hire date,结果中不包括 Zlotkey --1.写一个查询显示与 Zlotkey 的 在同一部门的雇员的 ...

  2. Spring事物实例

    Spring事务实例: entity实体类: public class Accounts { private int accountid; private String accountname; pr ...

  3. (全国多校重现赛一) J-Two strings

    Giving two strings and you should judge if they are matched.  The first string contains lowercase le ...

  4. robot_framework常用关键字

    快捷键 F8 运行 ctrl+alt+空格 log 类似于print Set variable 定义变量 Catenate 连接对象 SEPARATOR 对多个连接信息进行分割 Create List ...

  5. Orleans 初接触

    简介 这篇随笔主要记录了自己学习Orleans的经过和理解,在学习过程中会一直更新,思路和理解可能有些偏颇,如果有幸有大佬看到这篇文章,希望能给予批评指正. 导航 (一) 入门例子 (二) 测试用例 ...

  6. JS基础知识点——原始类型和对象类型的区别

    1.js类型 1.1 JavaScript语言规定了7种语言类型,他们分别是: Number(数字) Boolean(布尔值) String(字符串) Null (空) Undefined (未定义) ...

  7. vscode代码自动补全失效

    前段时间,朋友说自己的vscode突然出现了代码不能自动补全的问题(主要是js,其他语言也可以参考) 症状表现为,刚打开vscode有自动补全,过了一会,突然就没了,反反复复 解决过程也是相当坎坷了 ...

  8. python学习-os引入

    # 引入import os # 路径处理 -- 外部资源-os # 获取当前的工作路径workspace = os.getcwd() # os模块下的getcwd函数print(workspace) ...

  9. java基础-初识类

    一 前言 在 <[java基础]-谈谈对面向对象理解 >一文中已经知道什么是对象,如何创建对象:这篇文章主讲对象的类型,简称类: 二 类介绍 2.1 类 每个对象都有一个类型,通常在所有的 ...

  10. LeetCode刷题总结-字符串篇

    本文梳理对LeetCode上有关字符串习题的知识点,并给出对应的刷题建议.本文建议刷题的总数为32题.具体知识点如下图: 1.回文问题 题号:5. 最长回文子串,难度中等 题号:214. 最短回文串, ...