#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2\highgui\highgui.hpp>
#include <ctime>
#include <Windows.h>
#include "Python.h"
//#include "FaceRecognition.cpp"
using namespace cv;
using namespace std;
bool initialization(VideoCapture&, CascadeClassifier&);
bool get_img(VideoCapture, Mat&);
bool faceRecognition(Mat, vector<Rect>&, CascadeClassifier);
void sit_or_not(vector<Rect>);
void notification();
int detected = 0;
int absent = 0;
int sit_count = 0;
bool sit_flag = false;
bool sent_flag = false;
bool test_flag = true;
int main()
{
notification();
return 0;
/*Mat frame, frame_gray;
VideoCapture cam(0);
CascadeClassifier face;
vector<Rect> faceRect;
if (!initialization(cam, face))
return -1;
while (1)
{
if (!get_img(cam, frame))
break;
if (!faceRecognition(frame, faceRect, face))
break;
sit_or_not(faceRect);
imshow("BigBrotherVideo", frame);
if (waitKey(30) == 27)
break;
Sleep(2000);
}
waitKey(0);
return 0;*/
}
bool initialization(VideoCapture &cam, CascadeClassifier &face)
{
if (!face.load("haarcascade_frontalface_alt.xml"))
{
cout << "Failed to load haarcascade_frontalface_alt.xml!" << endl;
return false;
}
if (!cam.isOpened())
{
cout << "Failed to open the camera!" << endl;
return false;
}
return true;
}
bool get_img(VideoCapture cam, Mat &frame)
{
if (!cam.read(frame))
{
cout << "Failed to read the frame" << endl;
return false;
}
return true;
}
bool faceRecognition(Mat img, vector<Rect>& res, CascadeClassifier face)
{
Mat img_gray;
cvtColor(img, img_gray, CV_BGR2GRAY);
equalizeHist(img_gray, img_gray);
face.detectMultiScale(img_gray, res, 1.1, 2, 0);
return true;
}
void sit_or_not(vector<Rect> faceRect)
{
if (faceRect.size() == 0)
{
absent++;
//cout << "Buzai" << endl;
}
else
{
absent = 0;
detected++;
//cout << "Zai" << endl;
}
if (!sit_flag && detected >= 5)
sit_flag = true;
if (absent >= 2)
{
sit_flag = false;
detected = 0;
}
if (sit_flag)
{
if ((sent_flag && sit_count % 3 == 0) || !sent_flag)
{
notification();
sent_flag = true;
}
sit_count++;
}
cout << "Current data:" << endl
<< "Detected: " << detected << endl
<< "Absent: " << absent << endl << endl;
}
void notification()
{
Py_Initialize();
/*
string path = "~/python";
string chdir_cmd = string("sys.path.append(\"") + path + "\")";
const char* cstr_cmd = chdir_cmd.c_str();
PyRun_SimpleString("import sys");
PyRun_SimpleString(cstr_cmd);
*/
PyObject * pModule = PyImport_ImportModule("notification");
PyObject * pFunc = PyObject_GetAttrString(pModule, "notification");
PyEval_CallObject(pFunc, NULL);
Py_Finalize();
}
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
【资源说明】 基于OpenCV的防久坐解决方案源码+使用文档+全部资料(优秀项目).zip基于OpenCV的防久坐解决方案源码+使用文档+全部资料(优秀项目).zip基于OpenCV的防久坐解决方案源码+使用文档+全部资料(优秀项目).zip 【备注】 1、该项目是个人高分毕业设计项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(如软件工程、计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
资源推荐
资源详情
资源评论
收起资源包目录
基于OpenCV的防久坐解决方案源码+使用文档+全部资料(优秀项目).zip (38个子文件)
StandUp-master
StandUp
StandUp
FaceRecognition.cpp 571B
haarcascade_frontalface_alt.xml 661KB
main.cpp 3KB
x64
Release
vc141.pdb 1.69MB
StandUp.tlog
CL.write.1.tlog 462B
CL.command.1.tlog 702B
link.command.1.tlog 2B
link.read.1.tlog 2B
link.write.1.tlog 2B
StandUp.lastbuildstate 225B
CL.read.1.tlog 28KB
main.obj 3.36MB
StandUp.log 334B
Debug
vc141.pdb 1.84MB
vc141.idb 611KB
StandUp.tlog
CL.write.1.tlog 2KB
CL.command.1.tlog 1KB
link.command.1.tlog 3KB
link.read.1.tlog 3KB
link.write.1.tlog 774B
StandUp.lastbuildstate 223B
CL.read.1.tlog 28KB
FaceRecognition.obj 2KB
main.obj 494KB
StandUp.log 109B
header.h 187B
StandUp.vcxproj.filters 1KB
haarcascade_frontalcatface.xml 402KB
StandUp.vcxproj.user 165B
notification.py 172B
StandUp.vcxproj 6KB
x64
Debug
StandUp.pdb 1.04MB
StandUp.ilk 814KB
StandUp.exe 139KB
47455642_p0.png 3.54MB
StandUp.sln 1KB
.gitignore 270B
171265889347208773632.zip 416B
共 38 条
- 1
资源评论
不走小道
- 粉丝: 3225
- 资源: 5113
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功