2022-01-02 15:24:11 +00:00
|
|
|
|
using PluginInterface;
|
|
|
|
|
using System;
|
2022-08-06 10:21:00 +00:00
|
|
|
|
using Microsoft.Extensions.Logging;
|
2022-01-02 15:24:11 +00:00
|
|
|
|
using OpenNETCF.MTConnect;
|
2022-08-06 10:21:00 +00:00
|
|
|
|
|
2022-01-02 15:24:11 +00:00
|
|
|
|
namespace DriverMTConnect
|
|
|
|
|
{
|
|
|
|
|
internal class MTConnectClient : IDriver
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
#region 配置参数
|
|
|
|
|
|
|
|
|
|
[ConfigParameter("设备Id")]
|
|
|
|
|
public Guid DeviceId { get; set; }
|
|
|
|
|
|
|
|
|
|
[ConfigParameter("uri")]
|
|
|
|
|
public string Uri { get; set; }
|
|
|
|
|
|
|
|
|
|
[ConfigParameter("超时时间ms")]
|
2022-01-15 16:16:53 +00:00
|
|
|
|
public int Timeout { get; set; } = 3000;
|
2022-01-02 15:24:11 +00:00
|
|
|
|
|
|
|
|
|
[ConfigParameter("最小通讯周期ms")]
|
|
|
|
|
public uint MinPeriod { get; set; } = 3000;
|
|
|
|
|
|
|
|
|
|
public bool IsConnected { get; set; }
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
EntityClient m_client = null;
|
|
|
|
|
|
2022-08-06 10:21:00 +00:00
|
|
|
|
public ILogger _logger { get; set; }
|
2022-08-08 07:15:09 +00:00
|
|
|
|
private readonly string _device;
|
2022-08-06 10:21:00 +00:00
|
|
|
|
|
2022-08-08 07:15:09 +00:00
|
|
|
|
public MTConnectClient(string device, ILogger logger)
|
2022-01-02 15:24:11 +00:00
|
|
|
|
{
|
2022-08-06 10:21:00 +00:00
|
|
|
|
_device = device;
|
|
|
|
|
_logger = logger;
|
|
|
|
|
|
2022-08-08 07:15:09 +00:00
|
|
|
|
_logger.LogInformation($"Device:[{_device}],Create()");
|
2022-01-02 15:24:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool Close()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
m_client = null;
|
|
|
|
|
IsConnected = false;
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool Connect()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
m_client = new EntityClient(Uri);
|
2022-01-15 16:16:53 +00:00
|
|
|
|
m_client.RequestTimeout = Timeout;
|
2022-01-02 15:24:11 +00:00
|
|
|
|
IsConnected = true;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
IsConnected = false;
|
|
|
|
|
}
|
|
|
|
|
return IsConnected;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Dispose()
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Method("读MTConnect", description: "读MTConnect ID")]
|
|
|
|
|
public DriverReturnValueModel ReadById(DriverAddressIoArgModel Ioarg)
|
|
|
|
|
{
|
|
|
|
|
var ret = new DriverReturnValueModel { StatusType = VaribaleStatusTypeEnum.Good };
|
|
|
|
|
|
|
|
|
|
if (IsConnected)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var dataValue = m_client.GetDataItemById(Ioarg.Address).Value;
|
|
|
|
|
ret.Value = dataValue;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
ret.StatusType = VaribaleStatusTypeEnum.Bad;
|
|
|
|
|
ret.Message = $"读取失败,{ex.Message}";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
ret.StatusType = VaribaleStatusTypeEnum.Bad;
|
|
|
|
|
ret.Message = "连接失败";
|
|
|
|
|
}
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public DriverReturnValueModel Read(DriverAddressIoArgModel Ioarg)
|
|
|
|
|
{
|
|
|
|
|
var ret = new DriverReturnValueModel { StatusType = VaribaleStatusTypeEnum.Good };
|
|
|
|
|
return ret;
|
|
|
|
|
}
|
2022-04-13 09:01:24 +00:00
|
|
|
|
public async Task<RpcResponse> WriteAsync(string RequestId, string Method, DriverAddressIoArgModel Ioarg)
|
|
|
|
|
{
|
|
|
|
|
RpcResponse rpcResponse = new() { IsSuccess = false, Description = "设备驱动内未实现写入功能" };
|
|
|
|
|
return rpcResponse;
|
|
|
|
|
}
|
2022-01-02 15:24:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|