OpenCV读入3D相机数据

写在前面

  • 本人从事机器视觉细分的3D相机行业。编写此系列文章主要目的有:

    • 1、便利他人应用3D相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释;
    • 2、促进行业发展及交流。
  • 知微传感Dkam系列3D相机可以应用于定位分拣、焊接引导、逆向建模、检测测量等领域
  • 欢迎与我深入交流:微信号:liu_zhisensor

OpenCV读取数据说明

基本说明

  • 知微传感的3D相机可以输出红外图(灰度图)和RGB图以便利2D+3D的应用场景
  • 红外图和RGB图在相机端是以char类型存储并在上位机中以char类型接收的
  • 深度图是从点云中提取的Z值,按照红外图的顺序存放的,在提取数据的过程中将char类型转为了short类型

相关API

  • GetCloudPlaneZ 获取Z轴数据

    • int GetCloudPlaneZ(Camera_Object_C* camera_obj, PhotoInfo *raw_data, short *imagedata)
    • 函数功能:获取点云 Z 平面数据
    • 头文件:dkam_zhicamera_api.h
    • 参数:camera_obj:相机的结构体指针; raw_data:点云数据; imagedata:获取的 Z 平面数据
    • 返回值:0:获取成功; 非 0:获取失败

例程及注释

  • 本例程基于WIN10+VisualStudio2019+DkamSDK_1.6.71+OpenCV4.5.4,采用C++语言
  • DkamSDK的配置方法请参考SDK说明书
  • OpenCV的配置方法另请查阅
  • 除自己安装配置OpenCV外,还可以利用知微传感提供的DkamSDK自带的OpenCV,在include和lib文件夹内
  • 本例程在D132S型相机上验证
