如何使用由指向视频数据的指针创建的 cv::Mat imgbuf

how to use cv::Mat imgbuf created by pointer to video data

我正在使用

从读取缓冲区读取原始视频数据
cv::Mat imgbuf(Size(640, 480), CV_8UC3, &mem[0], (640*3));

这个变量 imgbuf 我正在传递给检测面部并在面部周围绘制矩形的面部检测算法。之后我得到类似

的输出

我尝试使用以下代码执行 调整大小操作,然后再传递给面部检测算法。通过使用这种方法,它工作正常。但没有调整大小功能,我得到明显的输出,面部周围有矩形。

 while(1)
 {
 unsigned char *mem = (unsigned char*)mmap(NULL, page_offset + len,
 PROT_READ |PROT_WRITE, MAP_PRIVATE, fd, page_base); 
 cv::Mat imgbuf(Size(640, 480), CV_8UC3, &mem[0], (640*3));

 cv::resize(imgbuf,imgbuf,(640,480)); //Dummy function to get the right output.


 auto result = v->facedetection(imgbuf);
    for (const auto &r : result.rects) {
 cv::rectangle(imgbuf,cv::Rect{ cv::Point(r.x * imgbuf.cols, r.y * 
 imgbuf.rows),cv::Size{(int)(r.width * imgbuf.cols), (int)(r.height * 
   imgbuf.rows) } },0xff);

   }
  imshow("face-detection", imgbuf);
  waitKey(1);

谁能帮忙解决这个问题

测试此方法:

unsigned char *mem = (unsigned char*)mmap(NULL, page_offset + len,
 PROT_READ |PROT_WRITE, MAP_PRIVATE, fd, page_base); 

cv::Mat imgbuf(480,640, CV_8UC3, &mem[0]);
cv::Mat img_2, img_3;
cv::resize(imgbuf,img_2,cv::Size(640,480));
img_2.copyTo(img_3);
auto result = v->facedetection(img_2);

for (const auto &r : result.rects)
{
   cv::Rect myR = cv::Rect(r.x * img_2.cols, r.y * img_2.rows, (int)(r.width * img_2.cols), 
   (int)(r.height * img_2.rows));

   cv::rectangle(img_3,myR,Scalar(0, 0, 255), 1);
}
imshow("Result", img_3);
waitKey(0);

获得有效结果后,您可以优化它并使用更少的 "Mat"s。