using RGD.Common;
using RGD.DataService;
using RGD.DBUtility;
using RGD.MdsAPI;
using RGD.MdsAPI.WMS;
using RGD.OPCClient;
using System;
using System.Data;
namespace RGD.WCS
{
///
/// Creator:RGD
/// 获得设备状态类
/// 需要做的工作:
/// 1.下位机给上位机发送设备(任务)状态信息(正在执行状态或者报警的设备所处调度路径的F_SerialNumber》=当前值)
/// 2.(单独处理)下位机给上位机发送条码信息(托盘条码,烟箱一号工程码)
/// 3.(单独处理)下位机给上位机发送现场控制触摸屏申请信号:1-重发当前设备指令
/// 2-申请修改当前设备所执行任务的目标位置
/// 4.跟踪货物运行到的位置(多个调度任务在执行同一个调度任务,取有探物的为当前位置)
/// 并且判断是否存在提前触发任务
/// 5.获取调度任务的优先策略判断:最短路径优先,
/// 入库优先携带出库,出库优先携带入库等
/// 6.任务号传递到当前设备时,把本路径的前一设备的运行锁解除,
/// 同时把当前设备加运行锁
/// 7.(根据故障点单独处理)调度路径是否可用的分析以及给管理进行反馈
/// 8.(单独处理)创建自动调度任务
/// 9.动画显示设备状态
///
public class CGetState
{
private Model.MError errs;
private Model.MDevice devinfo;
private ISendDeviceOrder sdo;
private CCommonFunction ccf = new CCommonFunction();
private CControl ccl = new CControl();
private string _CGetStateError = "";//监控调度类错误说明
public string CGetStateError
{
get { return _CGetStateError; }
set { _CGetStateError = value; }
}
public int[] _States;
private int _fid;
///
/// ManageTypeIndex
///
private int _mti;
private string _start_cell;
private string _fmanageid;
///
/// 获得所有正在执行设备的状态
///
public CGetState()
{
}
///
/// 获得反馈信息
///电器反馈该设备的"完成"时 删除设备指令 , 解除设备表占用状态F_LockedState=0;
///路径明细表F_LockedDeviceIndex里的所有对应设备索引解锁;
///
///判断是最后一个设备指令吗? 是,回写调度任务IO_Control的FSTATUS=2即"搬运完成";
/// T_Manage_Task的正在执行状态FSTATUS=2
///
///
public void GetDeviceState()
{
try
{
DataView dv = new DataView();
DataView dvm = new DataView();
DataView dvmo = new DataView();
int devKind;
int DeviceIdx;
int MonitorIndex = 0;
string[] wv = new string[1] { "2" };
string[] witemnames = new string[1];
//分类查找的设备类型
DataView dd = DbHelperSQL.Query("SELECT F_DeviceIndex,F_DeviceKindIndex,F_MaxSendCount,F_SendInterval FROM T_Base_Device WHERE F_DeviceKindIndex in(1,2,5,32,33,34)").Tables[0].DefaultView;
for (int j = 0; j < dd.Count; j++)
{
DeviceIdx = Convert.ToInt32(dd[j]["F_DeviceIndex"]);
devKind = Convert.ToInt32(dd[j]["F_DeviceKindIndex"]);
if (devKind != 1)
{
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
//分类查找设备状态
GetKindDeviceState(MonitorIndex, DeviceIdx, 0);
}
else
{
continue;
}
}
dv = null; dvm = null; dvmo = null; dd = null;
#region 任务STOPPING处理
DataView dv_task = DbHelperSQL.Query("select * from t_warehouse").Tables[0].DefaultView;
Object RFIDCount = DbHelperSQL.GetSingle("select count from T_InTask_QTY");
//任务停止状态 且 出库任务 且 有尾箱结束标志
if (dv_task[0]["F_TASK_STATUS"].ToString() == "STOPPING" || (dv_task[0]["F_LASTBOX_REACH_FLAG"] != DBNull.Value && ((bool)dv_task[0]["F_LASTBOX_REACH_FLAG"])) || dv_task[0]["F_TASK_TYPE"].Equals("Out") || RFIDCount.ToString() == "0")
{
DataView dv_manage = DbHelperSQL.Query("select * from t_manage_task where fmanageid='" + dv_task[0]["F_TASK_NO"] + "'").Tables[0].DefaultView;
//且无调度任务
if (dv_manage.Count == 0)
{
{
DataView dv_rfid = DbHelperSQL.Query("select SOURCE_CELL_CODE from IO_RFID where STATION_CODE in ('" + CConfig.Device_Rfid + "') and not SOURCE_CELL_CODE='' and SOURCE_CELL_CODE is not null").Tables[0].DefaultView;
//且射频无物
if (dv_rfid.Count == 0)
{
bool cleared = true;
DataSet ds_diepan = DbHelperSQL.Query("select * from t_base_plc_ask where f_askkind=2 and not f_barcode='' and f_barcode is not null and not f_barcode='-'");
if (ds_diepan.Tables[0].Rows.Count > 0)
{ //叠盘机有物时,入库命令下达
foreach (DataRow dr in ds_diepan.Tables[0].Rows)
{
//sdo = CommModeCreate.CreateSendDeviceOrder(14001);
//sdo.SendDeviceOrder(3, 0, 0, 14001, 0);
//sdo = CommModeCreate.CreateSendDeviceOrder(12003);
//sdo.SendDeviceOrder(3, 0, 0, 12003, 0);
sdo = CommModeCreate.CreateSendDeviceOrder(int.Parse(dr["f_bindingdevice"].ToString()));
sdo.SendDeviceOrder(3, 0, 0, int.Parse(dr["f_bindingdevice"].ToString()), 0);
LogUtil.WriteLog("", "任务STOPPING处理;叠盘放行指令下达:" + int.Parse(dr["f_bindingdevice"].ToString()));
}
cleared = false;
}
/*//判断当前任务状态是否为停止,且设备指令只存在送货任务,入库或回库时,设备指令只剩下堆垛机送货任务,查询非送货任务数量,若为0,则调用机器人离开接口
DataView monitortask = DbHelperSQL.Query("select * from t_monitor_task where F_DeviceCommandIndex !='5'").Tables[0].DefaultView;
if (dv_task[0]["F_TASK_STATUS"].ToString() == "STOPPING" && monitortask.Count == 0)
{
ApplyResult ar = SendDataToAgv.LetGo();
}*/
//叠盘机无物且任务状态停止
if (cleared && dv_task[0]["F_TASK_STATUS"].ToString() == "STOPPING")
{ //停止成功
DbHelperSQL.ExecuteSql("update t_warehouse set f_task_no='',f_task_type='',f_task_status='FREE',f_equip_type='',F_IO_WH_SORT_CODE='',F_LASTBOX_REACH_FLAG=0");
DataView dv_task_list = DbHelperSQL.Query("select top 1 * from t_task_list where task_status ='Waiting'").Tables[0].DefaultView;
if (dv_task_list.Count > 0)
{
string sResult = string.Empty;
//开启下一个等待中的任务
new RGD.MdsAPI.HouseBase().InvokeHouse(dv_task_list[0]["METHOD_NAME"].ToString(), dv_task_list[0]["XMLIN"].ToString(), out sResult);
}
}
}
}
}
}
#endregion 任务STOPPING处理
}
catch (Exception ex)
{
if (FrmControlMonitor.FormInstance.GetObjectText("tsStatus").IndexOf("获取设备状态时:" + ex.Message) < 0)
{
FrmControlMonitor.FormInstance.FlashPanit("tsStatus", "获取设备状态时:" + ex.Message, true);
}
}
}
///
/// 分类查找设备状态
///
/// 设备指令索引
/// 设备编号
/// /// 调度路径的子路径的编号
public void GetKindDeviceState(int TaskIdx, int DeviceIdx, int RouteIDSub)
{
int[] States;
try
{
States = CStaticClass.GetDeviceState(DeviceIdx);//[0]读写标志;[1]状态;[2]任务号;[3]X坐标;[4]Y坐标;[5]设备索引
if (States == null || States.Length < 2)
{
return;
}
DbHelperSQL.ExecuteSql("update t_base_device set f_runstate='" + States[1] + "' where F_DeviceIndex='" + DeviceIdx + "'");
}
catch (Exception ex)
{
DbHelperSQL.ExecuteSql("update t_base_device set f_runstate='" + ex.Message + "' where F_DeviceIndex='" + DeviceIdx + "'");
if (FrmControlMonitor.FormInstance.GetObjectText("tsStatus").IndexOf("获取状态时:" + ex.Message) < 0)
{
FrmControlMonitor.FormInstance.FlashPanit("tsStatus", "获取状态时:" + ex.Message, true);
}
return;
}
_States = States;
if (States == null)//没接收到任何返回值
{
return;
}
else
{
#region 状态处理
TaskIdx = States[2];
int fid = ccf.GetManageTaskIndexfromMonitor(TaskIdx);//dzf根据指令号找到任务号 这里参数TaskIdx是从PLC上读上来的,PLC中的TaskIdx是上位机send任务带的指令号
int mti = ccf.GetManageTaskKindIndexFromMonitor(TaskIdx);//dzf根据指令号找到任务类型,1 调度 2自动 4手动等
if (States[1] >= 30)//故障
{
ActionError(DeviceIdx, TaskIdx, States[1]);//设备号 指令号 故障码
}
switch (BaseDeviceService.GetDeviceKindIdx(DeviceIdx))
{
//正在运行的设备如果有探物就是说托盘运行到此设备
//根据任务号判断是否为调度任务,改写T_Manage_Task的当前位置
//根据任务号和当前位置判断是否有提前触发任务
//任务号传递到当前设备时,把本路径的前一设备的运行锁解除,
//同时把当前设备加运行锁
case 1:
#region 堆垛机:
//1-正在运行 2-完成;3-要求调度重发命令;
//4-通知调度取消当前任务;其它值表示错误
if ((States[1] == 1))
{
//开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
if (mti == 1)
{
}
#region 双叉关联任务,能同步的同时报告运行 暂无
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
if (devinfo.IfCorrelDoubleFork == "1")
{
if (CGeneralFunction.DoubleForkIfSync(TaskIdx, DeviceIdx, 1) == true)
{
string[] df = CGeneralFunction.GetDoubleForkMonitorInfo(TaskIdx, DeviceIdx);
if (df != null)
{
ActionStartRun(Convert.ToInt32(df[2]), Convert.ToInt32(df[0]));
if (mti == 1)
{//20100714
fid = ccf.GetManageTaskIndexfromMonitor(Convert.ToInt32(df[0]));
}
}
}
}
#endregion 双叉关联任务,能同步的同时报告运行 暂无
}
if (States[1] == 2)//报告完成,应该也有坐标
{
string[] df = CGeneralFunction.GetDoubleForkMonitorInfo(TaskIdx, DeviceIdx);
bool snyc = CGeneralFunction.DoubleForkIfSync(TaskIdx, DeviceIdx, 1);
ActionComplete(DeviceIdx, TaskIdx, 1);
//刷新监控中心显示
#region 双叉关联任务,能同步的同时报告完成;异步的直接执行关联的命令
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
if ((devinfo.IfCorrelDoubleFork == "1") && (df != null))
{
if (snyc == true)//双叉关联任务是否能同步运行
{
ActionComplete(DeviceIdx, Convert.ToInt32(df[0]), 1);
}
else
{
ccl.SendMonitorTask(Convert.ToInt32(df[0]));
}
}
#endregion 双叉关联任务,能同步的同时报告完成;异步的直接执行关联的命令
}
break;
#endregion 堆垛机:
case 2:
#region 输送机
if ((States[1] == 1))//开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
{
//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
#region 双叉关联任务,能同步的同时报告运行
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
if (devinfo.IfCorrelDoubleFork == "1")
{
if (CGeneralFunction.DoubleForkIfSync(TaskIdx, DeviceIdx, 2) == true)
{
string[] df = CGeneralFunction.GetDoubleForkMonitorInfo(TaskIdx, DeviceIdx);
if (df != null)
{
ActionStartRun(Convert.ToInt32(df[2]), Convert.ToInt32(df[0]));
}
}
}
#endregion 双叉关联任务,能同步的同时报告运行
//刷新监控中心显示
}
if (States[1] == 2)//报告完成
{
string[] df = CGeneralFunction.GetDoubleForkMonitorInfo(TaskIdx, DeviceIdx);
bool snyc = CGeneralFunction.DoubleForkIfSync(TaskIdx, DeviceIdx, 2);
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
if (devinfo.IfCorrelDoubleFork == "1")
{
int updowndevice = new CommonService().GetUpAndDownDevices(DeviceIdx, devinfo.Dbw1Address);
if (-1 != updowndevice)
{
GetKindDeviceState(0, updowndevice, 0);
}
}
ActionComplete(DeviceIdx, TaskIdx, 1);
//刷新监控中心显示
#region 双叉关联任务,能同步的同时报告完成;异步的直接执行关联的命令
if ((devinfo.IfCorrelDoubleFork == "1") && (df != null))
{
if (snyc == true)
{
ActionComplete(DeviceIdx, Convert.ToInt32(df[0]), 1);
}
else
{
ccl.SendMonitorTask(Convert.ToInt32(df[0]));
}
}
#endregion 双叉关联任务,能同步的同时报告完成;异步的直接执行关联的命令
}
break;
#endregion 输送机
case 4:
#region 穿梭车
if ((States[1] == 1)) //开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
{//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
//刷新监控中心显示
}
if (States[1] == 2)//报告完成
{
ActionComplete(DeviceIdx, TaskIdx, 1);
}
break;
#endregion 穿梭车
case 32:
#region 拣选
if ((States[1] == 1))//开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
{//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
}
if (States[1] == 2)//报告完成
{
ActionComplete(DeviceIdx, TaskIdx, 1);
}
break;
#endregion 拣选
case 33:
#region 贴标
if ((States[1] == 1))//开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
{//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
}
if (States[1] == 2)//报告完成
{
ActionComplete(DeviceIdx, TaskIdx, 1);
}
break;
#endregion 贴标
case 34:
#region AGV
if ((States[1] == 1))//开始运行,设置T_Monitor_Task的F_Status=2// || (States[0] == 2)
{//正在运行的设备如果有探物就是说托盘运行到此设备
ActionStartRun(DeviceIdx, TaskIdx);
}
if (States[1] == 10)//将取报告完成
{
string sql = "select F_DeviceIndex from T_Monitor_Task where F_MonitorIndex=" + TaskIdx;
DataView dv = DbHelperSQL.Query(sql).Tables[0].DefaultView;
if (dv.Count > 0 && dv[0]["F_DeviceIndex"].ToString() == DeviceIdx.ToString())
{
ActionComplete(DeviceIdx, TaskIdx, 1);
}
}
break;
#endregion AGV
}
#endregion 状态处理
}
}
///
/// 设备开始运行:
/// 1-根据任务号和探物情况判断任务执行的位置回写本地管理表
/// 2-回写调度任务表的开始执行状态
/// 3-判断是否存在提前触发任务
///
/// 设备索引
/// 调度任务号
public void ActionStartRun(int DeviceIdx, int TaskIdx)
{
if (TaskIdx <= 0) return;
int mti = ccf.GetManageTaskIndexfromMonitor(TaskIdx);
int mtikind = ccf.GetManageTaskKindIndexFromMonitor(TaskIdx);
DataView dvlane;
DataView dv;
try
{
//修改调度任务状态
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_Status=2 where F_Status=1 and F_MonitorIndex=" + TaskIdx);
#region 根据任务号和探物情况判断任务执行的位置回写本地管理表
DbHelperSQL.ExecuteSql("update T_Manage_Task set FCurrentLocation=" + DeviceIdx + " where F_ManageTaskKindIndex=" + mtikind + " and FID=" + mti + "");
//调度任务表也记录当前位置,主要是给输送机链用
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_CurrentLocation=" + DeviceIdx + " where F_MonitorIndex=" + TaskIdx);
//设备逻辑有物
//20090918给堆垛机送货的输送机逻辑有物解锁F_HaveGoods=0
dvlane = DbHelperSQL.Query("SELECT F_LaneGateDeviceIndex FROM T_Base_Lane_Gate where F_LaneGateDeviceIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvlane.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=0 where F_DeviceIndex=" + DeviceIdx);
}
else
{
//AGV暂无
dvlane = DbHelperSQL.Query("SELECT F_AGVGateDeviceIndex FROM T_Base_AGV_Gate where F_AGVGateDeviceIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvlane.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=0 where F_DeviceIndex=" + DeviceIdx);
}
}
DbHelperSQL.ExecuteSql("update T_Base_Lane_Gate set F_LogicHave = 0 where F_LogicHave =" + TaskIdx);//清理堆垛机发送后给巷道出口设备置的指令号
#endregion 根据任务号和探物情况判断任务执行的位置回写本地管理表
if (CStaticClass.MovedDeviceAheadTrigger == "1")
{
#region 判断是否存在提前触发任务(设备号-调度任务号) 堆垛机
//当设备运行时,触发调度任务号运行F_AheadTrigger
dv = DbHelperSQL.Query("select F_AheadTrigger from T_Monitor_Task " + "where F_MonitorIndex=" + TaskIdx + " and F_AheadTrigger like '" + DeviceIdx.ToString() + "-" + "%'").Tables[0].DefaultView;
if (dv.Count > 0)
{
//发送提前触发的命令调度任务
char[] cc = new char[1] { '-' };
string[] sp = dv[0]["F_AheadTrigger"].ToString().Split(cc);
if (sp.GetLength(0) > 0)
{
int TriTask = Convert.ToInt32(sp[1]);
if (ccl.SendMonitorTask(TriTask) == true)
{
//清除触发命令
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_AheadTrigger ='' where F_MonitorIndex=" + TaskIdx);
}
}
}
#endregion 判断是否存在提前触发任务(设备号-调度任务号) 堆垛机
}
}
catch (Exception ex)
{
_CGetStateError = "ControlSystem.CGetState发生错误:" + ex.Message;
}
finally
{
dvlane = null;
dv = null;
}
}
///
/// 报告完成
///电器反馈该设备的"完成"时 删除设备指令 , 解除设备表占用状态F_LockedState=0;
///路径明细表F_LockedDeviceIndex里的所有对应设备索引解锁
///
///判断是最后一个设备指令吗? 是,回写调度任务IO_Control的FSTATUS=2即"搬运完成";
/// T_Manage_Task的正在执行状态FSTATUS=2 ;
///
/// 设备索引
/// 设备指令索引
///是否向设备发送清零命令:1清零;900撤销整个调度任务;999手工报告调度任务完成
public void ActionComplete(int DeviceIdx, int TaskIdx, int ClearZero)
{
if (TaskIdx == 0)
{
return;
}
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
int devKind = BaseDeviceService.GetDeviceKindIdx(DeviceIdx);
int[] zxy = ccf.GetCoordinatesFromMonitorTask(TaskIdx);
string zxystr = "";
if (zxy != null)
{
//送货点坐标
zxystr = (zxy[3].ToString().Length == 1 ? "0" + zxy[3].ToString() : zxy[3].ToString()) + "-" + ((zxy[4].ToString().Length == 1) ? ("0" + zxy[4].ToString()) : (zxy[4].ToString())) + "-" + ((zxy[5].ToString().Length == 1) ? ("0" + zxy[5].ToString()) : (zxy[5].ToString()));
}
int order = ccf.GetDeviceOrderFromMonitor(TaskIdx);
if (order == -1)
{
_CGetStateError = "电器反馈的调度任务号没有记忆!";
return;
}
if (GetManage_Kind(TaskIdx) == false)
{
//没有调度任务 返回
return;
}
LogUtil.WriteLog("", "电气任务报完成;DeviceIdx:" + DeviceIdx + ";TaskIdx:" + TaskIdx);
int errrcode = new ManageTaskService().GetExceptionNOFromManageTask(_fid, _mti);
//任务类型
int ControlType = ccf.GetFCONTROLTASKTYPEFromManageTask(_mti, _fid);
//20100710
int AgvNextDeviceKind = 0;//设备类型
if ((devKind == 6) && (order == 2))
{
AgvNextDeviceKind = BaseDeviceService.GetDeviceKindIdx(zxy[4]);
}
int ErrorCount = 0;
DataView dvtemp = DbHelperSQL.Query("select F_ErrorCount from t_base_device where F_DeviceIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvtemp.Count > 0)
{
if (dvtemp[0][0] == DBNull.Value)
{
ErrorCount = 0;
}
else
{
ErrorCount = ((int)dvtemp[0][0]);
}
}
if (ErrorCount > 1)
{
//设备有异常将无法完成
return;
}
DataView dvman;
DataView dv;
DataView dvlane;
#region 出库优先携带入库优先策略的处理(入出库交替)
if ((devKind == 1) && (ccf.GetFCONTROLTASKTYPEFromManageTask(_mti, _fid) == 2))//堆垛机出库优先并且携带入库任务
{
string mansql = "select * from T_Manage_Task where FTASKLEVEL=10 and FSTACK = " + DeviceIdx + " AND (FCONTROLTASKTYPE = 1) AND (FIntoStepOK = '1') ";
dvman = DbHelperSQL.Query(mansql).Tables[0].DefaultView;
if (dvman.Count <= 0)
{
mansql = "SELECT FID, F_ManageTaskKindIndex, FCONTROLTASKTYPE FROM T_Manage_Task WHERE (FSTACK = " + DeviceIdx + ") AND (FCONTROLTASKTYPE = 1) AND (FIntoStepOK = '1') order by FTASKLEVEL desc, F_ManageTaskKindIndex desc,FID asc";
dvman = DbHelperSQL.Query(mansql).Tables[0].DefaultView;
for (int ii = 0; ii < dvman.Count; ii++)
{
string sql = "select * from T_Monitor_Task where F_ManageTASKKINDINDEX=" + dvman[ii]["F_ManageTASKKINDINDEX"] + " and F_ManageTaskIndex=" + dvman[ii]["FID"] + " order by F_MonitorIndex asc";
dv = DbHelperSQL.Query(sql).Tables[0].DefaultView;
if (dv.Count > 0)
{
int stackkind = BaseDeviceService.GetDeviceKindIdx(Convert.ToInt32(dv[0]["F_DeviceIndex"]));
if (stackkind == 1)
{
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_MonitorTaskLevel=10 where F_ManageTASKKINDINDEX=" + dvman[ii]["F_ManageTASKKINDINDEX"] + " and F_ManageTaskIndex=" + dvman[ii]["FID"] + "");
DbHelperSQL.ExecuteSql("update T_Manage_Task set FTASKLEVEL=10 where F_ManageTASKKINDINDEX=" + dvman[ii]["F_ManageTASKKINDINDEX"] + " and FID=" + dvman[ii]["FID"] + "");
break;
}
}
}
}
}
#endregion 出库优先携带入库优先策略的处理(入出库交替)
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
try
{
int fid = _fid;
int mti = _mti;
string BOX_LABLE = string.Empty;
bool TASK_TYPE = false;
#region [堆垛机任务]补充逻辑预约锁的解锁(此调度任务的此设备的最后一个命令需要解锁,有关联任务的改为关联任务预约)
if (devKind == 1)
{
object ob = DbHelperSQL.GetSingle("select count(F_MonitorIndex) as counts from T_Monitor_Task " +
" where F_ManageTaskIndex =" + fid + " and F_ManageTaskKindIndex= " + mti + " and F_DeviceIndex=" + DeviceIdx);
if (Convert.ToInt32(ob) == 1)//dzf同一任务的同一设备的最后一条指令
{
#region 有管理任务存在,增加关联任务预约锁//20100710
ob = DbHelperSQL.GetSingle("SELECT T_Manage_Task.FID FROM T_Manage_Task ,T_Monitor_Task where T_Manage_Task.F_ManageTaskKindIndex = T_Monitor_Task.F_ManageTASKKINDINDEX AND T_Manage_Task.FID = T_Monitor_Task.F_ManageTaskIndex and (T_Manage_Task.F_RELATIVECONTORLID = " + fid + ") AND (T_Manage_Task.F_ManageTaskKindIndex = " + mti + ") and F_DeviceIndex=" + DeviceIdx + "");
if (ob != null)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_ManTaskReserve=" + (mti.ToString() + ob.ToString()) + " where F_ManTaskReserve=" + (mti.ToString() + fid.ToString()) + " and F_DeviceIndex=" + DeviceIdx);
}
else
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_ManTaskReserve=0 where F_ManTaskReserve=" + (mti.ToString() + fid.ToString()) + " and F_DeviceIndex=" + DeviceIdx);
}
#endregion 有管理任务存在,增加关联任务预约锁//20100710
}
}
#endregion [堆垛机任务]补充逻辑预约锁的解锁(此调度任务的此设备的最后一个命令需要解锁,有关联任务的改为关联任务预约)
//dv = DbHelperSQL.Query("select count(F_MonitorIndex) as counts from T_Monitor_Task ").Tables[0].DefaultView;
dv = DbHelperSQL.Query("select count(F_MonitorIndex) as counts from T_Monitor_Task " + " where F_ManageTaskIndex =" + fid + " and F_ManageTaskKindIndex= " + mti).Tables[0].DefaultView;
if (dv.Count > 0)
{
#region 最后一个调度任务的处理
if ((Convert.ToInt32(dv[0]["counts"]) == 1))
{
//回写管理表//20091128
if ((ClearZero != CGeneralFunction.TASKDELETE) && (ClearZero != CGeneralFunction.TASKSTOPOUTPUT))//调度撤销删除调度任务900;人工暂停出库任务940
{
bool IS_PICKUP = true;
Object dt1 = DbHelperSQL.GetSingle("select F_DeviceCommandIndex from T_Monitor_Task");
if (dt1.ToString() == "9")
{
IS_PICKUP = false;
}
string Task_NO = "";
//固定路径模式
//调度任务的fid的最后一个监控分解任务完成
if (mti == 1)
{
//完成FSTATUS=999;970堆垛机送货重故障异常完成;980堆垛机取空故障异常完成;990条码扫描异常完成;
//调度撤销删除调度任务900;950送到拆盘机的不是空托盘组;940人工暂停出库任务
bool bResult = true;
string sResult = string.Empty;
DataView dvt = DbHelperSQL.Query("SELECT * FROM T_Manage_Task where F_ManageTaskKindIndex=" + mti + " and FID=" + fid + "").Tables[0].DefaultView;
DataView dv_task = DbHelperSQL.Query("select * from t_WareHouse").Tables[0].DefaultView;
//if (dv_task[0]["F_TASK_TYPE"].ToString() == "In" && dvt[0]["FENDDEVICE"].ToString()!="12001")
//{
// TASK_TYPE = true;
//}
BOX_LABLE = dvt[0]["BOX_LABLE"].ToString();
Task_NO = dvt[0]["fmanageid"].ToString();
//flaneway任务所在巷道的设备索引
if (dvt[0]["flaneway"].ToString() != "-1")
{
#region 盘点 出入库 堆垛机
string IO_FLAG, LOC_NO;
{
if (dvt[0]["FSTARTCELL"].ToString() == "-")
{
//入库
IO_FLAG = "02";
LOC_NO = dvt[0]["FENDCELL"].ToString();
}
else
{
IO_FLAG = "01";
LOC_NO = dvt[0]["FSTARTCELL"].ToString();
//出库时候由输送线上报完成 入库时候agv报完成
bResult = (new uploadStackIODet()).Notify(dvt[0]["fmanageid"].ToString(), IO_FLAG, LOC_NO, out sResult);
if (!bResult)
{
throw new Exception("接口调用失败。" + DateTime.Now.ToString() + "\r\n接口:uploadStackIODet。任务编号:" + TaskIdx + "\r\n错误信息:" + sResult);
}
}
}
#endregion 盘点 出入库 堆垛机
}
//更新叠盘机箱标签
if (dvt[0]["FENDDEVICE"].ToString() == CConfig.Device_Stacker.ToString())
{
if (dvt[0]["BOX_LABLE"].ToString().Contains("IS_RESTACK"))
{
DbHelperSQL.ExecuteSql("update T_Base_PLC_Ask set F_BOX_LABLE='" + dvt[0]["BOX_LABLE"].ToString().Replace("IS_RESTACK|", "") + "' where (F_BindingDevice=" + DeviceIdx + ")");
}
else
{
DbHelperSQL.ExecuteSql("update T_Base_PLC_Ask set F_BOX_LABLE='" + dvt[0]["BOX_LABLE"].ToString() + "' where (F_BindingDevice=" + DeviceIdx + ")");
}
}
// 任务终点是射频门,软启动射频
if (zxy != null && (zxy[3] == CConfig.Device_Rfid))
{
DbHelperSQL.ExecuteSql("update IO_RFID set BEGIN_TIME='" + DateTime.Now.ToString() + "',SOURCE_CELL_CODE='" + dvt[0]["FSTARTCELL"] + "',box_barcode='" + dvt[0]["FPALLETBARCODE"] + "' where (STATION_CODE='" + zxy[3] + "')");
}
if (!bResult)
{
bResult = (new uploadWhExceptionInfo()).Notify(DeviceIdx.ToString(), devinfo.DeviceName, sResult, DateTime.Now.ToString(), out sResult);
if (!bResult)
{
throw new Exception("接口调用失败。" + DateTime.Now.ToString() + "\r\n接口:uploadWhExceptionInfo。任务编号:" + TaskIdx + "\r\n错误信息:" + sResult);
}
ErrorCountAdd(DeviceIdx);
}
else
{//处理成功,清除设备故障计数
DbHelperSQL.ExecuteSql("update t_base_device set F_ErrorCount=0 where F_DeviceIndex=" + DeviceIdx);
}
}
ReturnManageInfo(fid, mti, true);
}
else
{
ReturnManageInfo(fid, mti, false);
}
}
#endregion
}
//被这个任务号锁定的设备全部解锁
DbHelperSQL.ExecuteSql("update T_Base_Device set F_LockedState=0 where F_LockedState=" + TaskIdx);
DbHelperSQL.ExecuteSql("update T_Base_Device set F_CreateLock='0' where F_DeviceIndex=" + DeviceIdx);
if (ClearZero != CGeneralFunction.TASKDELETE)//20100710删除调度任务不置逻辑有物
{
//堆垛机接货输送机完成时逻辑无货20100710
dvlane = DbHelperSQL.Query("SELECT F_LaneGateDeviceIndex FROM T_Base_Lane_Gate where F_LaneGateDeviceIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvlane.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=0 where F_DeviceIndex=" + DeviceIdx + " and F_HaveGoods=1");
}
else
{
//AGV接货输送机完成时逻辑无货20100710
dvlane = DbHelperSQL.Query("SELECT F_AGVGateDeviceIndex FROM T_Base_AGV_Gate where F_AGVGateDeviceIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvlane.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=0 where F_DeviceIndex=" + DeviceIdx);
}
}
//根据出口巷道设备里面置的指令号来置逻辑无货
DataView dvj = DbHelperSQL.Query("select F_LaneGateDeviceIndex from T_Base_Lane_Gate where F_LogicHave =" + TaskIdx).Tables[0].DefaultView;
if (dvj.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=0 where F_DeviceIndex='" + dvj[0]["F_LaneGateDeviceIndex"] + "'");
DbHelperSQL.ExecuteSql("update T_Base_Lane_Gate set F_LogicHave = 0 where F_LogicHave =" + TaskIdx);// 清除出口巷道设备里面置的指令号
}
}
#region 堆垛机、AGV逻辑有物的处理20101011
if (ClearZero != CGeneralFunction.TASKDELETE)//删除调度任务不置为逻辑有物
{
if ((devKind == 1) && ((order == 4) || (order == 5) || (order == 6)))//20101011 4取5送
{
bool sh = false;//20101011
if (order == 5) sh = true;//20101011
if (sh == true)//20101011
{
//20090918给堆垛机送货的输送机增加逻辑有物
////20100609改为使用巷道表关联
dvlane = DbHelperSQL.Query("SELECT T_Base_Lane_Gate.F_LaneGateDeviceIndex from T_Base_Lane_Gate,T_Base_LaneInfo " +
" where T_Base_Lane_Gate.F_LaneIndex = T_Base_LaneInfo.F_LaneDeviceIndex and T_Base_Lane_Gate.F_ZXY='" + zxystr + "' " +
" and T_Base_LaneInfo.F_StackIndex=" + DeviceIdx).Tables[0].DefaultView;
if (dvlane.Count > 0)
{
//dbo.ExceSQL("update T_Base_Device set F_HaveGoods=1 where F_DeviceIndex=" + dvlane[0]["F_LaneGateDeviceIndex"]);
DataView dvv = DbHelperSQL.Query("select F_MonitorIndex from T_Monitor_Task where F_ManageTaskIndex =" + fid + "and F_MonitorIndex>" + TaskIdx + "order by F_MonitorIndex asc").Tables[0].DefaultView;//增加 将出库堆垛机送出后的下一条指令号写在出口巷道设备里面
if (dvv.Count > 0)
{
DbHelperSQL.ExecuteSql("update T_Base_Lane_Gate set F_LogicHave = '" + dvv[0]["F_MonitorIndex"] + "' where F_LaneGateDeviceIndex =" + dvlane[0]["F_LaneGateDeviceIndex"]);
}
}
}
}
else if ((devKind == 6) && (order == 2) && (AgvNextDeviceKind == 2))//AGV向输送机放货20100710
{
DbHelperSQL.ExecuteSql("update T_Base_Device set F_HaveGoods=1 where F_DeviceIndex=" + zxy[4]);
}
}
#endregion
#region 向设备发送清零命令
if (ClearZero == 1)
{
sdo = CommModeCreate.CreateSendDeviceOrder(DeviceIdx);
if ((devKind == 34) || (devKind == 2) || (devKind == 32) || (devKind == 33))
{
//输送机、RGV故障清零
if (zxy != null && (DeviceIdx == CConfig.Device_Stacker))
{
//叠盘机上箱标签
DataView dv_plc_ask = DbHelperSQL.Query("select * from t_base_plc_ask where f_bindingdevice=" + DeviceIdx).Tables[0].DefaultView;
//到此叠盘机的任务
DataView dv_manage_other = DbHelperSQL.Query("select * from t_manage_task where FENDDEVICE=" + DeviceIdx).Tables[0].DefaultView;
LogUtil.WriteLog("", "TaskIdx:" + TaskIdx + ";GetState_叠盘机缓存:" + dv_plc_ask[0]["F_BarCode"].ToString() + ";叠盘机尾箱标签:" + dv_plc_ask[0]["F_BOX_LABLE"].ToString());
//输送线有到叠盘的任务 且 叠盘机有缓存(实际完成当前箱并未修改) 且 剩余任务标签与叠盘机最后标签不一致 dv_plc_ask[0]["F_BarCode"].ToString() != ""
//只要出现IS_RESTACK 必定不与缓存一致
if (dv_manage_other.Count > 0 && (1 == 1 && dv_manage_other[0]["BOX_LABLE"].ToString() != dv_plc_ask[0]["F_BOX_LABLE"].ToString()))
{
//有执行中任务,且,第一条标签不同
//sdo.SendDeviceOrder(2, 0, 0, DeviceIdx, 0);
//Thread.Sleep(100);
sdo.SendDeviceOrder(3, 0, 0, DeviceIdx, 0);
LogUtil.WriteLog("", "TaskIdx:" + TaskIdx + ";任务完成叠盘放行;箱号:" + new MonitorTaskService().GetBarCodeFromMonitor(TaskIdx) + ";当前任务标签: " + dv_manage_other[0]["BOX_LABLE"].ToString());
}
else
{
sdo.SendDeviceOrder(2, 0, 0, DeviceIdx, 0);
LogUtil.WriteLog("", "TaskIdx:" + TaskIdx + ";任务完成叠盘应答;箱号:" + new MonitorTaskService().GetBarCodeFromMonitor(TaskIdx));
//}
}
}
else
{
sdo.SendDeviceOrder(2, 0, 0, DeviceIdx, 0);
}
}
else if (devKind == 1) //堆垛机
{
sdo.SendDeviceOrder(2, 0, 0, DeviceIdx, 0, 0, 0, 0, 0, 0);
}
}
#endregion
// 每次叠盘任务完成时更新叠盘机条码信息
if (zxy != null && zxy[3] == 12003)
{
DbHelperSQL.ExecuteSql("update T_Base_PLC_Ask set F_BarCode=F_BarCode +'" + ccf.GetBarCodeFromMonitor(TaskIdx) + "|' where (F_BindingDevice=" + DeviceIdx + ")");
}
DbHelperSQL.ExecuteSql("delete from T_Monitor_Task where F_MonitorIndex=" + TaskIdx);
}
catch (Exception ex)
{
//dbo.TransRollback();
if (FrmControlMonitor.FormInstance.GetObjectText("tsStatus").IndexOf("报告完成时:" + ex.Message) < 0)
{
FrmControlMonitor.FormInstance.FlashPanit("tsStatus", "报告完成时:" + ex.Message, true);
}
ErrorCountAdd(DeviceIdx);
LogUtil.WriteLog("", "Error:" + ex.Message + "-" + ex.Source);
//throw ex;
}
finally
{
dvman = null;
dv = null;
dvlane = null;
}
}
private void ErrorCountAdd(int DeviceIndex)
{
int ErrorCount = 0;
DataView dv = DbHelperSQL.Query("select F_ErrorCount from t_base_device where F_DeviceIndex=" + DeviceIndex).Tables[0].DefaultView;
if (dv.Count > 0)
{
if (dv[0][0] == DBNull.Value)
{
ErrorCount = 1;
}
else
{
ErrorCount = ((int)dv[0][0]) + 1;
}
}
DbHelperSQL.ExecuteSql("update t_base_device set F_ErrorCount=" + ErrorCount + " where F_DeviceIndex=" + DeviceIndex);
}
///
/// 回写设备错误状态字(IO_Control,T_Manage_Task,T_Monitor_task)
///
/// 设备索引
/// 设备指令索引
/// 错误编号
public void ActionError(int DeviceIdx, int TaskIdx, int ErrId)
{
DataView dvmon;
DataTable dt;
DataView dv0;
try
{
//090915
string monsql = "SELECT F_MonitorIndex FROM T_Monitor_Task where F_Status =1 and F_DeviceIndex =" + DeviceIdx;
//20100108
dvmon = DbHelperSQL.Query(monsql).Tables[0].DefaultView;
if ((dvmon.Count > 0) && (TaskIdx == 0))
{
TaskIdx = Convert.ToInt32(dvmon[0]["F_MonitorIndex"]);
}
//090915
//有过记录的故障设备的任务号,不再重复处理
string devstr = "SELECT F_DeviceIndex FROM T_Base_Device where F_DeviceIndex=" + DeviceIdx + " and F_ErrorTaskNo=" + TaskIdx + "";
//20100108
dt = DbHelperSQL.Query(devstr).Tables[0];
if (dt.Rows.Count >= 1)
{
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_Status= " + ErrId + " where (F_MonitorIndex= " + TaskIdx + ") and ((F_Status<> " + ErrId + ") and (F_Status<> 3))");
return;
}
devinfo = BaseDeviceService.GetDeviceInfo(DeviceIdx);
int devKind = BaseDeviceService.GetDeviceKindIdx(DeviceIdx);
if (GetManage_Kind(TaskIdx) == false) return;
int fid = _fid;
int mti = _mti;
//string fwarehouse = "";
//string fcode = "";
//int flane = 0;
errs = BaseDeviceService.GetErrorInfo(Convert.ToInt32(devKind.ToString() + ErrId.ToString()));
if (errs.ErrorIndex > 0)
{
FrmMain.FormInstance.notifyIcon1.BalloonTipText = "警告:" + devinfo.DeviceName + "," + DeviceIdx + "发生故障:" + errs.ErrorName;
FrmMain.FormInstance.notifyIcon1.ShowBalloonTip(10000, "警告", devinfo.DeviceName + "," + DeviceIdx + "发生故障:" + errs.ErrorName, System.Windows.Forms.ToolTipIcon.Warning);
if (mti == 1)
{
string sResult;
RGD.MdsAPI.WMS.uploadWhExceptionInfo ss = new RGD.MdsAPI.WMS.uploadWhExceptionInfo();
ss.Notify(DeviceIdx.ToString(), devinfo.DeviceName, errs.ErrorName, DateTime.Now.ToString(), out sResult);
}
//20100108
dv0 = DbHelperSQL.Query("SELECT F_DeviceIndex, F_ErrorIndex FROM T_Base_Device_Error_Log Where F_ManageTaskNo=" + fid + " and F_DeviceIndex=" + DeviceIdx + " and F_ErrorIndex=" + errs.ErrorIndex).Tables[0].DefaultView;
string dtime = DateTime.Now.ToString("u");//20110603
dtime = dtime.Substring(0, dtime.Length - 1);
if (dv0.Count > 0)
{//20091107
DbHelperSQL.ExecuteSql("UPDATE T_Base_Device_Error_Log SET F_DateTime ='" + dtime + "' Where F_DeviceIndex=" + DeviceIdx + " and F_ErrorIndex=" + errs.ErrorIndex + " and F_ManageTaskNo=" + fid);
}
else
{
DbHelperSQL.ExecuteSql("INSERT INTO T_Base_Device_Error_Log (F_ManageTaskNo,F_DeviceIndex, F_ErrorIndex, F_DateTime) VALUES (" + fid + "," + DeviceIdx + "," + errs.ErrorIndex + ",'" + dtime + "')");
}
}
//20090915
DbHelperSQL.ExecuteSql("update T_Monitor_Task set F_Status= " + ErrId + " where F_MonitorIndex= " + TaskIdx + " and (F_Status<> 3)");
//记录发生故障的设备正在执行的任务号
DbHelperSQL.ExecuteSql("update T_Base_Device set F_ErrorTaskNo= " + TaskIdx + " where F_DeviceIndex= " + DeviceIdx);
DbHelperSQL.ExecuteSql("update T_Manage_Task set FERRORCODE='" + devinfo.DeviceName + "," + DeviceIdx + errs.ErrorName + "' where F_ManageTaskKindIndex=" + mti + " and FID=" + fid);
if (devinfo.UseCommonDB == "1")
{
return;
}
}
catch (Exception ex)
{
//dbo.TransRollback();
if (FrmControlMonitor.FormInstance.GetObjectText("tsStatus").IndexOf("向管理反馈设备错误时:" + ex.Message) < 0)
{
FrmControlMonitor.FormInstance.FlashPanit("tsStatus", "向管理反馈设备错误时:" + ex.Message, true);
}
}
finally
{//20100108
dvmon = null;
dt = null;
dv0 = null;
}
}
public bool GetManage_Kind(int taskidx)
{//20100108
DataSet ds;
try
{
//CCommonFunction ccf=new CCommonFunction();
ds = DbHelperSQL.Query("SELECT F_ManageTaskIndex, T_Monitor_Task.F_ManageTaskKindIndex, F_MonitorIndex,FSTARTCELL,FMANAGEID FROM T_Monitor_Task,T_Manage_Task Where F_ManageTaskIndex=FID and F_MonitorIndex=" + taskidx);
if (ds.Tables[0].DefaultView.Count > 0)
{
_fid = Convert.ToInt32(ds.Tables[0].DefaultView[0]["F_ManageTaskIndex"]);
_mti = Convert.ToInt32(ds.Tables[0].DefaultView[0]["F_ManageTaskKindIndex"]);
_start_cell = ds.Tables[0].DefaultView[0]["FSTARTCELL"].ToString();
_fmanageid = ds.Tables[0].DefaultView[0]["FMANAGEID"].ToString();
return true;
}
else
{
return false;
}
}
catch (Exception ex)
{
throw ex;
}
finally
{//20100108
ds = null;
}
}
//刷新监控中心显示
public void RefreshControlMonitor(int devidx)
{//_States[5] == DeviceIdx
try
{
if (CStaticClass.RealRefresh == true)
{
//显示设备指令
DataSet ds = DbHelperSQL.Query("select * from V_Monitor_Task where " + CStaticClass.Monstatus);
FrmControlMonitor.FormInstance.MonitorRefresh(ds.Tables[0].DefaultView);
//显示调度任务
FrmControlMonitor.FormInstance.ManagerRefresh(
DbHelperSQL.Query("select * from V_Manage_Task where " + CStaticClass.Manstatus).Tables[0].DefaultView);
}
}
catch (Exception ex)
{
throw ex;
}
}
///
/// 增加货位记录
///
///
///
///
public void ReturnManageInfo(int fid, int mti, bool IFOK)
{
string dtime = DateTime.Now.ToString("u");//20101028
dtime = dtime.Substring(0, dtime.Length - 1);//20101028
char[] cc = new char[1] { '-' };
string[] fcc;
DataView dv;
try
{
//200906240111增加货位记录:入库1-结束位置有货;出库2-起始位置无货;倒库3-起始位置无货,结束位置有货
//20100108
dv = DbHelperSQL.Query("SELECT * FROM T_Manage_Task where F_ManageTaskKindIndex=" + mti + " and FID=" + fid + "").Tables[0].DefaultView;
if (dv.Count > 0)
{
if (IFOK == true)
{
switch (dv[0]["FCONTROLTASKTYPE"].ToString())
{
case "1":
if (dv[0]["FENDCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FENDCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FCELLSTATUS = 1,FPALLETBARCODE='" + dv[0]["FPALLETBARCODE"] + "' WHERE (FLaneWay=" + dv[0]["FENDDEVICE"] + " and F_Z='" +
fcc[0] + "' and F_X='" + fcc[1] + "' and F_Y='" + fcc[2] + "')");
}
break;
case "2":
{
if (dv[0]["FSTARTCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FSTARTCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FCELLSTATUS =0,FPALLETBARCODE='-' WHERE (FLaneWay=" + dv[0]["FSTARTDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
}
break;
case "3":
if (dv[0]["FENDCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FENDCELL"].ToString().Split(cc);//FRUNSTATUS=0,
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FCELLSTATUS = 1,FPALLETBARCODE='" + dv[0]["FPALLETBARCODE"] + "' WHERE (FLaneWay=" + dv[0]["FENDDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FBIAOZHI =1 WHERE (FLaneWay=" + dv[0]["FENDDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
if (dv[0]["FSTARTCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FSTARTCELL"].ToString().Split(cc);//FRUNSTATUS=0,
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FCELLSTATUS =0,FPALLETBARCODE='-' WHERE (FLaneWay=" + dv[0]["FSTARTDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
break;
default:
break;
}
//20101028
DbHelperSQL.ExecuteSql("update T_Manage_Task set FSTATUS=999,FENDTIME='" + dtime + "' where FID=" + fid + " and F_ManageTaskKindIndex= " + mti);
}
else
{
switch (dv[0]["FCONTROLTASKTYPE"].ToString())
{
case "1":
if (dv[0]["FENDCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FENDCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FPALLETBARCODE='' WHERE (FLaneWay=" + dv[0]["FENDDEVICE"] + " and F_Z='" +
fcc[0] + "' and F_X='" + fcc[1] + "' and F_Y='" + fcc[2] + "')");
}
break;
case "2":
if (dv[0]["FSTARTCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FSTARTCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FPALLETBARCODE='" + dv[0]["FPALLETBARCODE"] + "' WHERE (FLaneWay=" + dv[0]["FSTARTDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
break;
case "3":
if (dv[0]["FENDCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FENDCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FPALLETBARCODE='' WHERE (FLaneWay=" + dv[0]["FENDDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
if (dv[0]["FSTARTCELL"].ToString().IndexOf("-") > 0)//20100905
{
fcc = dv[0]["FSTARTCELL"].ToString().Split(cc);
DbHelperSQL.ExecuteSql("UPDATE ST_CELL SET FRUNSTATUS=0,FPALLETBARCODE='" + dv[0]["FPALLETBARCODE"] + "' WHERE (FLaneWay=" + dv[0]["FSTARTDEVICE"] + " and F_Z=" +
fcc[0] + " and F_X=" + fcc[1] + " and F_Y=" + fcc[2] + ")");
}
break;
default:
break;
}
//20101028
DbHelperSQL.ExecuteSql("update T_Manage_Task set FSTATUS=900,FENDTIME='" + dtime + "' where FID=" + fid + " and F_ManageTaskKindIndex= " + mti);
}
}
DbHelperSQL.ExecuteSql("delete from T_Manage_Task where FID=" + fid + " and F_ManageTaskKindIndex= " + mti);
}
catch (Exception ex)
{
throw ex;
}
finally
{
dv = null;
}
}
///
/// 追加倒库货位至真实终点货位的取货和送货指令
///
/// 任务类型
/// 调度任务索引
/// 设备索引
/// 设备指令索引
private void AppendMoveCellOperate(int mti, int fid, int device, int monitorindex)
{
//获取管理任务送货坐标,当前调度任务的路径,条码,优先级;远近货叉,提前检测
string manzxy = DbHelperSQL.GetSingle("SELECT FENDCELL FROM T_Manage_Task WHERE (FID = " + fid + ") AND (F_ManageTaskKindIndex = " + mti + ")").ToString();
char[] cc = new char[1] { '-' };
string[] spcell = manzxy.Split(cc);
string newuseawayfork;
DataView dv = DbHelperSQL.Query("select F_NumParam4, F_NumParam5,F_NumParam6, F_RouteID,F_MonitorTaskLevel, F_UseAwayFork, F_TxtParam from T_Monitor_Task where F_MonitorIndex=" + monitorindex).Tables[0].DefaultView;
if (dv[0]["F_UseAwayFork"].ToString() == "1")
{
newuseawayfork = "0";
}
else
{
newuseawayfork = "1";
}
DbHelperSQL.ExecuteSql("update T_Manage_Task set FExceptionNO=NULL,FUseAwayFork='" + newuseawayfork + "' where F_ManageTaskKindIndex=" + mti + " and FID=" + fid);
int lev = int.Parse(dv[0]["F_MonitorTaskLevel"].ToString());
int routeid = int.Parse(dv[0]["F_RouteID"].ToString());
int fnp1 = int.Parse(dv[0]["F_NumParam4"].ToString());
int fnp2 = int.Parse(dv[0]["F_NumParam5"].ToString());
int fnp3 = int.Parse(dv[0]["F_NumParam6"].ToString());
string pcode = dv[0]["F_TxtParam"].ToString();
//string aheaddetect=;
int mindex = ccf.GetMonitorIndex(fid, mti);
DbHelperSQL.ExecuteSql("INSERT INTO T_Monitor_Task (F_ManageTaskIndex, F_ManageTASKKINDINDEX, F_MonitorIndex, F_MonitorTaskLevel," +
" F_DeviceIndex, F_DeviceCommandIndex, F_RouteID, F_Status,F_NumParam1, F_NumParam2, F_NumParam3, F_NumParam4, F_NumParam5," +
" F_NumParam6, F_TxtParam, F_AheadDetect, F_UseAwayFork)VALUES " +
"(" + fid + "," + mti + "," + mindex + "," + lev + "," + device + ",4," + routeid + ",0," + fnp1 + "," + fnp2 + "," + fnp3 + "," +
spcell[0] + "," + spcell[1] + "," + spcell[2] + ",'" + pcode + "',NULL,'" + newuseawayfork + "')");
mindex = ccf.GetMonitorIndex(fid, mti);
DbHelperSQL.ExecuteSql("INSERT INTO T_Monitor_Task (F_ManageTaskIndex, F_ManageTASKKINDINDEX, F_MonitorIndex, F_MonitorTaskLevel," +
" F_DeviceIndex, F_DeviceCommandIndex, F_RouteID, F_Status,F_NumParam1, F_NumParam2, F_NumParam3, F_NumParam4, F_NumParam5," +
" F_NumParam6, F_TxtParam, F_AheadDetect, F_UseAwayFork)VALUES " +
"(" + fid + "," + mti + "," + mindex + "," + lev + "," + device + ",5," + routeid + ",0," + fnp1 + "," + fnp2 + "," + fnp3 + "," +
spcell[0] + "," + spcell[1] + "," + spcell[2] + ",'" + pcode + "',NULL,'" + newuseawayfork + "')");
}
}
}