Wafer.cpp 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. #include "Wafer.h"
  2. #include <QPainter>
  3. #include <QPaintEvent>
  4. #include <cmath>
  5. #include <QDebug>
  6. #include <QPushButton>
  7. #include <QGridLayout>
  8. Wafer::Wafer(int flag, QWidget *parent) : QWidget(parent) {
  9. }
  10. void Wafer::UpdataGenerateTestData()
  11. {
  12. /*
  13. Flag = 0;
  14. rows = 51;
  15. cols = 51;
  16. centerX = 25;
  17. centerY = 25;
  18. radius = 25;
  19. // 随机数初始化
  20. std::srand(std::time(nullptr)); // 使用当前时间作为种子
  21. // 遍历矩阵,按行列判断是否在圆形区域内
  22. for (int row = 0; row < rows; ++row) {
  23. for (int col = 0; col < cols; ++col) {
  24. // 计算当前点到中心点的距离
  25. double dx = col - centerX;
  26. double dy = row - centerY;
  27. double distance = std::sqrt(dx * dx + dy * dy);
  28. // 如果点在圆形区域外部,跳过
  29. if (distance > radius) {
  30. continue;
  31. }
  32. // 创建一个新的WAFER_MATRIX_POINT_INFO_STRUCT
  33. ns_mat::WAFER_MATRIX_POINT_INFO_STRUCT point;
  34. point.nDieMatrixId = 1; // 假设所有点属于同一晶圆矩阵
  35. point.nDieRow = row;
  36. point.nDieCol = col;
  37. point.iDieIndex = row * cols + col; // 假设ID为行列号的线性映射
  38. point.bDisable = false; // 默认为可用
  39. point.stPosition.x = col * 10.0;
  40. point.stPosition.y = row * 10.0;
  41. // 判断该点是否在圆形区域的边缘
  42. if (distance > radius - 1 && distance < radius + 1) {
  43. point.eStatus = ns_mat::PICK_DIE_STATUS::EDGE_DIE; // 如果在边缘区域,状态设置为EDGE_DIE
  44. }
  45. else {
  46. // 如果在圆形区域内,随机设置其他状态
  47. int randomStatus = std::rand() % 4; // 随机选取DIE_EXIST, PICK_ING, NO_EXIST, SKIP_DIE
  48. point.eStatus = static_cast<ns_mat::PICK_DIE_STATUS>(randomStatus);
  49. }
  50. // 将点添加到waferData容器中
  51. waferData.append(point);
  52. }
  53. }
  54. */
  55. }
  56. void Wafer::UpdataVal(const std::vector<ns_mat::WAFER_MATRIX_POINT_INFO_STRUCT>& veWafer)
  57. {
  58. int currentDieMatrixId = veWafer[0].nDieMatrixId;
  59. int rowMax = veWafer[0].nDieRow;
  60. int colsMax = veWafer[0].nDieCol;
  61. double minx = veWafer[0].stPosition.x;
  62. double miny = veWafer[0].stPosition.y;
  63. double maxx = veWafer[0].stPosition.x;
  64. double maxy = veWafer[0].stPosition.y;
  65. for (const auto a : veWafer)
  66. {
  67. waferData.append(a);
  68. qDebug() << a.stPosition.x << " " << a.stPosition.y;
  69. if (a.nDieMatrixId != currentDieMatrixId) {
  70. maxRow_Colmap.insert(currentDieMatrixId, { rowMax ,colsMax,minx,miny,maxx,maxy });
  71. currentDieMatrixId = a.nDieMatrixId;
  72. rowMax = a.nDieRow;
  73. colsMax = a.nDieCol;
  74. minx = a.stPosition.x;
  75. maxx = a.stPosition.x;
  76. miny = a.stPosition.y;
  77. maxy = a.stPosition.y;
  78. }
  79. else {
  80. if (a.nDieRow >= rowMax) rowMax = a.nDieRow;
  81. if (a.nDieCol >= colsMax) colsMax = a.nDieCol;
  82. if (a.stPosition.x >= maxx) maxx = a.stPosition.x;
  83. if (a.stPosition.y <= maxx) maxx = a.stPosition.y;
  84. if (a.stPosition.x >= minx) minx = a.stPosition.x;
  85. if (a.stPosition.x <= miny) miny = a.stPosition.y;
  86. }
  87. }
  88. maxRow_Colmap.insert(currentDieMatrixId, { rowMax ,colsMax,minx,miny,maxx,maxy });
  89. }
  90. QColor Wafer::getColorByStatus(ns_mat::PICK_DIE_STATUS status) {
  91. switch (status) {
  92. case ns_mat::PICK_DIE_STATUS::DIE_EXIST: return QColor(0, 102, 255); // 蓝色
  93. case ns_mat::PICK_DIE_STATUS::NO_EXIST: return QColor(200, 200, 200); // 浅灰
  94. case ns_mat::PICK_DIE_STATUS::PICK_ING: return QColor(255, 255, 0); // 黄色
  95. case ns_mat::PICK_DIE_STATUS::SKIP_DIE: return QColor(128, 128, 128); // 深灰
  96. case ns_mat::PICK_DIE_STATUS::EDGE_DIE: return QColor(255, 165, 0); // 橙色
  97. default: return QColor(0, 0, 0); // 默认黑色
  98. }
  99. }
  100. void Wafer::paintInitFrom(QWidget *parent) {
  101. /*
  102. // 获取当前窗口的宽高
  103. int width = parent->width();
  104. int height = parent->height();
  105. // 根据行列数计算每个晶圆点的大小,选择小的边来决定
  106. int cellSize = qMin(width, height) / qMax(rows, cols); // 固定大小为正方形,按最小边计算
  107. // 计算左上角偏移量,居中显示
  108. int offsetX = (width - cellSize * cols) / 2;
  109. int offsetY = (height - cellSize * rows) / 2;
  110. // 创建一个 QPixmap 对象用于保存绘制的图像
  111. globalPixmap = QPixmap(width, height);
  112. globalPixmap.fill(Qt::white); // 填充背景色为白色
  113. // 创建 QPainter 以绘制到 QPixmap 上
  114. QPainter painter(&globalPixmap);
  115. painter.setRenderHint(QPainter::Antialiasing); // 启用抗锯齿
  116. // 设置画笔为无边框
  117. painter.setPen(Qt::NoPen);
  118. // 绘制每个晶圆点
  119. for (int i = 0; i < waferData.size(); ++i) {
  120. int x = offsetX + waferData[i].nDieCol * cellSize;
  121. int y = offsetY + waferData[i].nDieRow * cellSize;
  122. // 根据点的状态设置颜色
  123. painter.setBrush(getColorByStatus(waferData[i].eStatus));
  124. // 绘制晶圆点(每个点是一个矩形)
  125. painter.drawRect(x, y, cellSize, cellSize);
  126. }
  127. // 根据角度绘制黑点
  128. int centerX, centerY;
  129. int angle = 0;
  130. switch (angle) {
  131. case 0: {
  132. centerX = offsetX + (cols / 2) * cellSize;
  133. centerY = offsetY + (rows - 1) * cellSize;
  134. break;
  135. }
  136. case 90: {
  137. centerX = offsetX;
  138. centerY = offsetY + (rows / 2) * cellSize;
  139. break;
  140. }
  141. case 180: {
  142. centerX = offsetX + (cols / 2) * cellSize;
  143. centerY = offsetY;
  144. break;
  145. }
  146. case 270: {
  147. centerX = offsetX + (cols - 1) * cellSize;
  148. centerY = offsetY + (rows / 2) * cellSize;
  149. break;
  150. }
  151. default:
  152. return;
  153. }
  154. painter.setBrush(Qt::black);
  155. painter.drawEllipse(centerX - 3, centerY - 3, 6, 6);
  156. painter.end(); // 结束绘制
  157. */
  158. }
  159. void Wafer::initFrom(QWidget* parent) {
  160. //scene = new QGraphicsScene(parent);
  161. //view = new WaferGraphicsView(scene);
  162. //// 获取当前窗口的宽高
  163. double width = parent->width();
  164. double height = parent->height();
  165. //// 根据行列数计算每个晶圆点的大小,选择小的边来决定
  166. //int cellSize = qMin(width, height) / qMax(rows, cols); // 固定大小为正方形,按最小边计算
  167. //for (int i = 0; i < waferData.size(); ++i) {
  168. // DieItem* die = new DieItem(waferData[i].nDieRow, waferData[i].nDieCol, waferData[i].eStatus, cellSize);
  169. // die->setPos(waferData[i].nDieCol * cellSize, waferData[i].nDieRow * cellSize);
  170. // scene->addItem(die);
  171. //}
  172. //view->setSceneRect(scene->itemsBoundingRect());
  173. //view->resize(width, height);
  174. // 创建视图
  175. scene = new QGraphicsScene(parent);
  176. view = new WaferGraphicsView(scene);
  177. view->resize(width, height);
  178. QPointF center(width / 2.0, height / 2.0);
  179. QPointF pointf(m_centerX, m_centerY);
  180. double radius = width / 2 - 10;
  181. //比例
  182. double radio = m_radius / radius;
  183. int dieLong = m_dieLong / radio;
  184. int dieWide = m_dieWide / radio;
  185. // 初始化晶圆参数
  186. view->initWafer(center, // 中心坐标
  187. radius, // 半径
  188. dieLong, dieWide); // 固晶点显示尺寸
  189. // 添加固晶点
  190. int currentDieMatrixId = -1;
  191. double referPointX = 0.0;
  192. double referPointY = 0.0;
  193. MaxRow_Col maxRow_Col;
  194. for (int i = 0; i < waferData.size(); ++i) {
  195. //判断是否属于同一个矩阵
  196. if (waferData[i].nDieMatrixId != currentDieMatrixId) {
  197. //重新画矩阵框然后配置新的参考点
  198. currentDieMatrixId = waferData[i].nDieMatrixId;
  199. referPointX = center.x() + (waferData[i].stPosition.x - m_centerX) / radio;
  200. referPointY = center.y() - (waferData[i].stPosition.y - m_centerY) / radio;
  201. maxRow_Col = maxRow_Colmap.value(currentDieMatrixId);
  202. view->drawDieMatrix(QPointF(referPointX - dieLong, referPointY - dieWide), (maxRow_Col.maxRow+2) * dieLong, (maxRow_Col.maxCol+2) * dieWide);
  203. }
  204. referPointX = center.x() + (waferData[i].stPosition.x - m_centerX) / radio;
  205. referPointY = center.y() - (waferData[i].stPosition.y - m_centerY) / radio;
  206. view->addDiePoint(QPointF(referPointX, referPointY),waferData[i]);
  207. }
  208. scene->setSceneRect(0, 0, view->width(), view->height());
  209. }
  210. QPixmap Wafer::getGlobalPixmap() const {
  211. return globalPixmap;
  212. }
  213. void Wafer::setWaferInfo(ns_module::CViewInterface* CViewInterface) {
  214. m_pCViewInterface = CViewInterface;
  215. long result = m_pCViewInterface->GetViewMatrix()->GetDieSize(m_dieLong,m_dieWide);
  216. m_pCViewInterface->GetViewMatrix()->GetWaferSize(m_centerX, m_centerY,m_radius);
  217. //这里到时候更新接口时替换真实圆心点的数据
  218. /*m_dieLong = 10;
  219. m_dieWide = 10;
  220. m_radius = 200;*/
  221. m_centerX = 0;
  222. m_centerY = 0;
  223. }