Commit e002c0f5 authored by 潘栩锋's avatar 潘栩锋 🚴

优化 AD盒脉冲3秒不变化。 状态设置为手动停止

parent f64acccb
......@@ -348,14 +348,17 @@ namespace FlyADBase
/// 用于检测当 为IsRunning时,脉冲是否停了很久。
/// </summary>
int last_position = int.MinValue;
/// <summary>
/// 脉冲不变化次数
/// </summary>
int position_no_changed_cnt = 0;
TimeSpan NoTGridTimeOut = TimeSpan.FromSeconds(60);
Stopwatch stopwatch_noTGrid = new Stopwatch();
IsReadyContext isReadyContext = new IsReadyContext();
SysTickContext sysTickContext = new SysTickContext();
......@@ -366,7 +369,8 @@ namespace FlyADBase
string jsonDbPath;
DateTime lastTimeGridTime;
static FlyAD7() {
static FlyAD7()
{
propertyName_save = FlyAD7JsonDb.GetMemberNames();
}
/// <summary>
......@@ -456,17 +460,33 @@ namespace FlyADBase
() =>
{
if (!IsConnected)
{
position_no_changed_cnt = 0;
return;
}
if (DriveStatus != DRIVE_MAN_STATUS.RUNNING)
{
position_no_changed_cnt = 0;
return;
}
if (Position != last_position)
{
last_position = Position;
position_no_changed_cnt = 0;
return;
}
if (driveman_wait.CheckMark(TimeSpan.FromSeconds(3)))//每3秒检查一次
position_no_changed_cnt++;
if (position_no_changed_cnt >= 3)
{
//连续3秒,脉冲一样
//异常
DriveStatus = DRIVE_MAN_STATUS.STOP_MANUAL;
position_no_changed_cnt = 0;
return;
}
if (driveman_wait.CheckMark(TimeSpan.FromSeconds(2)))//每2秒检查一次
{
driveman_wait.Mark();
CurrObjSys.GetValueEx(
......@@ -593,7 +613,8 @@ namespace FlyADBase
ID,
FLYAD7_OBJ_INTERFACE.SYS_DATA_INTERFACE.GET_ZERO_POS);
}
else {
else
{
//参数不保存在设备中, 保存在电脑。
//参数写入到设备。
NotifyPropertyChanged(nameof(MotorType));
......@@ -658,7 +679,7 @@ namespace FlyADBase
ID,
FLYAD7_OBJ_INTERFACE.FLYIO_OBJ_INTERFACE.GET_IO);
NotifyPropertyChanged(nameof(Pos1LCShift));//写入到AD盒
NotifyPropertyChanged(nameof(Pos2LCShift));//写入到AD盒
......@@ -908,7 +929,7 @@ namespace FlyADBase
Position = pack.pos1;
DateTime dt = sysTickContext.ToDateTime(pack.systick);
Now = dt;
PositionChangedEvent?.Invoke(this, new PositionChangedEventArgs() { Time = dt, Position = Position });
}
calSpeed.SetPos1(Now, Position);
......@@ -933,7 +954,7 @@ namespace FlyADBase
Position2 = pack.pos2;
DateTime dt = sysTickContext.ToDateTime(pack.systick);
Now = dt;
Position2ChangedEvent?.Invoke(this, new PositionChangedEventArgs() { Time = dt, Position = Position });
}
calSpeed.SetPos2(Now, Position2);
......@@ -1158,7 +1179,7 @@ namespace FlyADBase
}
break;
}
_end_push_info:
_end_push_info:
bShieldSetValueEx = false;
}
......@@ -1183,7 +1204,7 @@ namespace FlyADBase
ID,
FLYAD7_OBJ_INTERFACE.DRIVE_MAN_INTERFACE.CALL_PXX,
new FLYAD7_OBJ_INTERFACE.DRIVE_MAN_INTERFACE.Pack_CallRunto() { to = TargetPos }.ToBytes());
}
break;
case DRIVE_MAN_ORDER.ORIGIN:
......@@ -1256,9 +1277,9 @@ namespace FlyADBase
bool ret = FlyAD7JsonDb.Load(jsonDbPath, this);
bShieldSetValueEx = false;
this.PropertyChanged += FlyAD7_PropertyChanged2;
return ret;
}
......@@ -1454,7 +1475,7 @@ namespace FlyADBase
/// <param name="velocity"></param>
public void SetVelocity(UInt32 velocity)
{
SetPosParam(velocity,UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue);
SetPosParam(velocity, UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue, UInt32.MaxValue);
}
/// <summary>
......@@ -1477,7 +1498,7 @@ namespace FlyADBase
FLYAD7_OBJ_INTERFACE.SYS_DATA_INTERFACE.GET_SYSINFO);
}
/// <summary>
/// 初始化系统信息区
/// </summary>
......@@ -1789,12 +1810,12 @@ namespace FlyADBase
//备份参数
public bool IsDevParamValid = false;
public MOTORTYPE MotorType = MOTORTYPE.SERVO;
public MOTORTYPE MotorType = MOTORTYPE.SERVO;
public UInt16 PosOfGrid = 10;
public UInt16 Ratio01 = 4;
public UInt16 Ratio02 = 1;
public Int16 PosOffset = 0;
public UInt32 JogVelocity = 1000;
public UInt32 JogVelocity = 1000;
/// <summary>
/// 硬件版本
......@@ -1805,8 +1826,9 @@ namespace FlyADBase
public int HardwareVersion = 2;
public static string[] GetMemberNames() {
var type = typeof(FlyAD7JsonDb);
public static string[] GetMemberNames()
{
var type = typeof(FlyAD7JsonDb);
return type.GetMembers().Select(mi => mi.Name).ToArray();
}
......
......@@ -24,7 +24,7 @@ namespace FLY.Thick.Base.Server
/// 归0开始时间点,用于计算什么时候需要归0
/// </summary>
private TimeSpan orgStartTime;
/// <summary>
/// 使用timer.Elapsed 代替 DateTime.Now 使用
/// </summary>
......@@ -90,7 +90,7 @@ namespace FLY.Thick.Base.Server
ScanEnd = -1;
}
public virtual void Init(IFlyADClientAdv flyad, GSample gsample)
public virtual void Init(IFlyADClientAdv flyad, GSample gsample)
{
base.Init(flyad);
this.gsample = gsample;
......@@ -128,24 +128,7 @@ namespace FLY.Thick.Base.Server
FinishEvent?.Invoke(this, null);
base.Stop();
}
bool WaitFinish(ref CTRLST src, CTRLST next)
{
switch (mFlyAD.DriveStatus)
{
case DRIVE_MAN_STATUS.STOP://完成任务
case DRIVE_MAN_STATUS.LIMIT:
{
src = next;
return true;
} break;
case DRIVE_MAN_STATUS.STOP_MANUAL://异常
{
NotifyError(ERRNO_Running_Manual);
Stop(); return false;
} break;
}
return false;
}
protected override void OnPoll()
{
switch (state)
......@@ -157,15 +140,31 @@ namespace FLY.Thick.Base.Server
mFlyAD.Origin();
state = CTRLST.ORIGINWAIT;
}
else {
else
{
state = CTRLST.SCAN_FORW;
}
}
break;
case CTRLST.ORIGINWAIT:
{
WaitFinish(ref state, CTRLST.FORWARD);
} break;
switch (mFlyAD.DriveStatus)
{
case DRIVE_MAN_STATUS.STOP://完成任务
{
state = CTRLST.FORWARD;
}
break;
case DRIVE_MAN_STATUS.LIMIT:
case DRIVE_MAN_STATUS.STOP_MANUAL://异常
{
NotifyError(ERRNO_Running_Manual);
Stop();
}
break;
}
}
break;
case CTRLST.FORWARD:
{
int to = ScanEnd;
......@@ -185,17 +184,22 @@ namespace FLY.Thick.Base.Server
to = b;
}
}
mFlyAD.SetVelocity(Velocity);
mFlyAD.Runto(to);
state = CTRLST.FORWAIT_1;
} break;
}
break;
case CTRLST.FORWAIT_1:
{
if (WaitFinish(ref state, CTRLST.FORWAIT_2))
if (WaitFinish())
{
state = CTRLST.FORWAIT_2;
FlushAD(DIRECTION.FORWARD);
}
} break;
}
break;
case CTRLST.FORWAIT_2:
{
state = CTRLST.BACKWARD;
......@@ -217,16 +221,22 @@ namespace FLY.Thick.Base.Server
state = CTRLST.FORWAIT_SAMPLE;
}
}
} break;
}
break;
case CTRLST.FORWAIT_SAMPLE:
{
WaitFinish(ref state, CTRLST.FORW_SAMPLE);
} break;
if (WaitFinish())
{
state = CTRLST.FORW_SAMPLE;
}
}
break;
case CTRLST.FORW_SAMPLE:
{
gsample.Do(Misc.DIRECTION.FORWARD);
state = CTRLST.BACKWARD;
} break;
}
break;
case CTRLST.BACKWARD:
{
int to = ScanStart;
......@@ -246,16 +256,21 @@ namespace FLY.Thick.Base.Server
to = e;
}
}
mFlyAD.SetVelocity(Velocity);
mFlyAD.Runto(to);
state = CTRLST.BACKWAIT_1;
} break;
}
break;
case CTRLST.BACKWAIT_1:
{
if (WaitFinish(ref state, CTRLST.BACKWAIT_2))
if (WaitFinish())
{
state = CTRLST.BACKWAIT_2;
FlushAD(DIRECTION.BACKWARD);
} break;
}
}
break;
case CTRLST.BACKWAIT_2:
{
int b, e;
......@@ -275,17 +290,23 @@ namespace FLY.Thick.Base.Server
state = CTRLST.BACKWAIT_SAMPLE;
}
}
else {
else
{
//完成一次周期
if (!gsample.IsFailure())
orgStartTime = timer.Elapsed;
state = CTRLST.INIT;
}
} break;
}
break;
case CTRLST.BACKWAIT_SAMPLE:
{
WaitFinish(ref state, CTRLST.BACKW_SAMPLE);
} break;
if (WaitFinish())
{
state = CTRLST.BACKW_SAMPLE;
}
}
break;
case CTRLST.BACKW_SAMPLE:
{
gsample.Do(Misc.DIRECTION.BACKWARD);
......@@ -293,7 +314,8 @@ namespace FLY.Thick.Base.Server
if (!gsample.IsFailure())
orgStartTime = timer.Elapsed;
state = CTRLST.INIT;
} break;
}
break;
case CTRLST.SCAN_FORW:
......@@ -306,8 +328,11 @@ namespace FLY.Thick.Base.Server
break;
case CTRLST.SCAN_FORWAIT:
{
if (WaitFinish(ref state, CTRLST.SCAN_BACKW))
if (WaitFinish())
{
state = CTRLST.SCAN_BACKW;
FlushAD(DIRECTION.FORWARD);
}
}
break;
case CTRLST.SCAN_BACKW:
......@@ -320,8 +345,11 @@ namespace FLY.Thick.Base.Server
break;
case CTRLST.SCAN_BACKWAIT:
{
if (WaitFinish(ref state, CTRLST.INIT))
if (WaitFinish())
{
state = CTRLST.INIT;
FlushAD(DIRECTION.BACKWARD);
}
}
break;
}
......@@ -329,7 +357,8 @@ namespace FLY.Thick.Base.Server
private bool IsOrging()
{
if (OrgInterval > 0) {
if (OrgInterval > 0)
{
if (timer.Elapsed >= (orgStartTime + TimeSpan.FromMinutes(OrgInterval)))
return true;
......@@ -383,7 +412,7 @@ namespace FLY.Thick.Base.Server
{
#region 成员变量
int scanCnt;//扫描次数, 当为-1时,无限次扫描,>0时,有限次扫描
protected int ScanCnt
{
......@@ -492,24 +521,7 @@ namespace FLY.Thick.Base.Server
FinishEvent(this, null);
base.Stop();
}
bool WaitFinish(ref CTRLST src, CTRLST next)
{
switch (mFlyAD.DriveStatus)
{
case DRIVE_MAN_STATUS.STOP://完成任务
case DRIVE_MAN_STATUS.LIMIT:
{
src = next;
return true;
} break;
case DRIVE_MAN_STATUS.STOP_MANUAL://异常
{
NotifyError(ERRNO_Running_Manual);
Stop(); return false;
} break;
}
return false;
}
protected override void OnPoll()
{
switch (state)
......@@ -518,48 +530,69 @@ namespace FLY.Thick.Base.Server
{
mFlyAD.Origin();
state = CTRLST.READY_ORIGINWAIT;
} break;
}
break;
case CTRLST.READY_ORIGINWAIT:
{
WaitFinish(ref state, CTRLST.READY_BACKW);
}break;
if (WaitFinish())
{
state = CTRLST.READY_BACKW;
}
}
break;
case CTRLST.READY_BACKW:
{
mFlyAD.SetVelocity(Velocity);
mFlyAD.RuntoMin();
state = CTRLST.READY_BACKWAIT;
} break;
}
break;
case CTRLST.READY_BACKWAIT:
{
WaitFinish(ref state, CTRLST.SFORWARD);
} break;
if (WaitFinish())
{
state = CTRLST.SFORWARD;
}
}
break;
case CTRLST.SFORWARD:
{
mFlyAD.SetVelocity(Velocity);
mFlyAD.RuntoMax();
state = CTRLST.SFORWAIT_1;
} break;
}
break;
case CTRLST.SFORWAIT_1:
{
if (WaitFinish(ref state, CTRLST.SFORWAIT_2))
if (WaitFinish())
{
state = CTRLST.SFORWAIT_2;
FlushAD(DIRECTION.FORWARD);
} break;
}
}
break;
case CTRLST.SFORWAIT_2:
{
state = CTRLST.SBACKWARD;
} break;
}
break;
case CTRLST.SBACKWARD:
{
mFlyAD.SetVelocity(Velocity);
mFlyAD.RuntoMin();
state = CTRLST.SBACKWAIT_1;
} break;
}
break;
case CTRLST.SBACKWAIT_1:
{
if (WaitFinish(ref state, CTRLST.SBACKWAIT_2))
if (WaitFinish())
{
state = CTRLST.SBACKWAIT_2;
FlushAD(DIRECTION.BACKWARD);
} break;
}
}
break;
case CTRLST.SBACKWAIT_2:
{
state = CTRLST.SFORWARD;
......@@ -573,7 +606,8 @@ namespace FLY.Thick.Base.Server
//扫描完成
Stop(); return;
}
} break;
}
break;
}
}
private void FlushAD(Misc.DIRECTION direction)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment