Qt+BASLER相机+OpenCV

				版权声明:本文为博主原创文章,未经博主允许不得转载。					https://blog.youkuaiyun.com/zong596568821xp/article/details/78790363				</div>
							            <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
					<div class="htmledit_views" id="content_views">
            <p>参考:</p>

http://www.ilovematlab.cn/thread-106077-1-1.html

http://blog.youkuaiyun.com/u013351270/article/details/54345855

http://blog.youkuaiyun.com/wt881010/article/details/53483813

https://imaginghub.com/projects/133-video-recording-with-opencv-qt-and-basler-pylon-on-mac-os-x#info

一、准备工作

相机型号:BASLER acA 1920-40gc

软件:pylon5,Qt,

用开发者模式安装pylon后,找到 Basler\pylon 5\Development\Samples\C++ 文件夹,我选择的是默认安装,所以路径是C:\Program Files\Basler\pylon5\Development\Samples\C++打开工程因为我的相机是GigE接口,所以我打开PylonSamples_GigE.sln编译就可以运行啦

二、示例工程

http://blog.youkuaiyun.com/u013351270/article/details/54290452

里边自带很多示例工程,工程的名字及作用如下:

DeviceRemovalHandling 这个示例程序演示了如何移除相机设备。它还显示如何重新连接到已删除的设备.。
Grab 这个例子演示了如何抓取过程中采用cinstantcamera类图像。图像是抓住和异步处理,当应用程序处理一个缓冲区,缓冲区的下一个收购是平行进行的,cinstantcamera类使用一个缓冲池,从摄像头获取图像数据。缓冲区填充完毕后,可以从相机对象检索缓冲区进行处理.。在抓取结果中收集缓冲区和附加图像数据。抓取结果由智能指针在检索后保持.。当显式释放或智能指针对象被销毁时,缓冲区将自动重复使用.。

Grab_camera_EventsGigE :在这个示例中显示了如何注册指示摄像机发送的事件到达的事件处理程序。 为了演示目的,为同一个事件注册了几个不同的处理程序。
Grab_ChunkImage Basler相机提供块特征:相机可以生成每个图像的某些信息,如帧计数器,时间戳,和CRC校验,这是附加到图像数据的“块”。
此示例说明如何启用块特性、如何抓取图像以及如何处理附加数据.。当相机处于块模式时,它将被划分成块的数据块传输.。第一个块总是图像数据.。当启用块特性时,图像数据块后面的块包含包含块特征的信息.。
Grab_MultiCast.cpp  此示例演示如何在多播模式下打开照相机以及如何接收多播流。
Grab_MultipleCameras 这个例子演示了如何抓取和处理来自多个摄像机的图像,使用cinstantcameraarray类。 
Grab_Strategies 这个例程显示了使用即时相机抓取策略。
Grab_UsingBufferFactory此示例演示用户提供的缓冲工厂的使用.。 缓冲工厂的使用是可选的,仅用于高级用例.。如果您打算抓取外部提供的缓冲区,则只需要缓冲工厂.。
Grab_UsingExposureEndEvent 此示例演示如何使用曝光结束事件以加快图像获取.。例如,当传感器曝光完成后,相机可以发送一个曝光结束事件的PC。PC可以接收事件之前的图像数据的成品曝光已被完全转移。这可以用来避免不必要的延迟,例如在相关的图像数据传输完成之前,成像对象被进一步移动。
Grab_UsingGrabLoopThread 此示例说明如何使用即时照相机类提供的抓取循环线程来抓取和处理图像.。 按下T获取一幅图像
GUI_ImageWindow 这个例子演示了如何显示图像使用cpylonimagewindow类。在这里,图像被抓取,分割成多个瓦片,每个平铺显示在一个单独的图像窗口。
ParametrizeCamera_AutoFunctions 本示例说明如何使用Basler相机的“自动功能”功能。
ParametrizeCamera_Configurations此示例演示如何通过使用标准配置和注册示例配置事件处理程序来使用配置事件处理程序。
 ParametrizeCamera_GenericParameterAccess.本示例演示使用genapi节点图的genapi表示配置相机的“通用”的方法::inodemap接口。名称和参数节点类型可以在巴斯勒塔程序员指南和API参考,在相机的用户手册,相机中的文件登记的结构和访问方法(如果适用),并利用塔查看器工具  x y offsetheight width
