深度相机获取实时图像总结

问题详情:之前一直把曝光调整到50000,画面一直很流畅,知道领导要求将曝光改成500000时整个程序卡死了

问题解决:

首先怀疑是帧率太低的原因,控制变量后发现不是帧率的问题,看着代码很迷茫,领导就看了我完整的代码,找到了bug,让人恍然大悟。

大家先看看错误代码:calibHMI是我的主类,PICThread是我的线程类

线程创建和触发代码:当发出信号returnResult,就执行displayResult。

复制代码
    thread=new PICThread();
    connect(thread, SIGNAL(returnResult(int)), this, SLOT(displayResult(int)));//信号槽

/*信号回调*/
void calibHMI::displayResult(int result)
{
    Camera.GetGrayImage(gray);
    if(!gray.empty())
        {
            gray.copyTo(grayCopy);
            cv::resize(grayCopy, grayCopy, cv::Size(gray.cols / 6, gray.rows / 6));

            qImage = QImage((const unsigned char*)(grayCopy.data),
                                   grayCopy.cols, grayCopy.rows,
                                   grayCopy.cols * grayCopy.elemSize(),
                                   QImage::Format_Grayscale8);

            // 如果需要,从QImage创建QPixmap
            QPixmap pixmap = QPixmap::fromImage(qImage);

            // 或者,直接在QLabel中设置QImage(注意灰度图像不需要rgbSwapped())
            ui->label_6->setPixmap(QPixmap::fromImage(qImage));

        }


}
void calibHMI::closeEvent(QCloseEvent *event){

    qDebug("关闭主界面");
    thread->m_stopRequested = true;

}
//线程类
PICThread::PICThread(){

}
/*线程循环*/
void PICThread::run()
{
    int result=0;
    m_stopRequested = false; // 初始化停止标志为 false
    while (!m_stopRequested)
    {
        msleep(500);//延时0.5s 600-1000比较合适
        emit returnResult(result);  //发送信号
    }
}
/*线程停止*/
void PICThread::stop()
{
    m_stopRequested = true;
}

void calibHMI::on_pushButton_2_clicked()
{
    int Expose=ui->lineEdit->text().toInt();
    int rate =ui->lineEdit_2->text().toInt();
    Camera.ConfigEyeExpose(hDevice,keVzNLExposeMode_Fix,Expose);
    if(Camera.SetFrameRate(hDevice,rate)==0){
        std::cout<<"帧率设置成功!"<<std::endl;
    }
}

void calibHMI::on_pushButton_6_clicked()
{    static SVzNLROIRect sLeftROI = { 0, 1536, 0, 2048 };
     static SVzNLROIRect sRightROI = { 0, 1536, 0, 2048 };
     Camera.ConfigDetectROI(hDevice, &sLeftROI, &sRightROI);
     thread->start();
}

void calibHMI::on_pushButton_7_clicked()
{
    thread->stop();
}

答案:

run()是我的子线主要作用间隔一段时间发送信号触发displayResult,displayResult是在主线程中运行的,包括获取图像和显示图像

最最需要资源的获取图像程序在主线程中苦苦阻塞,那么只要把图线获取写入到run()中即可!并且将usleep(500)删除。

相关推荐
bkspiderx11 分钟前
C++中的volatile:从原理到实践的全面解析
开发语言·c++·volatile
君义_noip2 小时前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
liulilittle2 小时前
OPENPPP2 Code Analysis One
网络·c++·网络协议·信息与通信·通信
Morwit2 小时前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
天赐学c语言3 小时前
1.7 - 删除排序链表中的重要元素II && 哈希冲突常用解决冲突方法
数据结构·c++·链表·哈希算法·leecode
w陆压3 小时前
12.STL容器基础
c++·c++基础知识
龚礼鹏4 小时前
Android应用程序 c/c++ 崩溃排查流程二——AddressSanitizer工具使用
android·c语言·c++
qq_401700414 小时前
QT C++ 好看的连击动画组件
开发语言·c++·qt
一条咸鱼_SaltyFish4 小时前
[Day10] contract-management初期开发避坑指南:合同模块 DDD 架构规划的教训与调整
开发语言·经验分享·微服务·架构·bug·开源软件·ai编程
额呃呃4 小时前
STL内存分配器
开发语言·c++