LineMoveInfo.cs
15.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
using log4net.Layout;
using OnlineStore.Common;
using System;
using System.Collections.Generic;
namespace CtuDeviceLib
{
/// <summary>
/// 料仓当前运动信息类(出入库状态,步骤记录)
/// </summary>
public class LineMoveInfo
{
/// <summary>
/// 超时时间
/// </summary>
public int TimeOutSeconds = 60;
public string Name = "";
public bool ShelfNoTray = false;
public LineMoveInfo(string name)
{
this.Name = name;
moveType = MoveType.None;
MoveParam = new InOutParam();
this.moveStep = RunStep.Wait;
IsInWait = false;
MoveNum = 0;
}
public int MoveNum { get; set; }
public DateTime MoveStartTime { get; set; }
public DateTime LastSetpTime { get; set; }
/// <summary>
/// =true表示满足一个等待条件,就可以完成此步骤的等待
/// </summary>
public bool OneWaitCanEndStep = false;
/// <summary>
/// 操作类型
/// </summary>
private MoveType moveType = MoveType.None;
public MoveType MoveType
{
get { return moveType; }
}
/// <summary>
///出入库参数
/// </summary>
public InOutParam MoveParam { get; set; }
/// <summary>
/// 是否再当前步骤等待中
/// </summary>
public bool IsInWait { get; set; }
/// <summary>
/// 上一个执行步骤
/// </summary>
public RunStep PreMoveStep { get; set; }
/// <summary>
/// 当前执行到的步骤
/// </summary>
private RunStep moveStep;
/// <summary>
/// 可以循环运动的次数(轴卡运动才需要)
/// </summary>
public int CanWhileCount = 0;
/// <summary>
/// 料仓运动步骤记录
/// </summary>
public RunStep MoveStep
{
get { return moveStep; }
}
public bool IsStep(RunStep step)
{
return (MoveStep.Equals(step));
}
public string SLog
{
get { return " "+MoveStep + " "; }
}
string curTaskInfo = "";
public void SetCurTaskInfo(RobotTask task)
{
if(task==null)
{
curTaskInfo = "";
}
else
{
curTaskInfo = $"{task?.TaskId}";
}
}
public void SetCurTaskInfo(string prefixMsg)
{
curTaskInfo = prefixMsg;
}
string preInfo = "";
public string Msg;
public void Info(string msg)
{
if (string.IsNullOrEmpty(msg)) return;
if (!preInfo.Equals(msg))
{
LogUtil.info($"【{Name}】【{curTaskInfo}】【{SLog}】:{msg}");
preInfo = msg;
Msg=msg;
}
}
string preError = "";
public void Error(string msg)
{
if (string.IsNullOrEmpty(msg)) return;
if(!preError.Equals(msg))
{
LogUtil.error($"【{Name}】【{curTaskInfo}】【{SLog}】:{msg}");
preError = msg;
Msg = msg;
}
}
public bool IsTimeOut(int timeOutSeconds = 60)
{
TimeSpan span = DateTime.Now - LastSetpTime;
if (span.TotalSeconds > timeOutSeconds)
{
return true;
}
return false;
}
public TimeSpan StepSpan()
{
TimeSpan span = DateTime.Now - LastSetpTime;
return span;
}
public void NextMoveStep(RunStep step)
{
StepMoveLog();
PreMoveStep = moveStep;
moveStep = step;
LastSetpTime = DateTime.Now;
IsInWait = true;
WaitList = new List<WaitResultInfo>();
WriteIoList = new List<WriteIOInfo>();
OneWaitCanEndStep = false;
CanWhileCount = 5;
}
/// <summary>
/// 当前步骤执行完成
/// </summary>
public void EndStepWait()
{
IsInWait = false;
WaitList = new List<WaitResultInfo>();
WriteIoList = new List<WriteIOInfo>();
}
public void NewMove(MoveType type )
{
moveStep = RunStep.Wait;
this.moveType = type;
LastSetpTime = DateTime.Now;
WaitList = new List<WaitResultInfo>();
WriteIoList = new List<WriteIOInfo>();
MoveNum++;
MoveStartTime = DateTime.Now;
}
public void NewMove(MoveType type, InOutParam param)
{
moveStep = RunStep.Wait;
this.moveType = type;
this.MoveParam = param;
LastSetpTime = DateTime.Now;
WaitList = new List<WaitResultInfo>();
WriteIoList = new List<WriteIOInfo>();
MoveStartTime = DateTime.Now;
}
public void EndMove()
{
StepMoveLog();
this.moveType = MoveType.None;
this.MoveParam = new InOutParam();
moveStep = RunStep.Wait;
LastSetpTime = DateTime.Now;
IsInWait = false;
WaitList = new List<WaitResultInfo>();
WriteIoList = new List<WriteIOInfo>();
CanWhileCount = 0;
}
public LineMoveInfo clone()
{
return (LineMoveInfo)this.MemberwiseClone();
}
public List<WaitResultInfo> WaitList = new List<WaitResultInfo>();
public List<WriteIOInfo> WriteIoList = new List<WriteIOInfo>();
/// <summary>
/// 重置之后继续出入库时,退回上一个步骤执行
/// </summary>
public void BackStep()
{
moveStep = PreMoveStep;
IsInWait = false;
}
internal string ToStr()
{
string str = $"[{MoveType}][{MoveStep}]{ MoveParam?.ToStr()}";
return str;
}
public string GetMoveType()
{
switch (moveType)
{
case MoveType.InStore:
return "入料";
case MoveType.OutStore:
return "出料";
}
return "";
}
private void StepMoveLog()
{
//try
//{
// RunLogUtil.MoveLog(new MoveLog(Name, GetMoveType(), GetStepDes(), LastSetpTime, DateTime.Now, MoveParam.PosId, MoveParam.WareCode));
//}
//catch (Exception ex)
//{
//}
}
}
public class WriteIOInfo
{
public static WriteIOInfo NInfo(string type,IO_VALUE value)
{
WriteIOInfo i = new WriteIOInfo();
i.IoType = type;
i.IoValue = value;
return i;
}
public string IoType = "";
public IO_VALUE IoValue = IO_VALUE.HIGH;
}
public class WaitResultInfo
{
private WaitResultInfo()
{
}
public static WaitResultInfo WaitTime(int MScends)
{
WaitResultInfo wait = new WaitResultInfo();
wait.CanWhileMoveCount = 0;
wait.WaitType = WaitEnum.W003_Time;
wait.TimeMSeconds = MScends;
wait.IsEnd = false;
return wait;
}
//public static WaitResultInfo WaitAxisOrg(ConfigMoveAxis axis,IO_VALUE value )
//{
// WaitResultInfo wait = new WaitResultInfo();
// wait.CanWhileMoveCount = 0;
// wait.WaitType = WaitEnum.W006_AxisOrg;
// wait.AxisInfo = axis;
// wait.IsHomeMove = true;
// wait.IoValue = value;
// wait.IsEnd = false;
// return wait;
//}
public static WaitResultInfo WaitHeight(int height)
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W007_ReelHeight;
wait.HeightValue = height;
wait.IsEnd = false;
return wait;
}
public static WaitResultInfo WaitCanInstore()
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W008_InStoreCheckOK;
return wait;
}
public static WaitResultInfo WaitBoxCanReviceTray( )
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W009_BoxCanInstore;
return wait;
}
public static WaitResultInfo WaitFeedScanCode()
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W102_FeedScanCode;
return wait;
}
/// <summary>
/// 入料机构拿走料串上的料,需要同时 SL_ClampCylinder_Check=HIGH,SL_AxisLocationCheck=LOW
/// </summary>
/// <returns></returns>
public static WaitResultInfo WaitGetShelfTray()
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W103_GetShelfTray;
return wait;
}
///// <summary>
///// 移栽入料时抓取料盘
///// </summary>
///// <returns></returns>
//public static WaitResultInfo WaitInStoreGetTray()
//{
// WaitResultInfo wait = new WaitResultInfo();
// wait.WaitType = WaitEnum.W010_InStoreGetTray;
// return wait;
//}
/// <summary>
/// 未抓起料报警
/// </summary>
/// <returns></returns>
public static WaitResultInfo WaitNoTrayAlarm()
{
WaitResultInfo wait = new WaitResultInfo();
wait.WaitType = WaitEnum.W1000_NoTrayAlarm;
return wait;
}
public string ToStr()
{
if (WaitType.Equals(WaitEnum.W002_IOValue))
{
return "等待【" + IoType + "】=【" + IoValue + "】";
}
else if (WaitType.Equals(WaitEnum.W003_Time))
{
return "时间【" + TimeMSeconds + "】毫秒";
}
else if (WaitType.Equals(WaitEnum.W004_StellMove))
{
return "电钢目标位置【" + TargetPosition + "】 ";
}
else if (WaitType.Equals(WaitEnum.W005_ShuoKe))
{
return "硕科电机目标位置【" + TargetPosition + "】 ";
}else if (WaitType.Equals(WaitEnum.W007_ReelHeight))
{
return "料盘高度【" + HeightValue + "】 ";
}else if (WaitType.Equals(WaitEnum.W008_InStoreCheckOK))
{
return "入库库位验证完成";
}
else if (WaitType.Equals(WaitEnum.W009_BoxCanInstore))
{
return "BOX可以开始入库";
} else if (WaitType.Equals(WaitEnum.W010_InStoreGetTray))
{
return "抓起料盘";
}
else if (WaitType.Equals(WaitEnum.W101_BatchAxisMove))
{
return "上料轴缓慢上升";
}
else if (WaitType.Equals(WaitEnum.W102_FeedScanCode))
{
return "入料模块扫码";
} else if (WaitType.Equals(WaitEnum.W103_GetShelfTray))
{
return "抓起料盘";
}
else if (WaitType.Equals(WaitEnum.W1000_NoTrayAlarm))
{
return "未抓起料盘,请取走料盘后复位";
}
else
{
return "Wait位置类型:WaitType=【" + WaitType + "】";
}
}
/// <summary>
/// 当未结束时可以重复运动的次数
/// </summary>
public int CanWhileMoveCount { get; set; }
/// <summary>
/// 等待结果,1=轴运动,2=IO运动,3=时间,4=电钢,5=硕科电机,6=等待轴原点信号
/// </summary>
public int WaitType { get; set; }
/// <summary>
/// 电钢地址
/// </summary>
public byte SlvAddr { get; set; }
/// <summary>
/// IO类型
/// </summary>
public String IoType { get; set; }
/// <summary>
/// IO值
/// </summary>
public IO_VALUE IoValue { get; set; }
/// <summary>
/// 等待的毫秒
/// </summary>
public int TimeMSeconds { get; set; }
/// <summary>
/// 是否是原点返回
/// </summary>
public bool IsHomeMove = false;
/// <summary>
/// 轴目标位置
/// </summary>
public int TargetPosition { get; set; }
/// <summary>
/// 轴目标速度
/// </summary>
public int TargetSpeed { get; set; }
/// <summary>
/// 是否已经结束
/// </summary>
public bool IsEnd{ get; set; }
/// <summary>
/// 高度
/// </summary>
public int HeightValue { get; set; }
}
public class WaitEnum
{
/// <summary>
/// 伺服运动
/// </summary>
public static int W001_AxisMove = 1;
/// <summary>
/// 信号到达
/// </summary>
public static int W002_IOValue = 2;
/// <summary>
/// 时间等待
/// </summary>
public static int W003_Time = 3;
/// <summary>
/// 电钢运动
/// </summary>
public static int W004_StellMove = 4;
/// <summary>
/// 硕科电机
/// </summary>
public static int W005_ShuoKe = 5;
/// <summary>
/// 轴原点信号
/// </summary>
public static int W006_AxisOrg = 6;
/// <summary>
/// 料盘高度
/// </summary>
public static int W007_ReelHeight = 7;
/// <summary>
/// 入库库位验证完成
/// </summary>
public static int W008_InStoreCheckOK = 8;
/// <summary>
/// BOX可以开始入库
/// </summary>
public static int W009_BoxCanInstore = 9;
/// <summary>
/// 入库时移栽拿走料盘上的料
/// </summary>
public static int W010_InStoreGetTray = 10;
///// <summary>
///// 等待横移模块可以顶升,等待入料四和入料一处无托盘处理
///// </summary>
//internal static int W010_SWCanTopUp = 10;
/// <summary>
/// 入料模块:批量轴缓慢上升,并检测有料盘后停止
/// </summary>
public static int W101_BatchAxisMove = 101;
/// <summary>
/// 入料模块扫码
/// </summary>
public static int W102_FeedScanCode = 102;
/// <summary>
/// 入料机构拿走料串上的料,需要同时 SL_ClampCylinder_Check=HIGH,SL_AxisLocationCheck=LOW
/// </summary>
public static int W103_GetShelfTray = 103;
/// <summary>
/// 未抓起料盘,请取走料盘后复位
/// </summary>
public static int W1000_NoTrayAlarm = 1000;
}
}