ParametrizeCamera_LoadAndSave 保存和读取相机参数!先读取后保存
ParametrizeCamera_LookupTable  本示例程序演示了使用亮度查找表功能。
ParametrizeCamera_NativeParameterAccess 此示例显示了使用设备特定的即时相机类配置相机的“原生”方法。
ParametrizeCamera_Shading  只有线阵相机支持
ParametrizeCamera_UserSets  演示如何使用用户配置集(用户集)以及如何配置摄像机以用户set1的用户定义设置启动。 您也可以使用pylon Viewerand配置您的相机,并将您的自定义设置存储在您选择的用户组中
Utility_GrabAvi.  本示例说明如何以音频视频交错(AVI)格式创建视频文件。
Utility_Image 本示例说明如何使用pylon图像类CPylonImage和CPylonBitmapImage。 
Utility_ImageFormatConverter  本示例演示了如何使用图像格式转换器类CImageFormatConverter。
Utility_ImageLoadAndSave 本示例说明如何加载和保存图像。

三、Pylon结构与枚举

参考:http://blog.youkuaiyun.com/liyuanbhu/article/details/74613768

四、Pylon5 SDK开发

参考:http://www.cnblogs.com/star91/p/6747946.html

在.pro文件中添加如下代码,注意前提是OpenCV的库也要配好,如果没有配,参考之前的文章配置http://blog.youkuaiyun.com/zong596568821xp/article/details/78819275:

OpenCV环境:


 
 
  1. INCLUDEPATH += C:\opencv\opencv\build\include \
  2. C:\opencv\opencv\build\include\opencv \
  3. C:\opencv\opencv\build\include\opencv2 \
  4. win32:CONFIG(release, debug|release): LIBS += -L$$PWD/../../../../opencv/opencv/build/x64/vc14/lib/ -lopencv_world320
  5. else:win32:CONFIG(debug, debug|release): LIBS += -L$$PWD/../../../../opencv/opencv/build/x64/vc14/lib/ -lopencv_world320d
  6. else:unix: LIBS += -L$$PWD/../../../../opencv/opencv/build/x64/vc14/lib/ -lopencv_world320
  7. INCLUDEPATH += $$PWD/../../../../opencv/opencv/build/x64/vc14
  8. DEPENDPATH += $$PWD/../../../../opencv/opencv/build/x64/vc14

Pylon环境:


 
 
  1. INCLUDEPATH += \
  2. $$(PYLON_DEV_DIR)/include \
  3. $$(PYLON_DEV_DIR)/include/pylon
  4. LIBS += \
  5. -L$$(PYLON_DEV_DIR)/lib/x64

注意如果电脑是64位系统,要添加x64的LIBS,如果电脑是32位,则添加Win32的LIBS

使用Pylon5 SDK搭配OpenCV采集图像程序流程如下:


