Ubuntu 连接海康智能相机步骤(亲测,成功读码)

ubuntu20.04下连接海康智能相机

    • Ubuntu 连接海康智能相机步骤(亲测,已成功读码)
    • 输出的结果

Ubuntu 连接海康智能相机步骤(亲测,已成功读码)

(就是按照海康的提供的步骤和源码连接相机,流水账)

  1. 安装Ubuntu20.04
  2. 安装gcc和g++,IDmvs只提供了C代码,所以需要自己make编译,自己去搜下怎么安装。
  3. 官网下载IDMVS软件,进入海康机器人页面,进入下载选项,,选择客户端下载,第二页,选择里面的IDMVS(linux)
  4. 解压安装,我是用deb文件安装的,选择X86_64版本。
  5. 安装完成后,在菜单栏里面有IDMVS图标,可以直接打开,或者进入/opt/IDMVS/bin/,运行./IDMVS.sh,两种方法都能打开客户端。
  6. 连接相机,如果没有找到相机你可以在windows上先连下相机试试,然后设定固定IP,连接相机
  7. 连上之后,进入/opt/IDMVS/有个demo的文件夹,具体在哪里忘记了,可以找一下,
  8. IDMVS只提供了两个demo,进入/GrabImage/目录下,应该只有两个文件,一个GrabImage.c,一个makefile。

在这里插入图片描述

  1. 然后把上级目录下的/sdk/里面的.so文件放到/GrabImage/目录下。
  2. 然后sudo make(如果你之前装好了g++和gcc,应该可以make成功)
  3. 执行生成后的文件。./GrabImage,就OK了,选择你想要连接的相机。就能看到获取到的结果了。

以下是GrabImage.c的代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>#include <cstdlib>
#include <string>
#include <iconv.h>#include "MvCodeReaderParams.h"
#include "MvCodeReaderErrorDefine.h"
#include "MvCodeReaderCtrl.h"bool g_bExit = false;
// ch:中文转换条码长度定义 | en:Chinese coding format len
#define MAX_BCR_LEN  512// ch:中文编码GB2312格式转换UTF_8 | en: Chinese coding format GB2312 to utf_8
int GB2312ToUTF8(char* szSrc, size_t iSrcLen, char* szDst, size_t iDstLen)
{iconv_t cd = iconv_open("utf-8//IGNORE", "gb2312//IGNORE");if(0 == cd){return -2;  }memset(szDst, 0, iDstLen);char **src = &szSrc;char **dst = &szDst;if(-1 == (int)iconv(cd, src, &iSrcLen, dst, &iDstLen)){return -1; }iconv_close(cd);return 0;
}// ch:等待用户输入enter键来结束取流或结束程序
// en:wait for user to input enter to stop grabbing or end the sample program
void PressEnterToExit(void)
{int c;while ( (c = getchar()) != '\n' && c != EOF );fprintf( stderr, "\nPress Enter to exit.\n");while( getchar() != '\n');g_bExit = true;usleep(1);
}// ch:打印设备信息 | en:Print device Info
bool PrintDeviceInfo(MV_CODEREADER_DEVICE_INFO* pstMVDevInfo)
{if (NULL == pstMVDevInfo){printf("The Pointer of pstMVDevInfo is NULL!\r\n");return false;}if (MV_CODEREADER_GIGE_DEVICE == pstMVDevInfo->nTLayerType){int nIp1 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0xff000000) >> 24);int nIp2 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x00ff0000) >> 16);int nIp3 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x0000ff00) >> 8);int nIp4 = (pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x000000ff);// ch:打印当前相机ip和用户自定义名字 | en:print current ip and user defined nameprintf("CurrentIp: %d.%d.%d.%d\r\n" , nIp1, nIp2, nIp3, nIp4);printf("UserDefinedName: %s\r\n\n" , pstMVDevInfo->SpecialInfo.stGigEInfo.chUserDefinedName);}else if (MV_CODEREADER_USB_DEVICE == pstMVDevInfo->nTLayerType){printf("UserDefinedName: %s\r\n\n", pstMVDevInfo->SpecialInfo.stUsb3VInfo.chUserDefinedName);}else{printf("Not support.\r\n");}return true;
}// ch:获取图像线程 | en:Get Image Thread
static void* GrabImageThread(void* pUser)
{int nRet = MV_CODEREADER_OK;MV_CODEREADER_IMAGE_OUT_INFO_EX2 stImageInfo = {0};memset(&stImageInfo, 0, sizeof(MV_CODEREADER_IMAGE_OUT_INFO_EX2));unsigned char * pData = NULL;while(1){if (g_bExit){break;}nRet = MV_CODEREADER_GetOneFrameTimeoutEx2(pUser, &pData, &stImageInfo, 1000);if (nRet == MV_CODEREADER_OK){MV_CODEREADER_RESULT_BCR_EX* stBcrResult = (MV_CODEREADER_RESULT_BCR_EX*)stImageInfo.pstCodeListEx;printf("Get One Frame: nChannelID[%d] Width[%d], Height[%d], nFrameNum[%d], nTriggerIndex[%d]\n", stImageInfo.nChannelID, stImageInfo.nWidth, stImageInfo.nHeight, stImageInfo.nFrameNum, stImageInfo.nTriggerIndex);printf("CodeNum[%d]\n", stBcrResult->nCodeNum);char strChar[MAX_BCR_LEN] = {0};for (int i = 0; i < stBcrResult->nCodeNum; i++){memset(strChar, 0, MAX_BCR_LEN);nRet = GB2312ToUTF8(stBcrResult->stBcrInfoEx[i].chCode, strlen(stBcrResult->stBcrInfoEx[i].chCode), strChar, MAX_BCR_LEN);if (nRet == MV_CODEREADER_OK){printf("CodeNum[%d] Code[%s]\r\n", i, strChar);}else{printf("CodeNum[%d] Code[%s]\r\n", i, stBcrResult->stBcrInfoEx[i].chCode);}				}}else{printf("No data[0x%x]\r\n", nRet);}}return 0;}// ch:主处理函数 | en:main process
int main()
{int nRet = MV_CODEREADER_OK;void* handle = NULL;bool bIsNormalRun = true;do{MV_CODEREADER_DEVICE_INFO_LIST stDeviceList;memset(&stDeviceList, 0, sizeof(MV_CODEREADER_DEVICE_INFO_LIST));// ch:枚举设备 | Enum devicenRet = MV_CODEREADER_EnumDevices(&stDeviceList, MV_CODEREADER_GIGE_DEVICE);if (MV_CODEREADER_OK != nRet){printf("Enum Devices fail! nRet [%#x]\r\n", nRet);break;}else{printf("Enum Devices succeed!\r\n");}if (stDeviceList.nDeviceNum > 0){for (unsigned int i = 0; i < stDeviceList.nDeviceNum; i++){printf("[device %d]:\r\n", i);MV_CODEREADER_DEVICE_INFO* pDeviceInfo = stDeviceList.pDeviceInfo[i];if (NULL == pDeviceInfo){break;}PrintDeviceInfo(pDeviceInfo);}}else{printf("Find No Devices!\r\n");break;}printf("Please Intput camera index:");unsigned int nIndex = 0;scanf("%d", &nIndex);if (nIndex >= stDeviceList.nDeviceNum){printf("Intput error!\r\n");break;}// ch:选择设备并创建句柄 | Select device and create handlenRet = MV_CODEREADER_CreateHandle(&handle, stDeviceList.pDeviceInfo[nIndex]);if (MV_CODEREADER_OK != nRet){printf("Create Handle fail! nRet [%#x]\r\n", nRet);break;}else{printf("Create Handle succeed!\r\n");}// ch:打开设备 | Open devicenRet = MV_CODEREADER_OpenDevice(handle);if (MV_CODEREADER_OK != nRet){printf("Open Device fail! nRet [%#x]\r\n", nRet);break;}else{printf("Open Device succeed!\r\n");}// ch:设置触发模式为off | eb:Set trigger mode as offnRet = MV_CODEREADER_SetEnumValue(handle, "TriggerMode", MV_CODEREADER_TRIGGER_MODE_OFF);if (MV_CODEREADER_OK != nRet){printf("Set Trigger Mode fail! nRet [%#x]\r\n", nRet);break;}else{printf("Set Trigger Mode succeed!\r\n");}// ch:开始取流 | en:Start grab imagenRet = MV_CODEREADER_StartGrabbing(handle);if (MV_CODEREADER_OK != nRet){printf("Start Grabbing fail! nRet [%#x]\r\n", nRet);break;}else{printf("Start Grabbing succeed!\r\n");}pthread_t nThreadID;nRet = pthread_create(&nThreadID, NULL, GrabImageThread, handle);if (MV_CODEREADER_OK != nRet){printf("Thread create failed! nRet [%d]\r\n", nRet);break;}PressEnterToExit();nRet = pthread_join(nThreadID, NULL);if (MV_CODEREADER_OK != nRet){printf("Thread free failed! nRet = [%d]\r\n", nRet);bIsNormalRun = false;break;}// ch:停止取流 | en:Stop grab imagenRet = MV_CODEREADER_StopGrabbing(handle);if (MV_CODEREADER_OK != nRet){printf("Stop Grabbing fail! nRet [%#x]\r\n", nRet);bIsNormalRun = false;break;}else{printf("Stop Grabbing succeed!\r\n");}// ch:关闭设备 | en:close devicenRet = MV_CODEREADER_CloseDevice(handle);if (MV_CODEREADER_OK != nRet){printf("MV_CODEREADER_CloseDevice fail! nRet [%#x]\r\n", nRet);bIsNormalRun = false;break;}else{printf("MV_CODEREADER_CloseDevice succeed!\r\n");}// ch:销毁句柄 | en:Destroy handlenRet = MV_CODEREADER_DestroyHandle(handle);if (MV_CODEREADER_OK != nRet){printf("MV_CODEREADER_DestroyHandle fail! nRet [%#x]\r\n", nRet);bIsNormalRun = false;break;}else{handle = NULL;printf("MV_CODEREADER_DestroyHandle succeed!\r\n");}} while (0);if (handle != NULL){// ch:关闭设备 | en:Close device// ch:销毁句柄 | en:Destroy handleMV_CODEREADER_CloseDevice(handle);MV_CODEREADER_DestroyHandle(handle);handle = NULL;}if (bIsNormalRun){printf("Exit!\r\n");		}if (false == bIsNormalRun){PressEnterToExit();printf("Exit!\r\n");}return 0;}

输出的结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/68694.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ansible的playbook剧本

playbook剧本 PlayBook1.playbooks 本身由以下各部分组成2.示例&#xff1a;3.运行playbook补充参数&#xff1a; 4.定义、引用变量5.指定远程主机sudo切换用户6.when条件判断7.迭代8.Templates 模块1.先准备一个以 .j2 为后缀的 template 模板文件&#xff0c;设置引用的变量2…

ICLR2020 Query2Box:基于BOX嵌入的向量空间知识推理8.15

Query2Box&#xff1a;基于BOX嵌入的向量空间知识推理 摘要介绍 摘要 在大规模不完全知识图谱上回答复杂的逻辑查询是一项基础性但具有挑战性的任务。最近&#xff0c;一种解决这个问题的很有前途的方法是将KG实体和查询嵌入到向量空间中&#xff0c;这样回答查询的实体紧密嵌…

vue3 setup+Taro3 调用原生小程序自定义年月日时分多列选择器,NutUI改造

vue3 setupTaro3 调用原生小程序自定义年月日时分多列选择器&#xff0c;NutUI改造 NutUI 有日期时间选择器&#xff0c;但是滑动效果太差&#xff0c;卡顿明显。换成 原生小程序 很顺畅 上代码&#xff1a; <template><view><pickermode"multiSelector&…

纯C#使用Visionpro工具1

各个工具的程序集名称 一般分类 一般情况是去掉Tool和Cog就是命名空间&#xff0c;如CogBlobTool对应于Cognex.Visionpro.Blob 也有特殊情况 忘了怎么办 可以借用ToolBlock引入工具后打开高级脚本查看 了解工具类和对象

SQLSERVER 查询语句加with (NOLOCK) 报ORDER BY 报错 除非另外还指定了 TOP、OFFSET 或 FOR XML

最近有一个项目在客户使用时发现死锁问题&#xff0c;用的数据库是SQLSERVER &#xff0c;死锁的原因是有的客户经常去点报表&#xff0c;报表查询时间又慢&#xff0c;然后又有人在做单导致了死锁&#xff0c;然后主管要我们用SQLSERVER查询时要加with (NOLOCK),但是我在加完 …

时序预测 | MATLAB实现WOA-CNN-GRU鲸鱼算法优化卷积门控循环单元时间序列预测

时序预测 | MATLAB实现WOA-CNN-GRU鲸鱼算法优化卷积门控循环单元时间序列预测 目录 时序预测 | MATLAB实现WOA-CNN-GRU鲸鱼算法优化卷积门控循环单元时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 时序预测 | MATLAB实现WOA-CNN-GRU鲸鱼算法优化卷积…

threejs使用gui改变相机的参数

调节相机远近角度 定义相机的配置&#xff1a; const cameraConfg reactive({ fov: 45 }) gui中加入调节fov的方法 const gui new dat.GUI();const cameraFolder gui.addFolder("相机属性设置");cameraFolder.add(cameraConfg, "fov", 0, 100).name(…

【运维】linkis安装dss保姆级教程与踩坑实践

文章目录 一. 安装准备二. 创建用户三. 准备安装包四. 修改配置1. 修改config.sh2. 修改db.sh 五、安装和使用1. 执行安装脚本2. 启动服务3. 查看验证是否成功 六. 报错处理报错一&#xff1a;The user is not logged in报错二&#xff1a;dss接口报错报错三&#xff1a;执行没…

div中的元素水平居中对齐

<div><img src"imgs/xy.jpg" alt""><h2>百变小樱</h2> </div> <style>* {padding: 0;margin: 0;box-sizing: border-box;}div {width: 200px;height: 300px;margin: 20em auto;padding-top: 4em;border: 2px solid rg…

SpringBoot、Java 使用 Jsoup 解析 HTML 页面

使用 Jsoup 解析 HTML 页面 什么是 Jsoup&#xff1f; Jsoup 是一个用于处理 HTML 页面的 Java 库&#xff0c;它提供了简单的 API&#xff0c;使得从 HTML 中提取数据变得非常容易。无论是获取特定标签的内容还是遍历整个页面的元素&#xff0c;Jsoup 都能轻松胜任。 如何使…

H13-922题库 HCIP-GaussDB-OLAP V1.5

**H13-922 V1.5 GaussDB(DWS) OLAP题库 华为认证GaussDB OLAP数据库高级工程师HCIP-GaussDB-OLAP V1.0自2019年10月18日起&#xff0c;正式在中国区发布。当前版本V1.5 考试前提&#xff1a; 掌握基本的数据库基础知识、掌握数据仓库运维的基础知识、掌握基本Linux运维知识、…

【博客692】grafana如何解决step动态变化时可能出现range duration小于step

grafana如何解决step动态变化时可能出现range duration小于step 1、grafana中的step和resolution grafana中的 “step” grafana本身是没有提供step参数的&#xff0c;因为仪表盘根据查询数据区间以及仪表盘线条宽度等&#xff0c;对于不同查询&#xff0c;相同的step并不能…