#include <iostream>
//DkamSDK
#include"dkam_discovery.h"
#include"dkam_gige_camera.h"
#include"dkam_gige_stream.h"
#include"dkam_zhicamera_api.h"
//OpenCV
#include <opencv2/opencv.hpp>int main()
{std::cout << "Hello ZhiSENSOR!" <<std::endl;std::cout << "Hello liu_sensor!" << std::endl;std::vector<DiscoveryInfo> discovery_info;Discovery discovery;GigeCamera camera;GigeStream* pointgigestream = NULL;GigeStream* graygigestream = NULL;GigeStream* rgbgigestream = NULL;//**********************************************查询相机****************************************************//查询局域网内的3D相机std::vector<DiscoveryInfo>().swap(discovery_info);int camer_num = discovery.DiscoverCamera(&discovery_info);std::cout << "局域网内共有" << camer_num << "台相机" << std::endl;//显示局域网内相机的IPfor (int i = 0; i < camer_num; i++){std::cout << "局域网内相机的IP为:" << discovery.ConvertIpIntToString(discovery_info[i].camera_ip) << std::endl;}//**********************************************连接相机****************************************************//选定相机int k = -1;for (int i = 0; i < camer_num; i++){if (strcmp((discovery.ConvertIpIntToString(discovery_info[i].camera_ip)), "192.168.30.35") == 0){k = i;std::cout << "将连接第" << k + 1 << "台相机" << std::endl;}else{std::cout << "局域网内无该IP的相机" << std::endl;}}//连接相机int connect = camera.CameraConnect(&discovery_info[k]);if (connect == 0){std::cout << "成功连接相机" << std::endl;}else{std::cout << "连接相机失败,请检查!!!" << std::endl;}//**********************************************配置相机****************************************************if (connect == 0){//获取当前红外相机的宽和高int width = -1;int height = -1;std::cout << "获取相机红外图的宽和高。。。" << std::endl;int height_gray = camera.GetCameraHeight(&height, 0);int width_gray = camera.GetCameraWidth(&width, 0);std::cout << "相机红外图的宽为:" << width << std::endl; std::cout << "相机红外图的高为:" << height << std::endl;//获取当前RGB相机的宽和高,如相机不支持则无此项int width_RGB = -1;int height_RGB = -1;std::cout << "获取相机RGB图的宽和高。。。" << std::endl;int height_rgb = camera.GetCameraHeight(&height_RGB, 1);int width_rgb = camera.GetCameraWidth(&width_RGB, 1);std::cout << "相机RGB图的宽为" << width_RGB << std::endl;std::cout << "相机RGB图的高为" << height_RGB << std::endl;//定义红外数据大小PhotoInfo* gray_data = new PhotoInfo;gray_data->pixel = new char[width * height];memset(gray_data->pixel, 0, width * height);//定义点云数据大小PhotoInfo* point_data = new PhotoInfo;point_data->pixel = new char[width * height * 6];memset(point_data->pixel, 0, width * height * 6);//定义RGB数据大小PhotoInfo* RGB_data = new PhotoInfo;RGB_data->pixel = new char[width_RGB * height_RGB * 3];memset(RGB_data->pixel, 0, width_RGB * height_RGB * 3);//**********************************************打开数据通道****************************************************//开启数据流通道(0:红外 1:点云 2:RGB)//红外图int stream_gray = camera.StreamOn(0, &graygigestream);if (stream_gray == 0){std::cout << "红外图通道打开成功!" << std::endl;}else{std::cout << "红外图通道打开失败!!!" << std::endl;}//点云int stream_point = camera.StreamOn(1, &pointgigestream);if (stream_point == 0){std::cout << "点云通道打开成功!" << std::endl;}else{std::cout << "点云通道打开失败!!!" << std::endl;}//RGB图通道int stream_RGB = camera.StreamOn(2, &rgbgigestream);if (stream_RGB == 0){std::cout << "RGB图通道打开成功!" << std::endl;}else{std::cout << "RGB图通道打开失败!!!" << std::endl;}//开始接受数据int acquistion = camera.AcquisitionStart();if (acquistion == 0){std::cout << "可以开始接受数据!" << std::endl;}//刷新缓冲区数据pointgigestream->FlushBuffer();graygigestream->FlushBuffer();rgbgigestream->FlushBuffer();//**********************************************等待相机上传数据***************************************//采集红外int captureGray = -1;captureGray = graygigestream->TimeoutCapture(gray_data, 3000000);if (captureGray == 0){std::cout << "红外接收成功!" << std::endl;}else{std::cout << "红外接收失败!!!" << std::endl;std::cout << "失败代号:" << captureGray << std::endl;}//采集点云int capturePoint = -1;capturePoint = pointgigestream->TimeoutCapture(point_data, 3000000);if (capturePoint == 0){std::cout << "点云接收成功!" << std::endl;}else{std::cout << "点云接收失败!!!" << std::endl;std::cout << "失败代号:" << capturePoint << std::endl;}//采集RGBint captureRGB = -1;captureRGB = rgbgigestream->TimeoutCapture(RGB_data, 3000000);if (captureRGB == 0){std::cout << "RGB接收成功!" << std::endl;}else{std::cout << "RGB接收失败!!!" << std::endl;std::cout << "失败代号:" << captureRGB << std::endl;}//保存数据到本地//保存红外数据int savegray = camera.SaveToBMP(*gray_data, (char*)"Gray.bmp");if (savegray == 0){std::cout << "红外图保存成功!" << std::endl;}else{std::cout << "红外图保存失败!!!" << std::endl;}//保存RGB数据int savergb = camera.SaveToBMP(*RGB_data, (char*)"RGB.bmp");if (savergb == 0){std::cout << "RGB图保存成功!" << std::endl;}else{std::cout << "RGB图保存失败!!!" << std::endl;}//保存深度图int savedepth = camera.SaveDepthToPng(*point_data, (char*)"Depth.png");if (savedepth == 0){std::cout << "深度图保存成功!" << std::endl;}else{std::cout << "深度图保存失败!!!" << std::endl;}//**********************************************将数据OpenCV可处理格式***************************************//灰度图std::cout << "将红外图转换到OpenCV格式,并显示..." << std::endl;cv::Mat GrayImage = cv::Mat(height, width, CV_8UC1, (void*)gray_data->pixel);//显示灰度图cv::imshow("Gray Picture", GrayImage);//RGB图std::cout << "将RGB图转换到OpenCV格式,并显示..." << std::endl;cv::Mat RGBimage = cv::Mat(height_RGB, width_RGB, CV_8UC3, (void*)RGB_data->pixel); cv::imshow("RGB Picture", RGBimage);//深度图std::cout << "提取深度数据,转换到OpenCV格式,并显示..." << std::endl;short* depthdata = (short*)malloc(width * height * 2 * sizeof(short));memset((void*)depthdata,0, width * height * 2 * sizeof(short));int getZ = camera.GetCloudPlaneZ(*point_data, depthdata);if (getZ == 0){std::cout << "提取点云Z值成功!" << std::endl;}else{std::cout << "提取点云Z值失败!!!" << std::endl;}cv::Mat DepthImage = cv::Mat(height, width, CV_16U, (void*)depthdata);cv::imshow("Depth Picture", DepthImage);std::cout << "注意:深度图像素值乘以0.05才是真实物理世界的距离。单位:mm" << std::endl;//**********************************************结束工作***************************************memset(point_data->pixel, 0, width* height * 6);memset(gray_data->pixel, 0, width* height);memset(RGB_data->pixel, 0, width_RGB* height_RGB * 3);//释放内存delete[] point_data->pixel;delete point_data;delete[] gray_data->pixel;delete gray_data;delete[] RGB_data->pixel;delete RGB_data;delete depthdata;//关闭数据流通道 int streamoff_gray = camera.StreamOff(0, graygigestream);int streamoff_point = camera.StreamOff(1, pointgigestream);int streamoff_rgb = camera.StreamOff(2, rgbgigestream);//断开相机连接int disconnect = camera.CameraDisconnect();std::cout << "工作结束!!!!!!" << std::endl;}else{std::cout << "相机连接失败!!!" << std::endl;std::cout << "请排查原因,代号:" << connect << std::endl;}cv::waitKey(0);
}