在mainwindow.cpp中添加如下代码,该工程使用Basler acA1920-40gc GigE 相机测试成功。


 
 
  1. #include "mainwindow.h"
  2. #include "ui_mainwindow.h"
  3. //定义是否保存图片 0-否 1-是
  4. #define saveImages 1
  5. //定义是否记录视频 0-否 1-是
  6. #define recordVideo 1
  7. // 加载OpenCV API
  8. #include <opencv2/core/core.hpp>
  9. #include <opencv2/highgui/highgui.hpp>
  10. #include <opencv2/video/video.hpp>
  11. //加载PYLON API.
  12. #include <pylon/PylonIncludes.h>
  13. #include <pylon/gige/BaslerGigECamera.h>
  14. #include<iostream>
  15. #ifdef PYLON_WIN_BUILD
  16. #include <pylon/PylonGUI.h>
  17. #endif
  18. //命名空间.
  19. using namespace Pylon;
  20. using namespace cv;
  21. using namespace std;
  22. //定义抓取的图像数
  23. static const uint32_t c_countOfImagesToGrab = 10;
  24. MainWindow::MainWindow(QWidget *parent) :
  25. QMainWindow(parent),
  26. ui( new Ui::MainWindow)
  27. {
  28. ui->setupUi( this);
  29. // read an image
  30. //cv::Mat image = cv::imread("d://1.jpg", 1);
  31. // create image window named "My Image"
  32. //cv::namedWindow("My Image");
  33. // show the image on window
  34. //cv::imshow("My Image", image);
  35. //Pylon自动初始化和终止
  36. Pylon::PylonAutoInitTerm autoInitTerm;
  37. try
  38. {
  39. //创建相机对象(以最先识别的相机)
  40. CInstantCamera camera(CTlFactory::GetInstance().CreateFirstDevice());
  41. // 打印相机的名称
  42. std:: cout << "Using device " << camera.GetDeviceInfo().GetModelName() << endl;
  43. //获取相机节点映射以获得相机参数
  44. GenApi::INodeMap& nodemap = camera.GetNodeMap();
  45. //打开相机
  46. camera.Open();
  47. //获取相机成像宽度和高度
  48. GenApi::CIntegerPtr width = nodemap.GetNode( "Width");
  49. GenApi::CIntegerPtr height = nodemap.GetNode( "Height");
  50. //设置相机最大缓冲区,默认为10
  51. camera.MaxNumBuffer = 5;
  52. // 新建pylon ImageFormatConverter对象.
  53. CImageFormatConverter formatConverter;
  54. //确定输出像素格式
  55. formatConverter.OutputPixelFormat = PixelType_BGR8packed;
  56. // 创建一个Pylonlmage后续将用来创建OpenCV images
  57. CPylonImage pylonImage;
  58. //声明一个整形变量用来计数抓取的图像,以及创建文件名索引
  59. int grabbedlmages = 0;
  60. // 新建一个OpenCV video creator对象.
  61. VideoWriter cvVideoCreator;
  62. //新建一个OpenCV image对象.
  63. Mat openCvImage;
  64. // 视频文件名
  65. std:: string videoFileName = "openCvVideo.avi";
  66. // 定义视频帧大小
  67. cv::Size frameSize = Size(( int)width->GetValue(), ( int)height->GetValue());
  68. //设置视频编码类型和帧率,有三种选择
  69. // 帧率必须小于等于相机成像帧率
  70. cvVideoCreator.open(videoFileName, CV_FOURCC( 'D', 'I', 'V', 'X'), 10, frameSize, true);
  71. //cvVideoCreator.open(videoFileName, CV_F0URCC('M','P',,4','2’), 20, frameSize, true);
  72. //cvVideoCreator.open(videoFileName, CV_FOURCC('M', '3', 'P', 'G'), 20, frameSize, true);
  73. // 开始抓取c_countOfImagesToGrab images.
  74. //相机默认设置连续抓取模式
  75. camera.StartGrabbing(c_countOfImagesToGrab, GrabStrategy_LatestImageOnly);
  76. //抓取结果数据指针
  77. CGrabResultPtr ptrGrabResult;
  78. // 当c_countOfImagesToGrab images获取恢复成功时,Camera.StopGrabbing()
  79. //被RetrieveResult()方法自动调用停止抓取
  80. while (camera.IsGrabbing())
  81. {
  82. // 等待接收和恢复图像,超时时间设置为5000 ms.
  83. camera.RetrieveResult( 5000, ptrGrabResult, TimeoutHandling_ThrowException);
  84. //如果图像抓取成功
  85. if (ptrGrabResult->GrabSucceeded())
  86. {
  87. // 获取图像数据
  88. cout << "SizeX: "<<ptrGrabResult->GetWidth()<< endl;
  89. cout << "SizeY: "<<ptrGrabResult->GetHeight()<< endl;
  90. //将抓取的缓冲数据转化成pylon image.
  91. formatConverter.Convert(pylonImage, ptrGrabResult);
  92. // 将 pylon image转成OpenCV image.
  93. openCvImage = cv::Mat(ptrGrabResult->GetHeight(), ptrGrabResult->GetWidth(), CV_8UC3, ( uint8_t *) pylonImage.GetBuffer());
  94. //如果需要保存图片
  95. if (saveImages)
  96. {
  97. std:: ostringstream s;
  98. // 按索引定义文件名存储图片
  99. s << "image_" << grabbedlmages << ".jpg";
  100. std:: string imageName(s.str());
  101. //保存OpenCV image.
  102. imwrite(imageName, openCvImage);
  103. grabbedlmages++;
  104. }
  105. //如果需要记录视频
  106. if (recordVideo)
  107. {
  108. cvVideoCreator.write(openCvImage);
  109. }
  110. //新建OpenCV display window.
  111. namedWindow( "OpenCV Display Window", CV_WINDOW_NORMAL); // other options: CV_AUTOSIZE, CV_FREERATIO
  112. //显示及时影像.
  113. imshow( "OpenCV Display Window", openCvImage);
  114. // Define a timeout for customer's input in
  115. // '0' means indefinite, i.e. the next image will be displayed after closing the window.
  116. // '1' means live stream
  117. waitKey( 1);
  118. }
  119. }
  120. }
  121. catch (GenICam::GenericException &e)
  122. {
  123. // Error handling.
  124. cerr << "An exception occurred." << endl
  125. << e.GetDescription() << endl;
  126. }
  127. return;
  128. }
  129. MainWindow::~MainWindow()
  130. {
  131. delete ui;
  132. }

运行成功后,显示如下界面(不知为什么,我的相机读出来是黑的——后来发现是镜头的问题,换了镜头就好了)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值