Qt/C++ 基于回调模式的海康3D相机开发流程详解(附工程源码、开发文档下载链接)

本文将基于海康3D相机SDK的回调模式,通过具体代码讲解如何完成从设备初始化到图像采集的完整流程。以下是标准的流程图和具体的开发步骤。


一、开发流程概述

流程分为以下几个关键步骤:

  1. 运行环境初始化 :调用MV3D_LP_Initialize(),初始化SDK运行环境。
  2. 设备发现 :调用MV3D_LP_GetDeviceNumber()MV3D_LP_GetDeviceList(),获取设备数量和设备列表。
  3. 设备连接 :通过MV3D_LP_OpenDeviceBySN()MV3D_LP_OpenDeviceByIp()连接设备。
  4. 参数管理 (可选):通过MV3D_LP_GetParam()获取参数,或通过MV3D_LP_SetParam()设置参数。
  5. 注册回调:注册异常消息和图像数据的回调函数。
  6. 采集启动与停止 :调用MV3D_LP_StartMeasure()MV3D_LP_StopMeasure(),控制设备工作。
  7. 关闭设备与环境释放 :调用MV3D_LP_CloseDevice()MV3D_LP_Finalize()完成设备关闭与资源释放。

流程图如下:


二、完整开发代码详解

1. 初始化运行环境

在应用启动时,首先调用MV3D_LP_Initialize()进行SDK环境的初始化。如果初始化失败,需要及时退出并提示用户。

cpp 复制代码
if (MV3D_LP_Initialize() != MV3D_LP_OK) {
    qDebug() << "SDK运行环境初始化失败";
    return;
}
qDebug() << "SDK运行环境初始化成功";

2. 获取设备列表

通过MV3D_LP_GetDeviceNumber()获取设备数量,然后调用MV3D_LP_GetDeviceList()获取设备的详细信息,并在界面显示。

cpp 复制代码
MV3D_LP_DEVICE_INFO deviceInfos[16];
uint32_t deviceCount = 0;

// 获取设备数量和列表
if (MV3D_LP_GetDeviceList(deviceInfos, 16, &deviceCount) == MV3D_LP_OK) {
    qDebug() << "发现设备数量:" << deviceCount;
    for (uint32_t i = 0; i < deviceCount; i++) {
        qDebug() << "设备序号:" << i
                 << "型号:" << deviceInfos[i].chModelName
                 << "序列号:" << deviceInfos[i].chSerialNumber;
    }
} else {
    qDebug() << "获取设备列表失败";
}

3. 打开设备

支持两种方式连接设备:

  • 通过序列号打开 :使用MV3D_LP_OpenDeviceBySN()
  • 通过IP地址打开 :使用MV3D_LP_OpenDeviceByIp()

代码示例:

cpp 复制代码
char* deviceSN = "输入设备序列号";
MV3D_LP_HANDLE handle;

// 通过序列号打开设备
if (MV3D_LP_OpenDeviceBySN(&handle, deviceSN) != MV3D_LP_OK) {
    qDebug() << "设备打开失败";
    return;
}
qDebug() << "设备打开成功";

4. 注册回调函数
  • 异常消息回调 :通过MV3D_LP_RegisterExceptionCallBack(),实时监控设备异常。
  • 图像数据回调 :通过MV3D_LP_RegisterImageDataCallBack(),处理图像数据。

示例代码:

cpp 复制代码
// 注册异常回调
if (MV3D_LP_RegisterExceptionCallBack(handle, ExceptionCallBackFunc, nullptr) != MV3D_LP_OK) {
    qDebug() << "注册异常回调失败";
}

// 注册图像数据回调
if (MV3D_LP_RegisterImageDataCallBack(handle, ImageCallBackFunc, this) != MV3D_LP_OK) {
    qDebug() << "注册图像回调失败";
}

5. 启动采集

启动采集调用MV3D_LP_StartMeasure(),停止采集调用MV3D_LP_StopMeasure()

采集启动代码:

cpp 复制代码
if (MV3D_LP_StartMeasure(handle) != MV3D_LP_OK) {
    qDebug() << "采集启动失败";
} else {
    qDebug() << "采集启动成功";
}

采集停止代码:

cpp 复制代码
if (MV3D_LP_StopMeasure(handle) != MV3D_LP_OK) {
    qDebug() << "停止采集失败";
} else {
    qDebug() << "停止采集成功";
}

6. 回调函数实现

图像数据回调

在回调中处理采集的图像数据,并使用Halcon生成图像对象:

cpp 复制代码
void __stdcall ImageCallBackFunc(MV3D_LP_IMAGE_DATA* imageData, void* user) {
    if (!imageData || !imageData->bValid) {
        qDebug() << "无效的图像数据";
        return;
    }

    HObject hImage;
    try {
        // 根据图像类型生成Halcon图像对象
        if (imageData->enImageType == ImageType_Mono8) {
            HalconCpp::GenImage1(&hImage, "byte", imageData->nWidth, imageData->nHeight, reinterpret_cast<Hlong>(imageData->pData));
        } else if (imageData->enImageType == ImageType_RGB24_Packed) {
            HalconCpp::GenImageInterleaved(&hImage, reinterpret_cast<Hlong>(imageData->pData), "rgb", imageData->nWidth, imageData->nHeight, -1, "byte", 0, 0, 0, 0, -1, 0);
        }
        // 在界面显示图像
        emit static_cast<MainWindow*>(user)->dispImage(hImage, "图像数据");
    } catch (HException& e) {
        qDebug() << "图像处理失败:" << e.ErrorMessage().Text();
    }
}

7. 关闭设备与释放环境

在程序退出时,必须关闭设备并释放运行环境:

cpp 复制代码
if (MV3D_LP_CloseDevice(&handle) != MV3D_LP_OK) {
    qDebug() << "设备关闭失败";
} else {
    qDebug() << "设备关闭成功";
}

MV3D_LP_Finalize();  // 释放SDK环境
qDebug() << "SDK资源释放完成";

三、资源下载

为了方便开发者快速上手,我们提供了完整的工程源码和开发手册,包含以下内容:

  • 工程源码:基于Qt + Halcon + 海康3D相机SDK的完整项目代码。
  • 开发手册:海康3D相机的官方开发文档,详细描述SDK API的使用方法及示例。

您可以通过以下网盘链接下载:


相关推荐
Alidme2 分钟前
cs106x-lecture14(Autumn 2017)-SPL实现
c++·学习·算法·codestepbystep·cs106x
小王努力学编程3 分钟前
【算法与数据结构】单调队列
数据结构·c++·学习·算法·leetcode
牵牛老人1 小时前
Qt开发中出现中文乱码问题深度解析与解决方案
开发语言·qt
Zfox_1 小时前
【QT】信号与槽 & 窗口坐标
开发语言·c++·qt·qt5
tekin3 小时前
Go、Java、Python、C/C++、PHP、Rust 语言全方位对比分析
java·c++·golang·编程语言对比·python 语言·php 语言·编程适用场景
小禾苗_4 小时前
C++ ——继承
开发语言·c++
进击ing小白4 小时前
Qt程序退出相关资源释放问题
开发语言·qt
OrangeJiuce5 小时前
【QT中的一些高级数据结构,持续更新中...】
数据结构·c++·qt
程序员-King.8 小时前
【接口封装】——13、登录窗口的标题栏内容设置
c++·qt
萌の鱼8 小时前
leetcode 2826. 将三个组排序
数据结构·c++·算法·leetcode