海康工业相机SDK二次开发(VS+QT+海康SDK+C++)

海康工业相机SDK二次开发(VS+QT+海康SDK+C++)

前言

工业相机在现代制造和工业自动化中扮演了至关重要的角色,尤其是在高精度、高速度检测中。海康威视工业相机以其性能稳定、图像质量高、兼容性强而受到广泛青睐。特别是搞机器视觉的小伙伴们跟海康打交道肯定不在少数,笔者在平常项目中跟海康相关人员对接也是比较多。

那么,本文将全面介绍如何基于海康工业相机的 SDK,使用 Visual Studio 和 Qt 构建上位机程序,逐步实现工业相机的图像采集、显示以及参数配置。

以下是巴斯勒相机开发

巴斯勒工业相机SDK二次开发(VS+QT+巴斯勒SDK+C++)-ZEEKLOG博客

一、海康工业相机简介

1. 工业相机的主要功能

  • 图像采集:捕获高速、高清的静态或动态图像。
  • 高速传输:通过 GigE 或 USB 接口将图像传输到上位机。
  • 稳定运行:设计用于工业环境,具有高可靠性。

2. 海康工业相机优势

  • 高分辨率:支持从 0.3MP 到 50MP 的分辨率。
  • 多接口:支持 USB 3.0、GigE、Camera Link 等多种接口。
  • 全面 SDK 支持:提供多平台(Windows、Linux)的 SDK,支持 C++、C#、Python 等多种语言。

3. 常见型号

包含USB以及GigE 系列:

  • MV-CA060-10GC:分辨率 0.6MP,帧率 100fps。
  • MV-CH120-20UC:分辨率 12MP,帧率 20fps。

二、海康工业相机SDK下载 

1.客户端下载

海康工业相机的sdk是跟随其上位机一起打包安装,我们只需要下载客户端安装即可。进入海康机器人官网,下载中心可以看到包括工业相机、读码器系列产品的客户端程序。我们选择下载最新4.40版本的客户端,按照默认步骤安装即可。

2.SDK浅析 

 安装完客户端后,打开安装目录。在Development文件内可以看见这几个文件夹,其中includes以及Libraries就包含了我们二次开发所需要用到的头文件、库文件以及附加依赖项。

简要说明:

Bin:已封装的可执行程序exe,包括win32、win64

Documentations:开发指南说明

DotNet:.NET Framework框架

Includes:头文件

Libraries:库文件

MVFG:采集卡

Samples:例程,包含c#、python、halcon、c++等多种语言

ThirdPartyPlatformAdapter:第三方平台

 三、项目创建与配置

开发环境操作系统:Windows开发工具:Visual Studio 2022图形界面库:Qt 5.14图像处理库:OpenCV 4.10其他:C++编程语言 

1. 新建 Qt 项目

在 Visual Studio 中创建基于 Qt 的 C++ 项目:

  1. 打开 Visual Studio,点击 新建项目
  2. 选择 Qt Widgets Application,设置项目名称和路径。

2. 添加海康 SDK以及OpenCV

(1) 添加头文件路径

在项目属性中:

  • 右键项目,选择 属性 > C/C++ > 常规 > 附加包含目录
  • 添加 SDK 的 Include 目录路径。

(2) 链接库文件

在项目属性中:

  • 进入 链接器 > 常规 > 附加库目录,添加 SDK 的 Lib 目录。
  • 链接器 > 输入 > 附加依赖项 中添加库文件:

 OpenCV的详细下载以及配置过程可以参考我这篇文章:QT+OpenCV+Zbar实现二维码识别_opencv zbar-ZEEKLOG博客文章浏览阅读705次,点赞16次,收藏17次。通过整合Qt、Zbar和OpenCV,我们实现了一个简单的二维码识别系统。OpenCV提供了图像处理和文件读取的支持,Zbar则负责解码二维码内容。这种组合方案为二维码识别提供了高效的实现途径,特别适合桌面应用和需要图像预处理的项目。t=O83A。_opencv zbarhttps://blog.ZEEKLOG.net/weixin_44765053/article/details/143659239?spm=1001.2014.3001.5502

 四、系统实现

1.ui设计

ui界面仿照bin文件夹里面已经打包好的exe程序设计,实现相关功能。

包括:

QLabel:显示相机图像

QComboBox:显示搜索到的设备列表

QPushButton:搜索设备、开关设备、设置参数等功能

QRadioButton:切换图像采集模式

QCheckBox:软触发使能

2.主要功能实现

海康工业相机SDK主动取流流程如下所示:

