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