From ccbda3e4f7ed430843fbc0190e8ee0d0f0e3a721 Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期二, 21 一月 2025 11:06:16 +0800
Subject: [PATCH] 1.SECS实现Off-Line和On-Line消息处理回调应用层,如何切换状态需待和机器端确定。
---
SourceCode/Bond/Servo/HsmsPassive.cpp | 241 +++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 225 insertions(+), 16 deletions(-)
diff --git a/SourceCode/Bond/Servo/HsmsPassive.cpp b/SourceCode/Bond/Servo/HsmsPassive.cpp
index 5a62733..b77ee1a 100644
--- a/SourceCode/Bond/Servo/HsmsPassive.cpp
+++ b/SourceCode/Bond/Servo/HsmsPassive.cpp
@@ -38,6 +38,7 @@
m_bCimWorking = FALSE;
m_hCimWorkEvent = ::CreateEvent(NULL, TRUE, FALSE, NULL);
m_nSessionId = 1;
+ m_listener.onEQConstantRequest = nullptr;
InitializeCriticalSection(&m_criticalSection);
}
@@ -59,6 +60,14 @@
m_hCimWorkEvent = NULL;
}
DeleteCriticalSection(&m_criticalSection);
+}
+
+void CHsmsPassive::setListener(SECSListener listener)
+{
+ m_listener.onEQOffLine = listener.onEQOffLine;
+ m_listener.onEQOnLine = listener.onEQOnLine;
+ m_listener.onEQConstantRequest = listener.onEQConstantRequest;
+ m_listener.onEQConstantSend = listener.onEQConstantSend;
}
void CHsmsPassive::setActionTimeout(int nSecond)
@@ -177,10 +186,22 @@
LOGI("<HSMS>收到消息 S%dF%d", nStream, pHeader->function);
if (nStream == 1 && pHeader->function == 1) {
// S1F1
- replyAreYouThere(pHeader->systemBytes);
+ replyAreYouThere(pMessage);
}
else if (nStream == 1 && pHeader->function == 13) {
- replyEstablishCommunications(pHeader->systemBytes);
+ replyEstablishCommunications(pMessage);
+ }
+ else if (nStream == 1 && pHeader->function == 15) {
+ replyOffLine(pMessage);
+ }
+ else if (nStream == 1 && pHeader->function == 17) {
+ replyOnLine(pMessage);
+ }
+ else if (nStream == 2 && pHeader->function == 13) {
+ replyEquipmentConstantRequest(pMessage);
+ }
+ else if (nStream == 2 && pHeader->function == 15) {
+ replyEquipmentConstantSend(pMessage);
}
else if (nStream == 2 && pHeader->function == 31) {
replyDatetime(pMessage);
@@ -190,6 +211,9 @@
}
else if (nStream == 5 && pHeader->function == 3) {
replyEanbleDisableAlarmReport(pMessage);
+ }
+ else if (nStream == 7 && pHeader->function == 19) {
+ replyQueryPPIDList(pMessage);
}
else if (nStream == 10 && pHeader->function == 3) {
replyTerminalDisplay(pMessage);
@@ -302,7 +326,7 @@
HSMS_Create1Message(pMessage, m_nSessionId, s, f, systemBytes);
ASSERT(pMessage);
ISECS2Item* pItem = pMessage->getBody();
- pItem->setBinary(ack, pszAckName);
+ pItem->setBinary((const char*)&ack, 1, pszAckName);
m_pPassive->sendMessage(pMessage);
LOGI("<HSMS>[SECS Msg SEND]S%dF%d (SysByte=%u)", s, f, systemBytes);
HSMS_Destroy1Message(pMessage);
@@ -330,14 +354,14 @@
}
// S1F2
-int CHsmsPassive::replyAreYouThere(unsigned int systemBytes)
+int CHsmsPassive::replyAreYouThere(IMessage* pRecv)
{
if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
return ER_NOTSELECT;
}
IMessage* pMessage = NULL;
- HSMS_Create1Message(pMessage, m_nSessionId, 1, 2, systemBytes);
+ HSMS_Create1Message(pMessage, m_nSessionId, 1, 2, pRecv->getHeader()->systemBytes);
ASSERT(pMessage);
ISECS2Item* pItem = pMessage->getBody();
@@ -350,15 +374,52 @@
return 0;
}
-// S1F14
-int CHsmsPassive::replyEstablishCommunications(unsigned int systemBytes)
+// S1F15
+int CHsmsPassive::replyOffLine(IMessage* pRecv)
+{
+ if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
+ return ER_NOTSELECT;
+ }
+
+
+ // 交由上层应用来获取机器常量值
+ if (m_listener.onEQOffLine != nullptr) {
+ m_listener.onEQOffLine(this);
+ }
+
+
+ // 回复
+ replyAck(1, 16, pRecv->getHeader()->systemBytes, BYTE(0), "OFLACK");
+ return 0;
+}
+
+// S1F17
+int CHsmsPassive::replyOnLine(IMessage* pRecv)
+{
+ if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
+ return ER_NOTSELECT;
+ }
+
+
+ // 交由上层应用来获取机器常量值
+ if (m_listener.onEQOnLine != nullptr) {
+ m_listener.onEQOnLine(this);
+ }
+
+
+ // 回复
+ replyAck(1, 18, pRecv->getHeader()->systemBytes, BYTE(0), "ONLACK");
+ return 0;
+}
+
+int CHsmsPassive::replyEstablishCommunications(IMessage* pRecv)
{
if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
return ER_NOTSELECT;
}
IMessage* pMessage = NULL;
- HSMS_Create1Message(pMessage, m_nSessionId, 1, 14, systemBytes);
+ HSMS_Create1Message(pMessage, m_nSessionId, 1, 14, pRecv->getHeader()->systemBytes);
ASSERT(pMessage);
ISECS2Item* pItem = pMessage->getBody();
@@ -373,6 +434,96 @@
return 0;
}
+// S2F13
+int CHsmsPassive::replyEquipmentConstantRequest(IMessage* pRecv)
+{
+ if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
+ return ER_NOTSELECT;
+ }
+
+
+ // 要获取的常量表表
+ BOOL bCheckData = FALSE;
+ std::vector<EQConstant> eqcs;
+ {
+ ISECS2Item* pItem = pRecv->getBody();
+ int ecidSize = pItem->getSubItemSize();
+ for (int i = 0; i < ecidSize; i++) {
+ EQConstant eqc;
+ unsigned short id;
+ if (pItem->getSubItemU2(i, id)) {
+ eqc.id = id;
+ eqcs.push_back(eqc);
+ }
+ }
+ }
+
+
+ // 交由上层应用来获取机器常量值
+ if (m_listener.onEQConstantRequest != nullptr) {
+ m_listener.onEQConstantRequest(this, eqcs);
+ }
+
+
+ // 回复
+ IMessage* pMessage = NULL;
+ HSMS_Create1Message(pMessage, m_nSessionId, 1, 14, pRecv->getHeader()->systemBytes);
+ ASSERT(pMessage);
+ ISECS2Item* pItem = pMessage->getBody();
+ for (auto& item : eqcs) {
+ pItem->addItem(item.szValue, "ECV");
+ }
+
+ m_pPassive->sendMessage(pMessage);
+ LOGI("<HSMS>[SECS Msg SEND]S2F14 (SysByte=%u)", pMessage->getHeader()->systemBytes);
+ HSMS_Destroy1Message(pMessage);
+
+ return 0;
+}
+
+// S2F15
+int CHsmsPassive::replyEquipmentConstantSend(IMessage* pRecv)
+{
+ if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
+ return ER_NOTSELECT;
+ }
+
+
+ // 要设置的常量表表
+ BOOL bCheckData = FALSE;
+ std::vector<EQConstant> eqcs;
+ {
+ ISECS2Item* pItem = pRecv->getBody();
+ int ecidSize = pItem->getSubItemSize();
+ for (int i = 0; i < ecidSize; i++) {
+ ISECS2Item* pItemEqc = pItem->getSubItem(i);
+ if (pItemEqc != nullptr) {
+ EQConstant eqc;
+ unsigned short eqcid;
+ const char* pszValue;
+ if (pItemEqc->getSubItemU2(0, eqcid)
+ && pItemEqc->getSubItemString(1, pszValue)) {
+ eqc.id = eqcid;
+ strcpy_s(eqc.szValue, 256, pszValue);
+ eqcs.push_back(eqc);
+ }
+ }
+ }
+ }
+
+
+ // 交由上层应用来保存和设置机器常量值
+ std::vector<unsigned int> ecvs;
+ if (m_listener.onEQConstantSend != nullptr) {
+ m_listener.onEQConstantSend(this, eqcs);
+ }
+
+
+ // 回复
+ replyAck(2, 16, pRecv->getHeader()->systemBytes, BYTE(0), "EACK");
+ return 0;
+}
+
// S2F31
int CHsmsPassive::replyDatetime(IMessage* pRecv)
{
@@ -381,7 +532,7 @@
}
ISECS2Item* pBody = pRecv->getBody();
if (pBody == nullptr || pBody->getType() != SITYPE::A) ER_PARAM_ERROR;
- char* pszMessage;
+ const char* pszMessage;
if (pBody->getString(pszMessage)) {
// 更新时间
SYSTEMTIME time;
@@ -459,20 +610,77 @@
BOOL bCheckData = FALSE;
- BYTE ALED;
+ const char* ALED;
unsigned int ALID;
+ unsigned int ALEDLEN;
{
ISECS2Item* pItem = pRecv->getBody();
if (pItem->getSubItemSize() < 2) goto MYREPLY;
- if (!pItem->getSubItemBinary(0, ALED)) goto MYREPLY;
+ if (!pItem->getSubItemBinary(0, ALED, ALEDLEN)) goto MYREPLY;
if (!pItem->getSubItemU4(1, ALID)) goto MYREPLY;
bCheckData = TRUE;
- LOGI("EanbleDisableAlarmReport ALED:%d, ALID:%d", ALED, ALID);
+ LOGI("EanbleDisableAlarmReport ALED:0x%02x, ALID:%d", ALED[0], ALID);
+
+ double d;
+ float f;
+ pItem->getSubItemF4(2, f);
+ pItem->getSubItemF8(3, d);
+ LOGI("EanbleDisableAlarmReport d:%lf, f:%f",
+ d, f);
+ /*
+ unsigned long long n1;
+ unsigned int n2;
+ unsigned short n3;
+ unsigned char n4;
+ long long sn1;
+ int sn2;
+ short sn3;
+ char sn4;
+ pItem->getSubItemU8(2, n1);
+ pItem->getSubItemU4(3, n2);
+ pItem->getSubItemU2(4, n3);
+ pItem->getSubItemU1(5, n4);
+ pItem->getSubItemI8(6, sn1);
+ pItem->getSubItemI4(7, sn2);
+ pItem->getSubItemI2(8, sn3);
+ pItem->getSubItemI1(9, sn4);
+
+ LOGI("EanbleDisableAlarmReport n1:%llu, n2:%u, n3:%hu, n4:%hhu",
+ n1, n2, n3, n4);
+ LOGI("EanbleDisableAlarmReport sn1:%lld, sn2:%d, sn3:%hd, sn4:%hhd",
+ sn1, sn2, sn3, sn4);
+ */
}
MYREPLY:
replyAck(5, 4, pRecv->getHeader()->systemBytes, BYTE(0), "ACKC5");
+ return 0;
+}
+
+// S7F19
+int CHsmsPassive::replyQueryPPIDList(IMessage* pRecv)
+{
+ if (m_pPassive == NULL || STATE::SELECTED != m_pPassive->getState()) {
+ return ER_NOTSELECT;
+ }
+
+
+ IMessage* pMessage = NULL;
+ HSMS_Create1Message(pMessage, m_nSessionId, 7, 20, pRecv->getHeader()->systemBytes);
+ ASSERT(pMessage);
+
+ ISECS2Item* pItem = pMessage->getBody();
+ pItem->addItem("banana1", "PPID1");
+ pItem->addItem("banana2", "PPID2");
+ pItem->addF8Item(-123.45, "PPID2");
+ pItem->addF4Item(-568.99f, "PPID2");
+ pItem->addF8Item(456.456, "PPID2");
+ pItem->addF4Item(123.123f, "PPID2");
+ m_pPassive->sendMessage(pMessage);
+ LOGI("<HSMS>[SECS Msg SEND]S7F20 (SysByte=%u)", pMessage->getHeader()->systemBytes);
+ HSMS_Destroy1Message(pMessage);
+
return 0;
}
@@ -488,15 +696,16 @@
BOOL bCheckData = FALSE;
- BYTE tid;
- char* pszText = nullptr;;
+ const char* tid;
+ unsigned int tidlen;
+ const char* pszText = nullptr;;
{
ISECS2Item* pItem = pRecv->getBody();
if (pItem->getSubItemSize() < 2) goto MYREPLY;
- if (!pItem->getSubItemBinary(0, tid)) goto MYREPLY;
+ if (!pItem->getSubItemBinary(0, tid, tidlen)) goto MYREPLY;
if (!pItem->getSubItemString(1, pszText)) goto MYREPLY;
bCheckData = TRUE;
- LOGI("TerminalDisplay tid:%d, pszText:%s", tid, pszText);
+ LOGI("TerminalDisplay tid:0x%02x, pszText:%s", tid[0], pszText);
m_pModel->notifyText(RX_HSMS_TERMINAL_TEXT, pszText);
}
--
Gitblit v1.9.3