详细步骤:

  1. 调用 MV_CC_Initialize() 初始化该SDK的运行环境,以便于提前申请和分配所必须的系统资源。
  2. (可选)调用 MV_CC_EnumDevices() 枚举子网内指定传输协议对应的所有设备。 可通过nTLayerType在结构 MV_CC_DEVICE_INFO() 中获取设备信息。
  3. (可选)打开指定设备前,调用 MV_CC_IsDeviceAccessible() 检查指定设备是否可访问。
  4. 调用 MV_CC_CreateHandle() 创建设备句柄。
  5. 调用 MV_CC_OpenDevice() 打开设备。
  6. (可选)执行以下一个或多个操作以获取/设置相机不同类型的参数。
    • 获取/设置Int类型节点值:调用 MV_CC_GetIntValue() / MV_CC_SetIntValue()
    • 获取/设置Float类型节点值:调用 MV_CC_GetFloatValue() / MV_CC_SetFloatValue()
    • 获取/设置Enum类型节点值:调用 MV_CC_GetEnumValue() / MV_CC_SetEnumValue()
    • 获取/设置Bool类型节点值:调用 MV_CC_GetBoolValue() / MV_CC_SetBoolValue()
    • 获取/设置String类型节点值:调用 MV_CC_GetStringValue() / MV_CC_SetStringValue()
    • 设置Command类型节点值:调用 MV_CC_SetCommandValue()
  7. 图像采集:
    • (可选)调用 MV_CC_SetImageNodeNum() 设置图像缓存节点个数。当获取的图像数超过这个设定值,最早的图像数据会被自动丢弃。
    • 调用 MV_CC_StartGrabbing() 开始取流。
    • 对于原始图像数据,可调用 MV_CC_ConvertPixelTypeEx() 转换图像的像素格式,也可调用 MV_CC_SaveImageEx3() 转换成JPEG或BMP格式的图片,并保存成图片文件。
    • 在应用程序层中重复调用 MV_CC_GetOneFrameTimeout() 来获取图片数据。
  8. 调用 MV_CC_StopGrabbing() 停止采集。
  9. 调用 MV_CC_CloseDevice() 关闭设备。
  10. 调用 MV_CC_DestroyHandle() 销毁句柄并释放资源。
  11. 调用 MV_CC_Finalize() 释放SDK资源。

①初始化SDK

 nRet = MV_CC_Initialize(); if (MV_OK != nRet) { printf("Initialize SDK fail! nRet [0x%x]\n", nRet); break; } 

②枚举设备

 // ch:枚举设备 | en:Enum device MV_CC_DEVICE_INFO_LIST stDeviceList; memset(&stDeviceList, 0, sizeof(MV_CC_DEVICE_INFO_LIST)); nRet = MV_CC_EnumDevices(MV_GIGE_DEVICE | MV_USB_DEVICE | MV_GENTL_CAMERALINK_DEVICE | MV_GENTL_CXP_DEVICE | MV_GENTL_XOF_DEVICE, &stDeviceList); if (MV_OK != nRet) { printf("Enum Devices fail! nRet [0x%x]\n", nRet); break; } if (stDeviceList.nDeviceNum > 0) { for (unsigned int i = 0; i < stDeviceList.nDeviceNum; i++) { printf("[device %d]:\n", i); MV_CC_DEVICE_INFO* pDeviceInfo = stDeviceList.pDeviceInfo[i]; if (NULL == pDeviceInfo) { break; } PrintDeviceInfo(pDeviceInfo); } } else { printf("Find No Devices!\n"); break; } 

③创建设备句柄

 // ch:选择设备并创建句柄 | en:Select device and create handle nRet = MV_CC_CreateHandle(&handle, stDeviceList.pDeviceInfo[nIndex]); if (MV_OK != nRet) { printf("Create Handle fail! nRet [0x%x]\n", nRet); break; } 

④打开设备

 // ch:打开设备 | en:Open device nRet = MV_CC_OpenDevice(handle); if (MV_OK != nRet) { printf("Open Device fail! nRet [0x%x]\n", nRet); break; } 

⑤图像取流

// ch:开始取流 | en:Start grab image nRet = MV_CC_StartGrabbing(handle); if (MV_OK != nRet) { printf("Start Grabbing fail! nRet [0x%x]\n", nRet); break; } 

五、系统效果

1.搜索设备显示在QComboBox并点击打开。

查找打开设备

2.连续、触发模式实现图像采集 

连续、触发采集

3.修改曝光、增益等出图参数

参数修改

 4.保存图片为jpg、bmp等格式

图片保存

