1 Star 0 Fork 0

IoTSharp / VLPR

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
VLPRService.cs 3.89 KB
一键复制 编辑 原始数据 按行查看 历史
麦壳饼 提交于 2022-04-30 17:25 . 加入 检查方法
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options;
using System.Diagnostics;
public class VLPRService : BackgroundService
{
private readonly VLPROptions _setting;
private readonly Dictionary<VLPRConfig, IVLPR> _vprs = new Dictionary<VLPRConfig, IVLPR>();
private readonly VLPRClient _client;
private readonly IServiceScope _scope;
private readonly ILoggerFactory _loggerFactory;
private readonly ILogger<VLPRService> _logger;
public VLPRService(IOptions<VLPROptions> options, VLPRClient client, IServiceScopeFactory scopeFactor)
{
_setting = options.Value;
_client = client;
_client.HCapture = Capture;
_client.HCheckStatus = CheckStatus;
_scope = scopeFactor.CreateScope();
_loggerFactory = _scope.ServiceProvider.GetService<ILoggerFactory>();
_logger = _loggerFactory?.CreateLogger<VLPRService>();
if (_setting.EasyVLPR)
{
_setting.VLPRConfigs.ForEach(cfg =>
{
var vlpr = new VLPRSingle(cfg,_loggerFactory?.CreateLogger($"{nameof(VLPRSingle)}{cfg.Name}"));
vlpr.FoundVehicle += _client.Vlpr_FoundVehicle;
_vprs.Add(cfg, vlpr);
});
}
else
{
_setting.VLPRConfigs.ForEach(cfg =>
{
var vlpr = new VLPR(cfg, _loggerFactory?.CreateLogger($"{nameof(VLPR)}{cfg.Name}"));
vlpr.FoundVehicle += _client.Vlpr_FoundVehicle;
_vprs.Add(cfg, vlpr);
});
}
}
private bool CheckStatus(string name)
{
bool result = false;
_logger?.LogInformation($"准备调用CheckStatus{name}");
if (_vprs.Any(f => f.Key.Name == name))
{
var cmp = _vprs.First(f => f.Key.Name == name).Value;
if (cmp != null)
{
result = cmp.CheckStatus();
_logger?.LogInformation($"名称为{name}CheckStatus结果{result}");
}
else
{
_logger?.LogWarning($"名称为{name}的相机值为空");
}
}
else
{
_logger?.LogWarning($"没有找到名称为{name}的相机");
}
return result;
}
private bool Capture(string name)
{
bool result=false;
_logger?.LogInformation($"准备调用抓拍{name}");
if (_vprs.Any(f => f.Key.Name == name))
{
var cmp = _vprs.First(f => f.Key.Name == name).Value;
if (cmp != null)
{
result= cmp.Capture();
_logger?.LogInformation($"名称为{name}抓拍调用结果{result}");
}
else
{
_logger?.LogWarning($"名称为{name}的相机值为空");
}
}
else
{
_logger?.LogWarning($"没有找到名称为{name}的相机");
}
return result;
}
protected override Task ExecuteAsync(CancellationToken stoppingToken)
{
return Task.Run(async () =>
{
while (!stoppingToken.IsCancellationRequested)
{
_logger.LogInformation($"开始检查相机,共{_vprs?.Count}个");
_vprs.ToList().ForEach(item =>
{
var cfg = item.Key;
var vpr = item.Value;
try
{
var status = vpr.CheckStatus();
}
catch (Exception ex)
{
_logger?.LogError($"定时检查结果:{ex.Message}");
}
});
await Task.Delay (TimeSpan.FromSeconds(_setting.Interval < 10 ? 10 : _setting.Interval));
}
});
}
}
C#
1
https://gitee.com/IoTSharp/VLPR.git
git@gitee.com:IoTSharp/VLPR.git
IoTSharp
VLPR
VLPR
master

搜索帮助