| | |
| | | using System.Drawing; |
| | | using System.IO; |
| | | using System.Linq; |
| | | using System.Runtime.CompilerServices; |
| | | using System.Runtime.InteropServices; |
| | | using System.Text; |
| | | using System.Threading; |
| | |
| | | } |
| | | } |
| | | |
| | | [MethodImpl(MethodImplOptions.Synchronized)] |
| | | public override IImageSet Snapshot(IOperationConfig config) |
| | | { |
| | | GocatorOperationConfig opConfig = config as GocatorOperationConfig; |
| | |
| | | { |
| | | try |
| | | { |
| | | system.Start(); |
| | | sensor.Start(); |
| | | LogAsync(DateTime.Now, $"传感器状态:{sensor.State.ToString()}", ""); |
| | | if (sensor.State != GoState.Running) |
| | | { |
| | | Thread.Sleep(100); |
| | |
| | | catch (Exception ex) |
| | | { |
| | | LogAsync(DateTime.Now, $"开启异常:{ex.GetExceptionMessage()}", ""); |
| | | Thread.Sleep(100); |
| | | } |
| | | } while (true); |
| | | |
| | |
| | | return null; |
| | | } |
| | | |
| | | try |
| | | int reTryTime = 3; |
| | | do |
| | | { |
| | | dataSet = system.ReceiveData(IIConfig.SnapshotTimeout); |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | LogAsync(DateTime.Now, $"{Name}获取图像异常", ex.GetExceptionMessage()); |
| | | imgSet.HImage = null; |
| | | dataSet = null; |
| | | //return imgSet; |
| | | } |
| | | try |
| | | { |
| | | dataSet = system.ReceiveData(IIConfig.SnapshotTimeout); |
| | | reTryTime = 0; |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | reTryTime--; |
| | | LogAsync(DateTime.Now, $"{Name}获取图像异常", ex.GetExceptionMessage()); |
| | | |
| | | if (reTryTime <= 0) |
| | | { |
| | | imgSet.HImage = null; |
| | | dataSet = null; |
| | | system.ClearData(); |
| | | } |
| | | } |
| | | } while (reTryTime > 0); |
| | | } |
| | | |
| | | if (!IIConfig.IsAsyncMode) |
| | |
| | | { |
| | | try |
| | | { |
| | | system.Stop(); |
| | | sensor.Stop(); |
| | | |
| | | LogAsync(DateTime.Now, $"传感器状态:{sensor.State.ToString()}", ""); |
| | | if (sensor.State != GoState.Ready) |
| | | { |
| | | Thread.Sleep(100); |
| | |
| | | catch (Exception ex) |
| | | { |
| | | LogAsync(DateTime.Now, $"关闭异常:{ex.GetExceptionMessage()}", ""); |
| | | Thread.Sleep(100); |
| | | } |
| | | } while (true); |
| | | |
| | |
| | | { |
| | | base.Start(); |
| | | |
| | | //system.Start(); |
| | | if (sensor.State != GoState.Ready) |
| | | { |
| | | system.Start(); |
| | | } |
| | | |
| | | if (IIConfig.IsAsyncMode) |
| | | system.Start(); |
| | | { |
| | | sensor.Start(); |
| | | } |
| | | else |
| | | { |
| | | //if (sensor.State == GoState.Ready) |
| | | { |
| | | sensor.Stop(); |
| | | } |
| | | } |
| | | } |
| | | |
| | | protected override void Stop() |