From bfe14e41fa5b07771d78af4511ba18d706bc23cc Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期一, 28 七月 2025 17:07:52 +0800
Subject: [PATCH] 1.Spooling Config功能EAP模拟测试;
---
SourceCode/Bond/Servo/CPageGraph1.cpp | 152 ++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 126 insertions(+), 26 deletions(-)
diff --git a/SourceCode/Bond/Servo/CPageGraph1.cpp b/SourceCode/Bond/Servo/CPageGraph1.cpp
index 70fefb3..6378512 100644
--- a/SourceCode/Bond/Servo/CPageGraph1.cpp
+++ b/SourceCode/Bond/Servo/CPageGraph1.cpp
@@ -7,9 +7,6 @@
#include "afxdialogex.h"
#include "Common.h"
-const POINT g_arm1Offset = { -30, -45 }; // ARM1 浠庝腑蹇冨悜宸�47, 鍚戜笂33
-const POINT g_arm2Offset = { 27, -45 }; // ARM2 浠庝腑蹇冨悜鍙�10, 鍚戜笂33
-
const std::map<SERVO::ROBOT_POSITION, RobotPositionMapping> g_positionMap = {
{ SERVO::ROBOT_POSITION::Port1, { SERVO::ROBOT_POSITION::Port1, 1.00f, 0.00f } },
{ SERVO::ROBOT_POSITION::Port2, { SERVO::ROBOT_POSITION::Port2, 0.90f, 0.00f } },
@@ -41,6 +38,10 @@
#define INDICATE_BAKE_COOLING 12
#define INDICATE_MEASUREMENT 13
+// 瀹氭椂鍣�
+#define TIMER_ID_DEVICE_STATUS 1 // 鐢ㄤ簬鍒濆鍖栬澶囩姸鎬�
+#define TIMER_ID_ROBOT_STATUS 2 // 鐢ㄤ簬鍛ㄦ湡鍒锋柊鏈哄櫒浜轰綅缃�/鑷傜姸鎬�
+
// CPageGraph1 瀵硅瘽妗�
IMPLEMENT_DYNAMIC(CPageGraph1, CDialogEx)
@@ -53,6 +54,15 @@
m_bIsRobotMoving = FALSE;
m_crBkgnd = PAGE_GRPAH1_BACKGROUND_COLOR;
m_hbrBkgnd = nullptr;
+ m_lastRobotPosition = SERVO::ROBOT_POSITION::Port1;
+ m_lastArmState[0] = FALSE;
+ m_lastArmState[1] = FALSE;
+
+ m_arm1Offset = LoadArmOffset("ARM1");
+ m_arm2Offset = LoadArmOffset("ARM2");
+
+ //m_arm1Offset = { -30, -45 }; // ARM1 浠庝腑蹇冨悜宸�47, 鍚戜笂33
+ //m_arm2Offset = { 27, -45 }; // ARM2 浠庝腑蹇冨悜鍙�10, 鍚戜笂33
}
CPageGraph1::~CPageGraph1()
@@ -77,6 +87,15 @@
// CPageGraph1 娑堟伅澶勭悊绋嬪簭
+std::string CPageGraph1::GetConfigPath()
+{
+ char path[MAX_PATH];
+ GetModuleFileNameA(NULL, path, MAX_PATH);
+ std::string exePath(path);
+ std::string configDir = exePath.substr(0, exePath.find_last_of("\\/")) + "\\Config";
+ CreateDirectoryA(configDir.c_str(), NULL);
+ return configDir + "\\robot_offset.ini";
+}
void CPageGraph1::InitRxWindows()
{
@@ -148,8 +167,8 @@
{
CDialogEx::OnInitDialog();
InitRxWindows();
- SetTimer(1, 3000, nullptr);
-
+ SetTimer(TIMER_ID_DEVICE_STATUS, 3000, nullptr);
+ SetTimer(TIMER_ID_ROBOT_STATUS, 1000, nullptr); // 姣� 1000ms 鏇存柊涓�娆$姸鎬�
// 鍥剧ず
m_pGraph = CServoGraph::Hook(GetDlgItem(IDC_SERVO_GRAPH1)->GetSafeHwnd());
@@ -251,7 +270,12 @@
newFrameColor2 = EQ_BOX_FRAME2;
break;
case OFFLINE:
- newBackgroundColor = RGB(222, 222, 222);
+ newBackgroundColor = EQ_BOX_OFFLINE;
+ newFrameColor1 = EQ_BOX_FRAME1;
+ newFrameColor2 = EQ_BOX_FRAME2;
+ break;
+ case OCCUPIED:
+ newBackgroundColor = EQ_BOX_OCCUPIED;
newFrameColor1 = EQ_BOX_FRAME1;
newFrameColor2 = EQ_BOX_FRAME2;
break;
@@ -300,6 +324,8 @@
{
CDialogEx::OnDestroy();
+ KillTimer(TIMER_ID_ROBOT_STATUS);
+
if (m_hbrBkgnd != nullptr) {
::DeleteObject(m_hbrBkgnd);
}
@@ -308,6 +334,9 @@
m_pObserver->unsubscribe();
m_pObserver = NULL;
}
+
+ SaveArmOffset("ARM1", m_arm1Offset);
+ SaveArmOffset("ARM2", m_arm2Offset);
}
void CPageGraph1::OnSize(UINT nType, int cx, int cy)
@@ -354,10 +383,10 @@
int cx = currentX + pImage->bmWidth / 2;
// 鏃嬭浆鍚庣殑鍋忕Щ
- int rotatedX1 = static_cast<int>(cos(radians) * g_arm1Offset.x - sin(radians) * g_arm1Offset.y);
- int rotatedY1 = static_cast<int>(sin(radians) * g_arm1Offset.x + cos(radians) * g_arm1Offset.y);
- int rotatedX2 = static_cast<int>(cos(radians) * g_arm2Offset.x - sin(radians) * g_arm2Offset.y);
- int rotatedY2 = static_cast<int>(sin(radians) * g_arm2Offset.x + cos(radians) * g_arm2Offset.y);
+ int rotatedX1 = static_cast<int>(cos(radians) * m_arm1Offset.x - sin(radians) * m_arm1Offset.y);
+ int rotatedY1 = static_cast<int>(sin(radians) * m_arm1Offset.x + cos(radians) * m_arm1Offset.y);
+ int rotatedX2 = static_cast<int>(cos(radians) * m_arm2Offset.x - sin(radians) * m_arm2Offset.y);
+ int rotatedY2 = static_cast<int>(sin(radians) * m_arm2Offset.x + cos(radians) * m_arm2Offset.y);
// 搴旂敤鎵�鏈夊厓绱犵殑鏂板潗鏍�
m_pGraph->UpdateImageCoordinates(IMAGE_ROBOT, currentX, y);
@@ -371,10 +400,10 @@
// 鏈�缁堜綅缃牎姝�
int cx = endX + pImage->bmWidth / 2;
- int rotatedX1 = static_cast<int>(cos(radians) * g_arm1Offset.x - sin(radians) * g_arm1Offset.y);
- int rotatedY1 = static_cast<int>(sin(radians) * g_arm1Offset.x + cos(radians) * g_arm1Offset.y);
- int rotatedX2 = static_cast<int>(cos(radians) * g_arm2Offset.x - sin(radians) * g_arm2Offset.y);
- int rotatedY2 = static_cast<int>(sin(radians) * g_arm2Offset.x + cos(radians) * g_arm2Offset.y);
+ int rotatedX1 = static_cast<int>(cos(radians) * m_arm1Offset.x - sin(radians) * m_arm1Offset.y);
+ int rotatedY1 = static_cast<int>(sin(radians) * m_arm1Offset.x + cos(radians) * m_arm1Offset.y);
+ int rotatedX2 = static_cast<int>(cos(radians) * m_arm2Offset.x - sin(radians) * m_arm2Offset.y);
+ int rotatedY2 = static_cast<int>(sin(radians) * m_arm2Offset.x + cos(radians) * m_arm2Offset.y);
m_pGraph->UpdateImageCoordinates(IMAGE_ROBOT, endX, y);
m_pGraph->UpdateIndicateBoxCoordinates(INDICATE_ROBOT_ARM1, cx + rotatedX1, cy + rotatedY1);
@@ -402,12 +431,12 @@
float radians = angleInDegrees * 3.1415926f / 180.0f;
// 鏃嬭浆 offset1
- int rotatedX1 = static_cast<int>(cos(radians) * g_arm1Offset.x - sin(radians) * g_arm1Offset.y);
- int rotatedY1 = static_cast<int>(sin(radians) * g_arm1Offset.x + cos(radians) * g_arm1Offset.y);
+ int rotatedX1 = static_cast<int>(cos(radians) * m_arm1Offset.x - sin(radians) * m_arm1Offset.y);
+ int rotatedY1 = static_cast<int>(sin(radians) * m_arm1Offset.x + cos(radians) * m_arm1Offset.y);
// 鏃嬭浆 offset2
- int rotatedX2 = static_cast<int>(cos(radians) * g_arm2Offset.x - sin(radians) * g_arm2Offset.y);
- int rotatedY2 = static_cast<int>(sin(radians) * g_arm2Offset.x + cos(radians) * g_arm2Offset.y);
+ int rotatedX2 = static_cast<int>(cos(radians) * m_arm2Offset.x - sin(radians) * m_arm2Offset.y);
+ int rotatedY2 = static_cast<int>(sin(radians) * m_arm2Offset.x + cos(radians) * m_arm2Offset.y);
// 鏇存柊鎸囩ず妗�
m_pGraph->UpdateIndicateBoxCoordinates(INDICATE_ROBOT_ARM1, cx + rotatedX1, cy + rotatedY1);
@@ -461,6 +490,29 @@
// 鏃嬭浆鏂瑰悜
RotateRobot(mapping.angle);
+
+ m_lastRobotPosition = position;
+}
+
+POINT CPageGraph1::LoadArmOffset(const std::string& armName)
+{
+ std::string iniPath = GetConfigPath();
+ POINT pt;
+ pt.x = GetPrivateProfileIntA("Offsets", (armName + "_X").c_str(), 0, iniPath.c_str());
+ pt.y = GetPrivateProfileIntA("Offsets", (armName + "_Y").c_str(), 0, iniPath.c_str());
+ return pt;
+}
+
+void CPageGraph1::SaveArmOffset(const std::string& armName, const POINT& pt)
+{
+ std::string iniPath = GetConfigPath();
+ char buf[16];
+
+ sprintf_s(buf, "%d", pt.x);
+ WritePrivateProfileStringA("Offsets", (armName + "_X").c_str(), buf, iniPath.c_str());
+
+ sprintf_s(buf, "%d", pt.y);
+ WritePrivateProfileStringA("Offsets", (armName + "_Y").c_str(), buf, iniPath.c_str());
}
void CPageGraph1::OnGraphItemClicked(NMHDR* pNMHDR, LRESULT* pResult)
@@ -501,26 +553,26 @@
else if (pGraphNmhdr->dwData == INDICATE_MEASUREMENT) {
MoveRobotToPosition(SERVO::ROBOT_POSITION::Measurement);
}
-
- CString s; s.Format(_T("OnGraphItemClicked %d"), pGraphNmhdr->dwData);
- SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)m_pGraph->GetIndicateBoxData(pGraphNmhdr->dwData);
- if (pEquipment != nullptr) {
- theApp.m_model.notifyPtr(RX_CODE_SELECT_EQUIPMENT, pEquipment);
- }
*pResult = 0;
}
void CPageGraph1::OnTimer(UINT_PTR nIDEvent)
{
- if (1 == nIDEvent) {
- KillTimer(1);
+ if (TIMER_ID_DEVICE_STATUS == nIDEvent) {
+ KillTimer(TIMER_ID_DEVICE_STATUS);
// 鏇存柊鐘舵��
{
SERVO::CEquipment* pEquipment = (SERVO::CEFEM*)theApp.m_model.m_master.getEquipment(EQ_ID_EFEM);
ASSERT(pEquipment);
DeviceStatus status = pEquipment->isAlive() ? DeviceStatus::ONLINE : DeviceStatus::OFFLINE;
+ UpdateDeviceStatus(INDICATE_FLIPER, status);
+ UpdateDeviceStatus(INDICATE_ALIGNER, status);
+ UpdateDeviceStatus(INDICATE_LPORT1, status);
+ UpdateDeviceStatus(INDICATE_LPORT2, status);
+ UpdateDeviceStatus(INDICATE_LPORT3, status);
+ UpdateDeviceStatus(INDICATE_LPORT4, status);
UpdateDeviceStatus(INDICATE_ROBOT_ARM1, status);
UpdateDeviceStatus(INDICATE_ROBOT_ARM2, status);
}
@@ -538,6 +590,54 @@
DeviceStatus status = pEquipment->isAlive() ? DeviceStatus::ONLINE : DeviceStatus::OFFLINE;
UpdateDeviceStatus(INDICATE_BONDER2, status);
}
+
+ {
+ SERVO::CEquipment* pEquipment = theApp.m_model.m_master.getEquipment(EQ_ID_VACUUMBAKE);
+ ASSERT(pEquipment);
+ DeviceStatus status = pEquipment->isAlive() ? DeviceStatus::ONLINE : DeviceStatus::OFFLINE;
+ UpdateDeviceStatus(INDICATE_VACUUM_BAKE, status);
+ }
+
+ {
+ SERVO::CEquipment* pEquipment = theApp.m_model.m_master.getEquipment(EQ_ID_BAKE_COOLING);
+ ASSERT(pEquipment);
+ DeviceStatus status = pEquipment->isAlive() ? DeviceStatus::ONLINE : DeviceStatus::OFFLINE;
+ UpdateDeviceStatus(INDICATE_BAKE_COOLING, status);
+ }
+
+ {
+ SERVO::CEquipment* pEquipment = theApp.m_model.m_master.getEquipment(EQ_ID_MEASUREMENT);
+ ASSERT(pEquipment);
+ DeviceStatus status = pEquipment->isAlive() ? DeviceStatus::ONLINE : DeviceStatus::OFFLINE;
+ UpdateDeviceStatus(INDICATE_MEASUREMENT, status);
+ }
+ }
+ else if (nIDEvent == TIMER_ID_ROBOT_STATUS) {
+ SERVO::CEFEM* pEFEM = (SERVO::CEFEM*)theApp.m_model.m_master.getEquipment(EQ_ID_EFEM);
+ if (!pEFEM || !pEFEM->isAlive()) {
+ return;
+ }
+
+ // 濡傛灉璁惧鍦ㄧ嚎锛岄偅涔堟洿鏂� ARM 鐘舵��
+ SERVO::RMDATA& robotData = pEFEM->getRobotMonitoringData();
+ if (m_lastArmState[0] != robotData.armState[0]) {
+ m_lastArmState[0] = robotData.armState[0];
+ DeviceStatus arm1Status;
+ arm1Status = robotData.armState[0] ? DeviceStatus::OCCUPIED : DeviceStatus::ONLINE;
+ UpdateDeviceStatus(INDICATE_ROBOT_ARM1, arm1Status);
+ }
+
+ if (m_lastArmState[1] != robotData.armState[1]) {
+ m_lastArmState[1] = robotData.armState[1];
+ DeviceStatus arm2Status;
+ arm2Status = robotData.armState[1] ? DeviceStatus::OCCUPIED : DeviceStatus::ONLINE;
+ UpdateDeviceStatus(INDICATE_ROBOT_ARM2, arm2Status);
+ }
+
+ // 浣嶇疆淇℃伅鐘舵�佹樉绀�
+ if (robotData.position != m_lastRobotPosition) {
+ MoveRobotToPosition(robotData.position);
+ }
}
CDialogEx::OnTimer(nIDEvent);
--
Gitblit v1.9.3