From da9df9d46ed3fc50e0c03497bd9f76b8aa1a4595 Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期三, 14 一月 2026 15:37:48 +0800
Subject: [PATCH] 1.修复以下问题: 作业前置条件不足导致 PJ 验证失败:onPRJobMultiCreate 调 CMaster::setProcessJobs,CProcessJob::validate 要求“当前没有其它 PJ”(issue 1000),且 carrierPresent/slotUsable 必须为真。只要本地还有未结批的 PJ/CJ 或载具/槽位状态未就绪(ID 未绑、Slot 未使能),Host 发送的 CreateMultiPJ 会直接被丢弃(返回 size=0),但当前代码没有向 Host 回 ACK/NAK,Host 会误以为创建成功。
---
SourceCode/Bond/BoounionPLC/FileManager/AxisManager.cpp | 14 ++++++--------
1 files changed, 6 insertions(+), 8 deletions(-)
diff --git a/SourceCode/Bond/BoounionPLC/FileManager/AxisManager.cpp b/SourceCode/Bond/BoounionPLC/FileManager/AxisManager.cpp
index 49a3c62..494cdd1 100644
--- a/SourceCode/Bond/BoounionPLC/FileManager/AxisManager.cpp
+++ b/SourceCode/Bond/BoounionPLC/FileManager/AxisManager.cpp
@@ -170,17 +170,15 @@
axisInfo.startAddress = "ZR" + std::to_string(10000 + (axisId - 1) * 300);
// 设置默认的 ValueRange
- axisInfo.jogDistance = ValueRange(1.0, 10.0, 1.0);
- axisInfo.manualSpeed = ValueRange(1.0, 100.0, 10.0);
- axisInfo.autoSpeed = ValueRange(5.0, 200.0, 50.0);
- axisInfo.accelerationTime = ValueRange(1.0, 10.0, 1.0);
- axisInfo.decelerationTime = ValueRange(1.0, 10.0, 1.0);
+ axisInfo.jogDistance = ValueRange(0.0, 0.1, 0.0);
+ axisInfo.manualSpeed = ValueRange(0.001, 100.0, 10.0);
+ axisInfo.autoSpeed = ValueRange(0.001, 100.0, 10.0);
+ axisInfo.accelerationTime = ValueRange(0.001, 10.0, 0.3);
+ axisInfo.decelerationTime = ValueRange(0.001, 10.0, 0.3);
// 添加定位点并设置默认的最小值和最大值
for (int posId = 0; posId < axisInfo.positioningPointCount; ++posId) {
- double minPos = (posId + 1) * 5.0;
- double maxPos = (posId + 1) * 20.0;
- axisInfo.positions.emplace_back(PositionRange(TRUE, "Position " + std::to_string(posId + 1), ValueRange(minPos, maxPos, (posId + 1) * 10.0)));
+ axisInfo.positions.emplace_back(PositionRange(TRUE, "Position " + std::to_string(posId + 1), ValueRange(0, 100, 0)));
}
m_axes[axisId] = axisInfo;
--
Gitblit v1.9.3