#region << 版 本 注 释 >>
/*----------------------------------------------------------------
* 命名空间:WIDESEAWCS_Communicator
* 创建者:胡童庆
* 创建时间:2024/8/2 16:13:36
* 版本:V1.0.0
* 描述:基础通讯抽象类,封装连接、断开连接、读取、写入等方法
*
* ----------------------------------------------------------------
* 修改人:
* 修改时间:
* 版本:V1.0.1
* 修改说明:
*
*----------------------------------------------------------------*/
#endregion << 版 本 注 释 >>
using HslCommunication;
using HslCommunication.LogNet;
using System.Diagnostics.CodeAnalysis;
namespace WIDESEAWCS_Communicator
{
public abstract class BaseCommunicator
{
///
/// 构造函数
///
protected BaseCommunicator()
{
}
public abstract ILogNet LogNet { get; }
public abstract string Name { get; }
///
/// 获取当前通讯器是否已连接到PLC。
///
public abstract bool IsConnected { get; }
///
/// 连接到PLC。
///
/// 如果连接成功则返回true,否则返回false。
public abstract bool Connect();
///
/// 断开与工业设备的连接。
///
/// 如果成功断开连接则返回true,如果已经是断开状态则返回false。
public abstract bool Disconnect();
///
/// 从PLC读取数据。
///
/// 源地址,具体格式取决于使用的工业协议。
/// 要读取的数据长度。
/// 读取到的数据,如果读取失败则可能返回null或空数组。
public abstract byte[] Read(string address, int length);
///
/// 从PLC读取数据。
///
/// 读取数据的类型泛型。
/// 源地址,具体格式取决于使用的工业协议。
/// 要读取的数据长度。
/// 读取到的数据,如果读取失败则可能返回null或抛出异常。
public abstract T Read(string address);
///
/// 从PLC读取数据。
///
/// 源地址,具体格式取决于使用的工业协议。
/// 数据类型。
/// 读取到的数据,如果读取失败则可能返回null或抛出异常。
public abstract object ReadAsObj(string address, string dataType);
///
/// 向PLC写入数据。
///
/// 源地址,具体格式取决于使用的工业协议。
/// 要写入的数据。
/// 如果写入成功则返回true,否则返回false。
public abstract bool Write(string address, byte[] data);
///
///
///
///
///
///
///
public abstract bool Write(string address, T value) where T : notnull;
///
/// 向PLC写入数据。
///
/// 源地址,具体格式取决于使用的工业协议。
/// 要写入的数据类型。
/// 要写入的数据。
/// 如果写入成功则返回true,失败则抛出自定义通讯异常。
///
public abstract bool WriteObj(string address, string dataType, object value);
public abstract OperateResult Wait(string address, int readInterval, int waitTimeout, T value) where T : struct;
public abstract T ReadCustomer(string address) where T : IDataTransfer, new();
public abstract bool WriteCustomer(string address, [NotNull] T value) where T : IDataTransfer, new();
}
}