海康工业相机SDK + OpenCV实例(3):

相机初始化Bug调试



文章目录

  • 海康工业相机SDK + OpenCV实例(3):
  • 相机初始化Bug调试
  • 前言
  • 一、心跳时间设置
  • 二、相机先关闭再打开



前言

前文海康工业相机SDK+OpenCV实例(2):RawDataFormatConvert详解中,以RawDataFormatConvert为例,讲解了海康工业相机的基本操作与转为Mat格式的操作。但是在实际应用中,相机开关初始化遇到了种种不便利的情况。
(1)调试时期,相机默认的心跳时间为60s,导致重启周期很长。
(2)当相机已经打开或者连接,再次访问,导致开机报错。
基于上述可能存在的问题,本文进行调试。


一、心跳时间设置

相机在调试过程,在程序中,若相机已经开机,如果在程序异常退出前相机没有进行相应的关机操作,会导致一段时间内相机无法连接,这个时间就叫心跳时间。海康相机默认的心跳时间为60s,这意味着如果程序异常跳出,海康相机60s内不能重新进行连接,这会给相机的调试带来困扰。
海康工业相机SDK提供了心跳时间HeartBeatTimeout设置的接口MV_CC_SetHeartBeatTimeout,可以在相机开机后加入下述程序段,设置心跳时间为3s(心跳时间的最小值为500ms)。

int HeartBeatTimeout = 3000;
        nRet = MV_CC_SetHeartBeatTimeout(handle, HeartBeatTimeout);
        if (MV_OK != nRet)
        {
            printf("Set HeartBeatTimeout fail! nRet [0x%x]\n", nRet);
        }

尽管重新设置了心跳时间,但也不排除在极短的心跳时间内,程序需要重新启动。我们可以通过一个判断设备是否可达的接口MV_CC_IsDeviceAccessible,倘若当前相机仍然处于心跳时间内,程序会自动等待心跳时间。

nRet = MV_CC_IsDeviceAccessible(stDeviceList.pDeviceInfo[nIndex], MV_ACCESS_Exclusive);
        if (nRet == 0) Sleep(3000);

MV_ACCESS_Exclusive是一种相机访问模式,具体种类可详见于SDK。


二、相机先关闭再打开

当相机已经在服务端被打开,客户端初次连接后,倘若客户端异常跳出,没有下达相机关闭指令,当客户端再次尝试连接相机时,由于相机已经打开,会有相机开机异常的报错。
因此,我们可以尝试在每次连接相机之前,先调用判断相机连接状态的接口MV_CC_IsDeviceConnected,倘若相机已经连接,尝试先关闭再打开相机;倘若,相机没有连接,直接打开相机。

//判断设备是否已经连接,如果已经连接,尝试先关闭相机
        nRet = MV_CC_IsDeviceConnected(handle);
        if (nRet == 1)
        {
            nRet = MV_CC_CloseDevice(handle);
            if (MV_OK != nRet)
            {
                printf("ClosDevice fail! nRet [0x%x]\n", nRet);
            }
        }
        //创建句柄,打开设备
        nRet = MV_CC_CreateHandle(&handle, stDeviceList.pDeviceInfo[nIndex]);
        if (MV_OK != nRet)
        {
            printf("Create Handle fail! nRet [0x%x]\n", nRet);
        }
        nRet = MV_CC_OpenDevice(handle);
        if (MV_OK != nRet)
        {
            printf("Open Device fail! nRet [0x%x]\n", nRet);
        }