运行结果

结果对比

  • 使用知微传感自带的保存API保存的图片和OpenCV显示结果对比(仅示意了红外图)

  • 可以看出用OpenCV显示的图片和用官方体供的API保存的数据相同,以上代码可行

后记

  • 知微传感Dkam系列3D相机可以应用于定位分拣、焊接引导、逆向建模、检测测量等领域
  • 如有问题,欢迎与我深入交流:微信号:liu_zhisensor

知微传感Dkam系列3D相机OpenCV应用篇:OpenCV读入3D相机数据相关推荐

  1. 知微传感Dkam系列3D相机SDK例程篇:点云滤波

    3D相机点云滤波 写在前面 本人从事机器视觉细分的3D相机行业.编写此系列文章主要目的有: 1.便利他人应用3D相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释: 2.促进行业发展及交流 ...

  2. 知微传感Dkam系列3D相机SDK例程篇:配置相机曝光

    配置3D相机曝光 写在前面 本人从事机器视觉细分的3D相机行业.编写此系列文章主要目的有: 1.便利他人应用3D相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释: 2.促进行业发展及交流 ...

  3. 知微传感Dkam系列3D相机SDK例程篇:获取内外参

    获取3D相机内外参 写在前面 本人从事机器视觉细分的3D相机行业.编写此系列文章主要目的有: 1.便利他人应用3D相机,本系列文章包含公司所出售相机的SDK的使用例程及详细注释: 2.促进行业发展及交 ...

  4. 知微传感Dkam系列3D相机PCL应用篇:PCL读入3D相机数据

    PCL读入Dkam系列3D相机数据 写在前面 PCL(Point Cloud Library):是一个开源的算法库,用C++编写,是当前点云处理的得力工具: 在使用PCL处理3D相机输出的点云中,可能 ...

  5. 知微传感3D相机SDK开发文档一查找相机

    知微传感3D相机SDK开发文档一查找相机 主要对知微传感3D相机的SDK文件做一个介绍,大家一个界面显示程序包含图像的获得,相机的查找和链接 查找相机,通过UDP广播形式查找局域网相机 链接相机,通过 ...

  6. 【计算机视觉】全景相机标定(MATLAB/opencv)

    全景相机标定 1Matlab工具箱 http://www.vision.caltech.edu/bouguetj/calib_doc/htmls/links.html http://www-sop.i ...

  7. Udacity机器人软件工程师课程笔记(十九) - 3D感知介绍 - 主动/被动式传感器、RGB-D相机、点云

    3D感知介绍 目录 传感器 RGB-D相机 点云 1.传感器 主动式传感器是指向目标发射电磁波,然后收集从目标反射回来的电磁波信息的传感器,如合成孔径雷达等. 被动式传感器指只能收集地而目标反时来自太 ...

  8. VTN系列多通道振弦、温度、模拟传感信号系列数据采集仪

    VTN208-432是多通道振弦.温度.模拟传感信号系列数据采集仪,可对32通道振弦频率.32通道热敏电阻或DS18B20温度传感器.32通道模拟量传感器(电流或电压)进行实时在线采集或全自动定时采集 ...

  9. 利用Matlab进行相机标定并使用openCV进行简单三维重建

    注:本文主要针对Matlab和OpenCV跨平台进行相机标定.单相机三维重建工作的实现,因为我发现网上竟然没有一篇博客径直指出这两者在进行图像处理时的巨大差异(坐标系完全不同),不然我也不会走了很多弯 ...

