当前位置: 首页 > news >正文

第14课 利用openCV快速数豆豆

除了检测运动,openCV还能做许多有趣且实用的事情。其实openCV和FFmpeg一样都是宝藏开源项目,貌似简单的几行代码功能实现背后其实是复杂的算法在支撑。有志于深入学习的同学可以在入门后进一步研究算法的实现,一定会受益匪浅。

这节课,我们先来看一个简单的例子:数豆豆。这个小例子可以让你领略openCV的强悍。

1.复制demo4并改名为demo14。

2.修改init函数:

//capCamHandle = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)capCamThread, (LPVOID)this, 0, NULL);
capImgHandle = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)capImgThread, (LPVOID)this, 0, NULL);

3.添加对应的数豆豆函数:

DWORD WINAPI fmle::capImgThread(LPVOID lpParam) {fmle *pThis = (fmle*)lpParam;pThis->capImg();return 0;
}int fmle::capImg() {videoCap.open(0);cv::Mat imgMat;imgMat = cv::imread("Bean.jpg");// 转换为HSV颜色空间cv::Mat hsvMat;cv::cvtColor(imgMat, hsvMat, cv::COLOR_BGR2HSV);	// 定义黄色范围的HSV阈值cv::Scalar lowerColor(26, 43, 46);cv::Scalar upperColor(34, 255, 255);// 对图像进行颜色过滤cv::Mat maskMat;cv::inRange(hsvMat, lowerColor, upperColor, maskMat);// 对二值图像进行形态学操作,去除噪点cv::Mat kernel = cv::getStructuringElement(cv::MORPH_RECT, cv::Size(5, 5));cv::morphologyEx(maskMat, maskMat, cv::MORPH_OPEN, kernel);// 寻找轮廓std::vector<std::vector<cv::Point>> contours;cv::findContours(maskMat, contours, cv::RETR_EXTERNAL, cv::CHAIN_APPROX_SIMPLE);// 统计豆子数量int beanCount = contours.size();cv::Mat resultMat = imgMat.clone();cv::drawContours(resultMat, contours, -1, cv::Scalar(0, 0, 255), 2);cv::putText(resultMat, "Total: " + std::to_string(beanCount), cv::Point(0, 290), cv::FONT_HERSHEY_SIMPLEX, 1, cv::Scalar(255, 255, 255), 2);mainDlg->drawMatOfPub(resultMat);return 0;
}

4.调试运行,豆豆数量立即就显示出来了,是不是很简单?

http://www.lryc.cn/news/274753.html

相关文章:

  • 在前端利用Broadcast Channel实现浏览器跨 Tab 窗口通信的方法
  • 【Apache Doris】自定义函数之 JAVA UDF 详解
  • BMS电池管理系统带充放电控制过流过压保护
  • 在Linux中以后台静默运行Java应用程序
  • k8s---Pod的生命周期
  • CSS animation动画和关键帧实现轮播图效果HTML
  • Unity之键盘鼠标的监控
  • C# windows服务程序开机自启动exe程序
  • 【SpringMVC】常用注解
  • 关于曲率、曲率半径和曲率圆,看这几篇文章就够啦
  • java面试题-Spring常见的异常类有哪些?
  • 数据库选择题 (期末复习)
  • WeNet语音识别+Qwen-72B-Chat Bot+Sambert-Hifigan语音合成
  • 是否需要跟上鸿蒙(OpenHarmony)开发岗位热潮?
  • 【Golang】Json 无法表示 float64 类型的 NaN 以及 Inf 导致的 panic
  • bootstrap5实现宠物商店网站 Cat-Master
  • 基于多反应堆的高并发服务器【C/C++/Reactor】(中)创建并初始化TcpServer实例 以及 启动
  • 边缘计算设备是什么意思。
  • 使用ChatGPT midjourney 等AI智能工具,能为视觉营销做些什么?
  • 图像分割实战-系列教程4:unet医学细胞分割实战2(医学数据集、图像分割、语义分割、unet网络、代码逐行解读)
  • 防火墙未开端口导致zookeeper集群异常,kafka起不来
  • React-hook-form-mui(二):表单数据处理
  • java网络文件地址url的转换为MultipartFile文件流
  • JS实现/封装节流函数
  • ENVI 各版本安装指南
  • 60天零基础干翻C++————初识C++
  • 考研复试英语口语问答举例第二弹
  • MyBatis-Plus实现自定义SQL语句的分页查询
  • vue3 里的 ts 类型工具函数
  • 【SpringCloud】之远程消费(进阶使用)