一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 578万

一、功能

这里的需求是,判断摄像头有没有被物体遮挡。这里只考虑用手遮挡---->判断黑色颜色的范围。

二、使用OpenCV的Mat格式图片遍历图片

下面代码里,传入的图片的尺寸是640*480,判断黑色范围。

复制代码
 1 /*
 2 在图片里查找指定颜色的比例
 3 */
 4 int Widget::Mat_color_Find(QImage qimage)
 5 {
 6   Mat image = QImage2cvMat(qimage);//将图片加载进来
 7   int num = 0;//记录颜色的像素点
 8   float rate;//要计算的百分率
 9   //遍历图片的每一个像素点
10   for(int i = 0; i < image.rows;i++) //行数
11   {
12    for(int j = 0; j <image.cols;j++) //列数
13    {
14     //对该像素是否为指定颜色进行判断 BGR 像素点
15     //OpenCV 中 MAT类的默认三原色通道顺序BGR
16     /*
17    动态地址访问像素语法:image.at<Vec3b>(i,j)[0]、image.at<uchar>(i, j)
18    访问三通道图像的单个像素:
19    int b = image.at<Vec3b>(i, j)[0];
20    int g = image.at<Vec3b>(i, j)[1];
21    int r = image.at<Vec3b>(i, j)[2];
22    对于三通道图像,每个像素存储了三个值,分别为蓝色、绿色、红色通道上的数值。
23    int gray_data = image.at<uchar>(i, j);
24    用来访问灰度图像的单个像素。对于灰度图像,每个像素只存储一个值
25    */
26     if((image.at<Vec3b>(i, j)[0] <= 120 &&
27      image.at<Vec3b>(i, j)[1] <= 120 &&
28      image.at<Vec3b>(i, j)[2] <= 120))
29     {
30      num++;
31     }
32    }
33   }
34   rate = (float)num / (float)(image.rows * image.cols);
35  
36   //阀值为 0.249255 表示为全黑
37   if(rate>0.20)
38   {
39    qDebug()<<":Mat:故意遮挡摄像头";
40   }
41   qDebug()<<"Mat:比例"<<rate;
42   return 0;
43 }
44  
45  
46 Mat Widget::QImage2cvMat(QImage image)
47 {
48  Mat mat;
49  switch(image.format())
50  {
51  case QImage::Format_ARGB32:
52  case QImage::Format_RGB32:
53  case QImage::Format_ARGB32_Premultiplied:
54   mat = Mat(image.height(), image.width(), CV_8UC4, (void*)image.constBits(), image.bytesPerLine());
55   break;
56  case QImage::Format_RGB888:
57   mat = Mat(image.height(), image.width(), CV_8UC3, (void*)image.constBits(), image.bytesPerLine());
58   cvtColor(mat, mat, CV_BGR2RGB);
59   break;
60  case QImage::Format_Indexed8:
61   mat = Mat(image.height(), image.width(), CV_8UC1, (void*)image.constBits(), image.bytesPerLine());
62   break;
63  }
64  return mat;
65 }
复制代码

 

posted on   一杯清酒邀明月  阅读(1097)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示