顺带说一嘴,这个蜂蜜雀氏不错,冬天泡水喝暖暖的很贴心哈哈哈哈哈。 决非广告,但是背景太假哥给我打钱也不是不阔以!!!

六、总结 

通过本文,完成了从环境配置到功能实现的完整开发流程。在此基础上,可以扩展更多功能,如多相机支持、图像处理、结合halcon、opencv检测等。

如有问题,欢迎评论区讨论!如果本文对您有帮助,请点赞支持!

可以关注我一下子,敬请期待后续功能实现~

Read more

【C++:哈希表】从哈希冲突到负载因子:熟悉哈希表的核心机制

【C++:哈希表】从哈希冲突到负载因子:熟悉哈希表的核心机制

🔥艾莉丝努力练剑:个人主页 ❄专栏传送门:《C语言》、《数据结构与算法》、C/C++干货分享&学习过程记录、Linux操作系统编程详解、笔试/面试常见算法:从基础到进阶、测试开发要点全知道 ⭐️为天地立心,为生民立命,为往圣继绝学,为万世开太平 🎬艾莉丝的简介: 🎬艾莉丝的C++专栏简介: 目录 C++的两个参考文档 前情提示 1  ~>  初始哈希 2  ~>  直接定址法 2.1  概念 2.2  示例:字符串中的第一个唯一字符 3  ~>  哈希的一些概念 3.1  哈希冲突 3.2  负载因子 3.3

By Ne0inhk
【高阶数据结构】二叉搜索树

【高阶数据结构】二叉搜索树

二叉搜索树 * 1.二叉搜索树的概念 * 2.二叉搜索树的性能分析 * 3.二叉搜索树的实现 * 1.二叉搜索树的结构 * 2.二叉搜索树的插入 * 3.二叉搜索树的查找 * 4.二叉搜索树的删除 * 5.二叉搜索树的中序遍历 * 6.默认构造 * 7.拷贝构造 * 8.赋值重载 * 9.析构函数 * 4.二叉搜索树key和key/value使用场景 * 1.key搜索场景(set容器) * 2.key/value搜索场景(map容器) * 5.key二叉搜索树代码 * 6.key/value二叉搜索树代码 1.二叉搜索树的概念 二叉搜索树又称搜索二叉树,它或者是一棵空树,或者是具有以下性质的⼆叉树: 若它的左子树不为空,则左子树上所有结点的值都小于等于根结点的值。若它的右子树不为空,则右子树上所有结点的值都大于等于根结点的值。

By Ne0inhk
重生之我在异世界学编程之算法与数据结构:深入静态顺序表篇

重生之我在异世界学编程之算法与数据结构:深入静态顺序表篇

大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在ZEEKLOG这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 本文目录 * 引言 * 正文 * 一、顺序表的概念及结构 * 1. 顺序表的定义 * 2. 顺序表的结构 * 3. 顺序表的初始化 * 二、顺序表的基本操作(静态) * 1. 插入操作 * 2. 删除操作 * 3. 查找操作 * 4. 更新操作 * 5. 获取元素操作 * 6. 遍历操作 * 7. 求顺序表的长度 * 8. 判断顺序表是否为空 * 快乐的时光总是短暂,咱们下篇博文再见啦!!!在下一篇博文,小编将会带着宝子们学习动态顺序表,敬请期待吧!!!不要忘了,给小编点点赞和收藏支持一下,在此非常感谢!!! 引言 C语言顺序表(Sequential List)是一种线性表的存储结构,

By Ne0inhk
【递归,搜索与回溯算法篇】专题(一) - 递归

【递归,搜索与回溯算法篇】专题(一) - 递归

文章目录 * 面试题 08.06. 汉诺塔问题 * 21. 合并两个有序链表 * 206. 反转链表 * 24. 两两交换链表中的节点 * 50. Pow(x, n) 面试题 08.06. 汉诺塔问题 题目链接:面试题 08.06. 汉诺塔问题 题目描述: 在经典汉诺塔问题中,有 3 根柱子及 N 个不同大小的穿孔圆盘,盘子可以滑入任意一根柱子。一开始,所有盘子自上而下按升序依次套在第一根柱子上(即每一个盘子只能放在更大的盘子上面)。移动圆盘时受到以下限制: (1) 每次只能移动一个盘子; (2) 盘子只能从柱子顶端滑出移到下一根柱子; (3) 盘子只能叠在比它大的盘子上。 请编写程序,用栈将所有盘子从第一根柱子移到最后一根柱子。 你需要原地修改栈。 示例 1: 输入:A = [2,

By Ne0inhk