CameraImageHandler.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. #include "CameraImageHandler.h"
  2. #include "CameraMaterialGroupWnd/Group.h"
  3. #include <QDirIterator>
  4. CameraImageHandler::CameraImageHandler(const int groupId,const CameraInfo& cameraInfo)
  5. {
  6. captureAndConvertImage(groupId,cameraInfo);
  7. }
  8. void CameraImageHandler::captureAndConvertImage(const int groupId,const CameraInfo& cameraInfo) {
  9. m_pCViewInterface = ns_module::CViewInterface::GetInstance();
  10. if (m_pCViewInterface == nullptr);
  11. {
  12. // 目前不做处理,为了兼容
  13. }
  14. CreateGroupData(groupId,cameraInfo);
  15. }
  16. Group* CameraImageHandler::getGroup() const {
  17. return m_pGroup;
  18. }
  19. Wafer* CameraImageHandler::getWafer() const{
  20. return m_pWafer;
  21. }
  22. Waffle* CameraImageHandler::getWaffle() const{
  23. return m_pWaffle;
  24. }
  25. MaterialBox* CameraImageHandler::getMaterialBox() const
  26. {
  27. return m_pMaterialBox;
  28. }
  29. Bond* CameraImageHandler::getBond() const {
  30. return m_pBond;
  31. }
  32. QList<QPair<QString, QString>> CameraImageHandler::getFileList(){
  33. return m_pfileList;
  34. }
  35. void CameraImageHandler::CreateGroupData(const int groupId,const CameraInfo& cameraInfo)
  36. {
  37. QString strPatch = R"(D:\config\MaterialInfo\)"; // 真实的路径
  38. switch (cameraInfo.iCameraId)
  39. {
  40. case 0: //TODO: yang
  41. {
  42. strPatch += CreateMaterialType(cameraInfo.eType);
  43. }
  44. break;
  45. case 1:
  46. {
  47. strPatch += CreateMaterialType(cameraInfo.eType);
  48. }
  49. break;
  50. case 2:
  51. {
  52. strPatch += CreateMaterialType(cameraInfo.eType);
  53. }
  54. break;
  55. case 3:
  56. {
  57. strPatch += CreateMaterialType(cameraInfo.eType);
  58. }
  59. break;
  60. case 4:
  61. {
  62. strPatch += CreateMaterialType(cameraInfo.eType);
  63. }
  64. break;
  65. default:
  66. break;
  67. }
  68. //初始化group
  69. //测试路径
  70. strPatch = "D:/code/JSBTDieBondH/View/die-bonder-ui/images/test_image";
  71. m_pfileList = loadImages(cameraInfo, strPatch);
  72. m_pGroup = new Group(groupId,cameraInfo, m_pCViewInterface,m_pfileList, this);
  73. }
  74. QString CameraImageHandler::CreateMaterialType(MATERIAL_TYPE materialType)
  75. {
  76. QString strLoadPatch;
  77. switch (materialType)
  78. {
  79. case MATERIAL_NULL:
  80. {
  81. }
  82. break;
  83. case MATERIAL_WAFER:
  84. {
  85. strLoadPatch = "Wafer";
  86. m_pWafer = new Wafer(0); //TODO:以下传入指针实现同步?
  87. if (m_pCViewInterface != nullptr)
  88. {
  89. std::vector<ns_mat::WAFER_MATRIX_POINT_INFO_STRUCT> veWafer;
  90. m_pCViewInterface->GetWaferAllPointInfo(veWafer);
  91. m_pWafer->UpdataVal(veWafer);
  92. }
  93. else
  94. {
  95. m_pWafer->UpdataGenerateTestData();
  96. }
  97. }
  98. break;
  99. case MATERIAL_WAFFLE:
  100. {
  101. strLoadPatch = "Waffle";
  102. m_pWaffle = new Waffle(0);
  103. if (m_pCViewInterface != nullptr)
  104. {
  105. std::vector<ns_mat::WAFFLE_MATRIX_POINT_STRUCT> veWaffle;
  106. m_pCViewInterface->GetWafflePackAllPointInfo(veWaffle);
  107. m_pWaffle->UpdataVal(veWaffle);
  108. }
  109. else
  110. {
  111. m_pWaffle->UpdataGenerateTestData();
  112. }
  113. }
  114. break;
  115. case MATERIAL_BOX: //-----------------------------未提供
  116. {
  117. strLoadPatch = "MaterialBox";
  118. m_pMaterialBox = new MaterialBox(0);
  119. }
  120. break;
  121. case MATERIAL_BOND:
  122. {
  123. strLoadPatch = "Bond";
  124. m_pBond = new Bond(0);
  125. if (m_pCViewInterface != nullptr)
  126. {
  127. std::vector<ns_mat::POINT_INFO_STRUCT> stPointInfo;
  128. m_pCViewInterface->GetBondAllPointInfo(stPointInfo);
  129. m_pBond->UpdataVal(stPointInfo);
  130. }
  131. else
  132. {
  133. m_pBond->UpdataGenerateTestData();
  134. }
  135. }
  136. break;
  137. default:
  138. break;
  139. }
  140. return strLoadPatch;
  141. }
  142. QList<QPair<QString, QString>> CameraImageHandler::loadImages(const CameraInfo& cameraInfo,const QString &dirPath)
  143. {
  144. QDir directory(dirPath);
  145. if (!directory.exists()) {
  146. qWarning() << "Directory does not exist:" << dirPath;
  147. }
  148. // 支持的图片格式过滤器
  149. QStringList filters;
  150. filters << "*.png" << "*.jpg" << "*.jpeg" << "*.bmp" << "*.gif";
  151. // 递归遍历所有子目录,忽略大小写
  152. QDirIterator it(dirPath, filters, QDir::Files | QDir::NoDotAndDotDot,
  153. QDirIterator::Subdirectories);
  154. QList<QPair<QString, QString>> fileList;
  155. fileList.append(qMakePair(QString::fromStdString(cameraInfo.name), QString("1")));
  156. while (it.hasNext()) {
  157. QString filePath = it.next();
  158. QFileInfo fileInfo(filePath);
  159. // 添加文件名和完整路径到列表
  160. fileList.append(qMakePair(fileInfo.fileName(), filePath));
  161. }
  162. return fileList;
  163. }