From 0d885fe2e84ac5a6390ddc4d43ab701112eedc64 Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期一, 17 二月 2025 16:53:01 +0800
Subject: [PATCH] 1.各设备Alive状态获取,监听状态变化并回调应用层;
---
SourceCode/Bond/Servo/CEquipment.h | 25 +++++++++++++++++++++++++
1 files changed, 25 insertions(+), 0 deletions(-)
diff --git a/SourceCode/Bond/Servo/CEquipment.h b/SourceCode/Bond/Servo/CEquipment.h
index 9f83bb8..37d8e2b 100644
--- a/SourceCode/Bond/Servo/CEquipment.h
+++ b/SourceCode/Bond/Servo/CEquipment.h
@@ -3,13 +3,30 @@
#include "CCLinkIEControl.h"
namespace SERVO {
+#define BLOCK_BUFFER_MAX 1024
+#define ALIVE_TIMEOUT 15
+
+ typedef std::function<void(void* pEiuipment, BOOL bAlive)> ONALIVE;
+ typedef struct _EquipmentListener
+ {
+ ONALIVE onAlive;
+ } EquipmentListener;
+
// Memory Block 结构体定义
typedef struct _MemoryBlock {
unsigned int type;
unsigned int start;
unsigned int end;
unsigned int size;
+ char buffer[BLOCK_BUFFER_MAX];
} MemoryBlock;
+
+ // ALIVE
+ typedef struct _ALIVE {
+ BOOL flag;
+ int count;
+ BOOL alive;
+ } ALIVE;
class CEquipment
{
@@ -20,6 +37,7 @@
public:
virtual const char* getClassName() = 0;
+ virtual void setListener(EquipmentListener listener);
void setName(const char* pszName);
std::string& getName();
void setDescription(const char* pszDescription);
@@ -34,18 +52,25 @@
virtual void term();
virtual void onTimer(UINT nTimerid);
virtual void serialize(CArchive& ar);
+ virtual void onReceiveLBData(const char* pszData, size_t size);
+ BOOL isAlive();
+
+ private:
+ BOOL isBitOn(const char* pszData, size_t size, int index);
protected:
inline void Lock() { EnterCriticalSection(&m_criticalSection); }
inline void Unlock() { LeaveCriticalSection(&m_criticalSection); }
protected:
+ EquipmentListener m_listener;
std::string m_strName;
std::string m_strDescription;
CRITICAL_SECTION m_criticalSection;
StationIdentifier m_station;
MemoryBlock m_blockReadBit;
MemoryBlock m_blockWriteBit;
+ ALIVE m_alive;
};
}
--
Gitblit v1.9.3