最新文章

  1. Java初级笔记-第五章
  2. 小黑小波比.git clone报错解决方案
  3. android方向触摸事件,Android触摸事件传递机制,这一篇就够了
  4. Support Vector Machine (3) : 再谈泛化误差(Generalization Error)
  5. 图像分类数据集类型--典型模型--相关论文
  6. 全国青少年软件编程(C语言)等级考试试题-2019年9月(一级含答案)
  7. 安装服务器系统提示加载驱动程序,启动sqlserver服务时,总是出现“系统错误(126),指定驱动程序无法加载,...
  8. mp3转html,使用javascript将wav转换为mp3
  9. JavaScript基础--DOM部分02--李南江
  10. 2010新财富中国富豪榜1至100名
  11. TP5整合阿里云OSS上传文件第二节,异步上传头像实现,
  12. 数风流人物,俱在今朝!|2019年度CSDN博客之星TOP10榜单揭晓
  13. Windows系统封装(二)导入封装工具安装软件,安装系统。
  14. 经典语录(个人喜欢)
  15. Android系统打不开,安卓手机打不开pdf文件怎么解决?
  16. android 快速实现图片压缩与上传
  17. 设计c语言程序得到回文数,C语言程序设计实训题目.pdf
  18. 【Keepass】配置好keepassnatmsg插件、keepassxc-browser扩展后,出现Failed to save to the specified file未将对象引用设置到对象
  19. 几类常用Case工具介绍
  20. 四元素基础理论及其应用

热门文章

  1. EXCEL的IF函数学习
  2. SAS实验四 一元回归分析
  3. 基于JavaSwing开发开发的打字软件(疯狂打字通)+论文 课程设计 大作业源码
  4. Quartz立即执行
  5. Hill-climbing 算法python 实现
  6. Missing key(s) in state_dict | unexpected_keys | 模型加载 [torch.load] 报错【解决方案】
  7. mac最值得关注的终端工具,你知道几个?
  8. C++ 第17章 输入、输出和文件(iostream/ostream/fstream)
  9. 解决Hash(哈希表)冲突的四种方案
  10. dell笔记本显卡报错43解决方法