ToolDialog.cpp 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. #include "ToolDialog.h"
  2. #include <QImage>
  3. #include <QFileInfo>
  4. #include <QFileDialog>
  5. #include <QElapsedTimer>
  6. #include <QGridLayout>
  7. ToolDialogImpl::ToolDialogImpl(QWidget* parent, DllTool* pDllTool)
  8. : DllToolDialog(parent)
  9. {
  10. ui.setupUi(this);
  11. this->setWindowFlags(Qt::Dialog | Qt::WindowMaximizeButtonHint | Qt::WindowCloseButtonHint /*| Qt::WindowStaysOnTopHint*/);
  12. connect(this, SIGNAL(sigUpdateUI()), this, SLOT(on_UpdateUI()));
  13. // 显示控件初始化
  14. hwndUnit = new HWndUnit(this);
  15. Util::ShowUnitInWidget(ui.Image_widget, hwndUnit);
  16. for (int i = 0; i < 256; i++)
  17. {
  18. grayColourTable.append(qRgb(i, i, i));
  19. }
  20. int dataSize = 400 * 300 * 3;
  21. m_data.reset(new uchar[dataSize], std::default_delete<uchar[]>());
  22. int iCameraCounts = 4;
  23. int iStatus = -1;
  24. tSdkCameraDevInfo tCameraEnumList[4];
  25. //sdk初始化 0 English 1中文
  26. CameraSdkInit(1);
  27. //枚举设备,并建立设备列表
  28. CameraEnumerateDevice(tCameraEnumList, &iCameraCounts);
  29. Initialize(0, "");
  30. }
  31. ToolDialogImpl::~ToolDialogImpl()
  32. {
  33. }
  34. VPEnum::RETURN_VALUE ToolDialogImpl::Execute()
  35. {
  36. try
  37. {
  38. hwndUnit->ShowImage(m_Image);
  39. hwndUnit->Refresh();
  40. }
  41. catch (...)
  42. {
  43. qWarning() << "Execute() Error";
  44. }
  45. emit sigUpdateUI();
  46. return VPEnum::RETURN_VALUE::Success;
  47. }
  48. /// <summary>
  49. ///
  50. /// </summary>
  51. /// <param name="bRun"></param>
  52. void ToolDialogImpl::Running(bool bRun)
  53. {
  54. }
  55. /// <summary>
  56. ///
  57. /// </summary>
  58. /// <param name="ar"></param>
  59. /// <param name="bIsOut"></param>
  60. /// <returns></returns>
  61. bool ToolDialogImpl::Serialized(QDataStream& ar, bool bIsOut)
  62. {
  63. int paranum;//参数数量
  64. if (bIsOut)//保存参数流程
  65. {
  66. paranum = 1;
  67. ar << paranum;//先保存参数数量
  68. ar << (int)1 << m_Image;
  69. }
  70. else//加载参数流程,参数加载顺序一定要跟保存顺序一致
  71. {
  72. int nSize1 = 0;
  73. int para;
  74. ar >> paranum;//读取参数数量
  75. for (int i = 0; i < paranum; i++)
  76. {
  77. ar >> para;
  78. switch (para)
  79. {
  80. case 1: ar >> m_Image; break;
  81. default:
  82. {
  83. qWarning() << "Serialized(In) Error" ;
  84. return false;
  85. }
  86. break;
  87. }
  88. }
  89. }
  90. return true;
  91. }
  92. void ToolDialogImpl::on_UpdateUI()
  93. {
  94. }
  95. /// <summary>
  96. /// 确定
  97. /// </summary>
  98. void ToolDialogImpl::on_btnOK_clicked()
  99. {
  100. this->hide();
  101. }
  102. /// <summary>
  103. /// 取消按钮
  104. /// </summary>
  105. void ToolDialogImpl::on_btnCancel_clicked()
  106. {
  107. // 将本工具的恢复到打开工具之前的状态
  108. RecoverData();
  109. }
  110. /// <summary>
  111. /// 测试按钮
  112. /// </summary>
  113. void ToolDialogImpl::on_btnExecute_clicked()
  114. {
  115. QElapsedTimer toolTimer;
  116. toolTimer.start();
  117. // 发送事件
  118. ToolEvent* pToolEvent = new ToolEvent(m_strPouName, m_strInstanceName, TOOL_EVENT_TYPE::TOOL_TRIGGER);
  119. QCoreApplication::sendEvent(m_pEventTarget, pToolEvent);
  120. // 统计返回值
  121. VPEnum::RETURN_VALUE ret = pToolEvent->ret;
  122. double nExecTime = toolTimer.elapsed();
  123. QString str;
  124. str = QString("耗时: %1 ms").arg(nExecTime, 0, 'G', 5);
  125. ui.label_time->setText(str);
  126. str = QString("状态: %1 ").arg(QMetaEnum::fromType<VPEnum::RETURN_VALUE>().key((short)ret));
  127. ui.label_state->setText(str);
  128. delete pToolEvent;
  129. }
  130. //////////////////////////////////////////////////////////////////////////
  131. void ToolDialogImpl::getDevices(tSdkCameraDevInfo** devices, int& count, bool redo)
  132. {
  133. const int maxNum = 20;
  134. static tSdkCameraDevInfo tCameraEnumList[maxNum];
  135. static int counts(0);
  136. if (redo || counts <= 0) {
  137. static bool bSdkOk(false);
  138. if (!bSdkOk)
  139. //sdk初始化 0 English 1中文
  140. bSdkOk = CameraSdkInit(1) == CAMERA_STATUS_SUCCESS;
  141. int iCameraCounts(maxNum);
  142. CameraEnumerateDevice(tCameraEnumList, &iCameraCounts);
  143. counts = iCameraCounts;
  144. }
  145. *devices = tCameraEnumList;
  146. count = counts;
  147. }
  148. bool ToolDialogImpl::Initialize(int DeviceNumber, QString varParamPath)
  149. {
  150. tSdkCameraDevInfo* tCameraEnumList(Q_NULLPTR);
  151. int count(0);
  152. getDevices(&tCameraEnumList, count);
  153. int iStatus = -1;
  154. //相机初始化。初始化成功后,才能调用任何其他相机相关的操作接口
  155. iStatus = CameraInit(&tCameraEnumList[DeviceNumber], PARAM_MODE_BY_SN, -1, &m_hCamera);
  156. //初始化失败
  157. if (iStatus != CAMERA_STATUS_SUCCESS)
  158. {
  159. return false;
  160. }
  161. //获得相机的特性描述结构体。该结构体中包含了相机可设置的各种参数的范围信息。决定了相关函数的参数
  162. CameraGetCapability(m_hCamera, &m_sCameraInfo);
  163. /*
  164. 设置图像处理的输出格式,彩色黑白都支持RGB24位
  165. */
  166. //相机参数的raw2rgb主要有A1、A3两种算法,默认输出BGR
  167. //CameraImageProcess负责将raw转换成rgb,而算法A1只支持BGR,算法A3 可以在设置CameraSetIspOutFormat成格式RGB 的时候可以输出 RGB
  168. if (m_sCameraInfo.sIspCapacity.bMonoSensor)
  169. {
  170. CameraSetIspOutFormat(m_hCamera, CAMERA_MEDIA_TYPE_MONO8);
  171. }
  172. else
  173. {
  174. //CameraSetIspOutFormat(m_hCamera,/*CAMERA_MEDIA_TYPE_RGB8*/CAMERA_MEDIA_TYPE_BGR8);
  175. }
  176. CameraSetMirror(m_hCamera, MIRROR_DIRECTION_VERTICAL, true);
  177. CameraSetCallbackFunction(m_hCamera, &ToolDialogImpl::GrabImageCallback, (PVOID)this, nullptr);
  178. CameraPlay(m_hCamera);
  179. return true;
  180. }
  181. /**
  182. * @brief QImage2HImage 将 Qt QImage 转换为 Halcon 的 HImage
  183. * @param from 输入的 QImage
  184. * @param to 输出的 HImage ,from 和 to 不共享内存数据。 每次都会为 to 重新分配内存。
  185. * @return true 表示转换成功,false 表示转换失败。
  186. */
  187. bool QImage2HImage(QImage& from, HalconCpp::HImage& to)
  188. {
  189. if (from.isNull()) return false;
  190. int width = from.width(), height = from.height();
  191. QImage::Format format = from.format();
  192. if (format == QImage::Format_RGB32 ||
  193. format == QImage::Format_ARGB32 ||
  194. format == QImage::Format_ARGB32_Premultiplied)
  195. {
  196. to.GenImageInterleaved(from.bits(), "rgbx", width, height, 0, "byte", width, height, 0, 0, 8, 0);
  197. return true;
  198. }
  199. else if (format == QImage::Format_RGB888)
  200. {
  201. to.GenImageInterleaved(from.bits(), "rgb", width, height, 0, "byte", width, height, 0, 0, 8, 0);
  202. return true;
  203. }
  204. else if (format == QImage::Format_Grayscale8 || format == QImage::Format_Indexed8)
  205. {
  206. to.GenImage1("byte", width, height, from.bits());
  207. return true;
  208. }
  209. return false;
  210. }
  211. void ToolDialogImpl:: GrabImageCallback(CameraHandle hCamera, BYTE* pFrameBuffer, tSdkFrameHead* pFrameHead, PVOID pContext)
  212. {
  213. CameraSdkStatus status;
  214. ToolDialogImpl* pThis = (ToolDialogImpl*)pContext;
  215. //将获得的原始数据转换成RGB格式的数据,同时经过ISP模块,对图像进行降噪,边沿提升,颜色校正等处理。
  216. //我公司大部分型号的相机,原始数据都是Bayer格式的
  217. status = CameraImageProcess(pThis->m_hCamera, pFrameBuffer, pThis->m_data.get(), pFrameHead);
  218. //在成功调用CameraGetImageBuffer后,必须调用CameraReleaseImageBuffer来释放获得的buffer。
  219. //否则再次调用CameraGetImageBuffer时,程序将被挂起,知道其他线程中调用CameraReleaseImageBuffer来释放了buffer
  220. CameraReleaseImageBuffer(pThis->m_hCamera, pFrameBuffer);
  221. // TODOLINLIN copy line by line
  222. const int width(pFrameHead->iWidth), height(pFrameHead->iHeight);
  223. // int dataSize(width * height);
  224. // int bytesPerLine(width);
  225. QImage::Format imgFmt = QImage::Format_Indexed8;
  226. if (pFrameHead->uiMediaType != CAMERA_MEDIA_TYPE_MONO8)
  227. {
  228. // dataSize = width * height * 3;
  229. // bytesPerLine = width * 3;
  230. imgFmt = QImage::Format_RGB888;
  231. }
  232. // GenImage3(&pThis->m_Image, "byte", width, height, (Hlong)pThis->m_data.get() ,);
  233. // pThis->hwndUnit->ShowImage(pThis->m_Image);
  234. // pThis->hwndUnit->Refresh();
  235. // return;
  236. QImage img(pThis->m_data.get(), width, height, imgFmt);
  237. if (pFrameHead->uiMediaType == CAMERA_MEDIA_TYPE_MONO8)
  238. {
  239. img.setColorTable(pThis->grayColourTable);
  240. }
  241. //img.save("./123.png");
  242. QImage2HImage(img, pThis->m_Image);
  243. pThis->hwndUnit->ShowImage(pThis->m_Image);
  244. pThis->hwndUnit->Refresh();
  245. }