protected override void AnalysisRecvDataEx(string strCmdStr) { //报文格式F2 XX XX ... XX XX F3 //判断设备类型是否合法 DeviceType devType = CommandProcesserHelper.GetDevTypeByCmdInfo(StrUtils.CopySubStr(strCmdStr, 6, 2)); if (devType != DeviceType.LinkageCtrl) { return; } //根据命令字,解析对应命令 string strCmdWord = StrUtils.CopySubStr(strCmdStr, 14, 4); if (strCmdWord == AppConst.CMD_WORD_SEARCH_DEVIDES) { //判断报文长度 //取云电梯数量 int cloudElevatorCount = StrUtils.StrToIntDef(StrUtils.CopySubStr(strCmdStr, 64, 2), 0, 16); if (strCmdStr.Length < 70 + cloudElevatorCount * 10) //35 + cloudElevatorCount 字节 { HintProvider.ShowAutoCloseDialog(null, string.Format("报文长度错误,报文:{0}", strCmdStr)); return; } this.AnalysisSearchDevicesRecvData(strCmdStr); } else if (strCmdWord == AppConst.CMD_WORD_SET_CLOUD_ELEVATOR_PARAMS) { //判断报文长度 if (strCmdStr.Length < 24) //12字节 { HintProvider.ShowAutoCloseDialog(null, string.Format("报文长度错误,报文:{0}", strCmdStr)); return; } this.AnalysisDownParams(strCmdStr); } //this.UpdateHintInfo(strCmdStr); }
private void AnalysisRecvData(string strData) { //非忙碌状态,不解析数据 //if(!this.IsBusy) //{ // return; //} //去F0 string strCmdStr = CommandProcesserHelper.DelF0Escape(strData); //判断报文长度 if (strCmdStr.Length < 18) { RunLog.Log(string.Format("返回的报文长度错误,报文:{0}", strCmdStr)); HintProvider.ShowAutoCloseDialog(null, string.Format("返回的报文校验错误,错误:{0}", strCmdStr), HintIconType.Err); return; } //判断校验码 string requiredCheckValue = StrUtils.GetXORCheck(strCmdStr, 2, strCmdStr.Length - 6).ToUpper(); string factCheckValue = StrUtils.CopySubStr(strCmdStr, strCmdStr.Length - 4, 2); if (string.Compare(requiredCheckValue, factCheckValue, true) != 0) { RunLog.Log(string.Format("返回的报文校验错误,报文:{0}", strCmdStr)); HintProvider.ShowAutoCloseDialog(null, string.Format("返回的报文校验错误,错误:{0}", strCmdStr), HintIconType.Err); return; } //判断返回的命令状态 string strCmdStatus = StrUtils.CopySubStr(strCmdStr, 12, 2); //string strCmdStatus = StrUtils.CopySubStr(strCmdStr, 10, 2); if (StrUtils.HexStrToInt(strCmdStatus) != CommonUtils.RES_OK) { if (strCmdStatus == "7F") { string strCmdStatus2 = StrUtils.CopySubStr(strCmdStr, 18, 2); if (strCmdStatus2 == "02") { HintProvider.ShowAutoCloseDialog(null, string.Format("需要初始化设备,才能重新设置网络参数")); return; } } RunLog.Log(string.Format("命令状态错误:{0}", CommonUtils.GetErrMsgByCode(StrUtils.HexStrToInt(strCmdStatus)))); string Error = string.Format("命令状态错误:{0}", CommonUtils.GetErrMsgByCode(StrUtils.HexStrToInt(strCmdStatus))); HintProvider.ShowAutoCloseDialog(null, string.Format(Error), HintIconType.Err); return; } else if (StrUtils.HexStrToInt(strCmdStatus) == CommonUtils.RES_OK) { string strDevID = CommandProcesserHelper.GetDevIDByCmdInfo(StrUtils.CopySubStr(strCmdStr, 2, 4)).ToString(); if (IsDownParm || AppConst.IsDownParmCloudLinkage) { HintProvider.ShowAutoCloseDialog(null, string.Format("下载成功")); AppConst.IsDownParmCloudLinkage = false; IsDownParm = false; } } DeviceType devType = CommandProcesserHelper.GetDevTypeByCmdInfo(StrUtils.CopySubStr(strCmdStr, 6, 2)); if (devType == DeviceType.CloudLinkageInfoCtrl) { //云联动器 string strCmdStatusLink = StrUtils.CopySubStr(strCmdStr, 15, 4); if (strCmdStatusLink == "0121" || strCmdStatusLink == "012E" || strCmdStatusLink == "0100") { HintProvider.ShowAutoCloseDialog(null, "下载成功", HintIconType.OK); Thread.Sleep(1000); } } //重置 IsDownLoadDevLength = string.Empty; this.AnalysisRecvDataEx(strCmdStr); }