#include "PurifierClient.h" #include "S7Command.h" #include "../global.h" #include "../SystemInfo.h" #include "../PLC/SignalService.h" #include "../utils/DataByte.h" PurifierClient::PurifierClient(CommunicationCfg* pconfig) :S7Client(pconfig) { m_RunCfg = ConfigManager::GetInstance()->GetRunCfg(); m_ExtCfg = ConfigManager::GetInstance()->GetExtCfg(); m_AlarmCfgWrapper = ConfigManager::GetInstance()->GetAlarmCfg(); size_t ptrSize = sizeof(nullptr); //指针大小 void* startPtr = &m_Stat.m_startFlag + 1; size_t count = ((size_t)&m_Stat.m_endFlag - (size_t)startPtr) / ptrSize; InsertMp(startPtr, count); } PurifierClient::~PurifierClient() { Shutdown(); } void PurifierClient::InitCommand() { S7Command* pcommand = new S7Command(S7_COMMAND_READ_INFO, READ_ITEM_COUNT); TS7DataItem* items = pcommand->getDataItems(); int itemFlag = 0; items[itemFlag].Area = S7AreaMK; items[itemFlag].WordLen = S7WLByte; items[itemFlag].Start = 0; items[itemFlag].Amount = 6; items[itemFlag].pdata = new unsigned char[6]; //VD_中效过滤器压力实值 itemFlag = 1; items[itemFlag].Area = S7AreaDB; items[itemFlag].WordLen = S7WLByte; items[itemFlag].DBNumber = 1; items[itemFlag].Start = 0; items[itemFlag].Amount = 206; items[itemFlag].pdata = new unsigned char[206]; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcReadInfoXT; pcommand->isNeedDel = false; S7Command* pcommand2 = new S7Command(S7_COMMAND_READ_INFO, READ_ITEM_COUNT2); TS7DataItem* items2 = pcommand2->getDataItems(); //报警信息 itemFlag = 0; //报警信息 items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 389; items2[itemFlag].Amount = 2; items2[itemFlag].pdata = new unsigned char[2]; //最大风速 itemFlag = 1; items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 550; items2[itemFlag].Amount = 8; items2[itemFlag].pdata = new unsigned char[8]; itemFlag = 2; items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 594; items2[itemFlag].Amount = 1; items2[itemFlag].pdata = new unsigned char[1]; itemFlag = 3; items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 696; items2[itemFlag].Amount = 4; items2[itemFlag].pdata = new unsigned char[4]; itemFlag = 4; items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 812; items2[itemFlag].Amount = 4; items2[itemFlag].pdata = new unsigned char[4]; itemFlag = 5; items2[itemFlag].Area = S7AreaDB; items2[itemFlag].WordLen = S7WLByte; items2[itemFlag].DBNumber = 1; items2[itemFlag].Start = 846; items2[itemFlag].Amount = 4; items2[itemFlag].pdata = new unsigned char[4]; pcommand2->m_Ref = this; pcommand2->m_Fun = &PurifierClient::ProcReadInfoXT2; pcommand2->isNeedDel = false; //写测氧值 S7Command* oxygenPressureCom = new S7Command(S7_COMMAND_WRITE,2); TS7DataItem* dataItem = oxygenPressureCom->getDataItems(); dataItem[0].Area = S7AreaDB; dataItem[0].DBNumber = 1; dataItem[0].Start = 408; dataItem[0].WordLen = S7WLByte; dataItem[0].Amount = 4; unsigned char* poxygenfloat = new unsigned char[4]; S7FLOATDATA foxygendata; //EnterCriticalSection(&g_SystemInfo->m_InfoCs); foxygendata.fValue = (g_SystemInfo->m_ComPrintOxygen1 > g_SystemInfo->m_ComPrintOxygen2 ? g_SystemInfo->m_ComPrintOxygen1 : g_SystemInfo->m_ComPrintOxygen2); //LeaveCriticalSection(&g_SystemInfo->m_InfoCs); poxygenfloat[0] = foxygendata.data[3]; poxygenfloat[1] = foxygendata.data[2]; poxygenfloat[2] = foxygendata.data[1]; poxygenfloat[3] = foxygendata.data[0]; dataItem[0].pdata = poxygenfloat; m_OxygenWriteValue = (unsigned char*)dataItem[0].pdata; dataItem[1].Area = S7AreaDB; dataItem[1].DBNumber = 1; dataItem[1].Start = 20; dataItem[1].WordLen = S7WLByte; dataItem[1].Amount = 4; unsigned char* pfloat = new unsigned char[4]; S7FLOATDATA fPressure; EnterCriticalSection(&g_SystemInfo->m_InfoCs); fPressure.fValue = g_SystemInfo->m_EnvState.m_PrintPressureAnalog; LeaveCriticalSection(&g_SystemInfo->m_InfoCs); pfloat[0] = fPressure.data[3]; pfloat[1] = fPressure.data[2]; pfloat[2] = fPressure.data[1]; pfloat[3] = fPressure.data[0]; dataItem[1].pdata = pfloat; m_PressureWriteValue = (unsigned char*)dataItem[1].pdata; oxygenPressureCom->m_Ref = this; oxygenPressureCom->m_Fun = &PurifierClient::ProcWriteValueXT; oxygenPressureCom->isNeedDel = false; oxygenPressureCom->m_PreWrite = &PurifierClient::ProcSetOxygenValue; m_CycleCommands.push_back(pcommand); m_CycleCommands.push_back(pcommand2); m_CycleCommands.push_back(oxygenPressureCom); } void PurifierClient::ProcReadInfoXT(void *pobject, Command* pcommand) { S7Command* s7Command = (S7Command*)pcommand; TS7DataItem* pdataItems = s7Command->getDataItems(); int itemcount = s7Command->getItemCount(); if (pobject == NULL || itemcount != READ_ITEM_COUNT)return; PurifierClient* ppw = (PurifierClient*)pobject; TS7DataItem pCtrl = pdataItems[0]; TS7DataItem pPresure = pdataItems[1]; TS7DataItem pBoxClean = pdataItems[2]; TS7DataItem pWind = pdataItems[3]; TS7DataItem pFilterTime = pdataItems[4]; TS7DataItem pAlarm = pdataItems[5]; TS7DataItem pMaxWind = pdataItems[6]; TS7DataItem pCoverWindOffset = pdataItems[7]; EnterCriticalSection(&ppw->m_ValueCS); if (pCtrl.Result == 0) { unsigned char* arr = (unsigned char*)pCtrl.pdata; unsigned char mdata0 = arr[0]; unsigned char mdata1 = arr[1]; unsigned char mdata2 = arr[2]; unsigned char mdata3 = arr[3]; unsigned char mdata4 = arr[4]; unsigned char mdata5 = arr[5]; ppw->m_Stat.isPurifying->SetValue(((mdata5 & 0x1) > 0 ? true : false)); ppw->m_Stat.isDedusting->SetValue(((mdata0 & 0x4) ? true : false)); ppw->m_Stat.isBoxCleaning->SetValue(((mdata0 & 0x40) ? true : false)); ppw->m_Stat.isBlowBack->SetValue(((mdata1 & 0x2) ? true : false)); ppw->m_Stat.isFilterDiscarding->SetValue(((mdata1 & 0x10) ? true : false)); ppw->m_Stat.isFilterCleaning->SetValue(((mdata1 & 0x80) ? true : false)); ppw->m_Stat.isHopperCleaning->SetValue(((mdata2 & 0x20) ? true : false)); } if (pPresure.Result == 0) { unsigned char* pchar = (unsigned char*)pPresure.pdata; ppw->m_Stat.midPressureValue->SetValue(FLOATDATA(false, &pchar[0]).fValue); ppw->m_Stat.midPressureDifValue->SetValue(FLOATDATA(false, &pchar[4]).fValue); ppw->m_Stat.midTemperatureValue->SetValue(FLOATDATA(false, &pchar[8]).fValue); ppw->m_Stat.highPressureDifValue->SetValue(FLOATDATA(false, &pchar[12]).fValue); ppw->m_Stat.anemometerActualValue->SetValue(FLOATDATA(false, &pchar[16]).fValue); ppw->m_Stat.printPressureValue->SetValue(FLOATDATA(false, &pchar[20]).fValue); ppw->m_Stat.boxPressureUpLimit->SetValue(FLOATDATA(false, &pchar[28]).fValue); ppw->m_Stat.boxPressureDownLimit->SetValue(FLOATDATA(false, &pchar[32]).fValue); ppw->m_Stat.filterOxygenValue->SetValue(FLOATDATA(false, &pchar[48]).fValue); ppw->m_Stat.printOxygenValue->SetValue(FLOATDATA(false, &pchar[60]).fValue); ppw->m_Stat.midPressureDifAlarmValue->SetValue(FLOATDATA(false, &pchar[64]).fValue); ppw->m_Stat.highPressureDifAlarmValue->SetValue(FLOATDATA(false, &pchar[68]).fValue); ppw->m_Stat.printOxygenUpSetValue->SetValue(FLOATDATA(false, &pchar[76]).fValue); ppw->m_RunCfg->m_WarnOxygen = ppw->m_Stat.printOxygenUpSetValue->GetValue(); ppw->m_Stat.boxWashTime->SetValue(((pchar[110] & 0xff) << 8) + (pchar[111] & 0xff)); ppw->m_Stat.filterWashTime->SetValue(((pchar[112] & 0xff) << 8) + (pchar[113] & 0xff)); ppw->m_Stat.boxWashDelayTime->SetValue(((pchar[114] & 0xff) << 8) + (pchar[115] & 0xff)); ppw->m_Stat.dedustingWashDelayTime->SetValue(((pchar[116] & 0xff) << 8) + (pchar[117] & 0xff)); ppw->m_Stat.hopperCleanRemind->SetValue(((pchar[118] & 0xff) << 8) + (pchar[119] & 0xff)); ppw->m_Stat.printCleanOxygenSetValue->SetValue(FLOATDATA(false, &pchar[142]).fValue); ppw->m_Stat.windSetValue->SetValue(FLOATDATA(false, &pchar[146]).fValue); ppw->m_Stat.windActualValue->SetValue(FLOATDATA(false, &pchar[150]).fValue); ppw->m_Stat.filterCleanOxygenSetValue->SetValue(FLOATDATA(false, &pchar[158]).fValue); ppw->m_Stat.midTempHighSetValue->SetValue(FLOATDATA(false, &pchar[166]).fValue); ppw->m_Stat.midTempUltraSetValue->SetValue(FLOATDATA(false, &pchar[170]).fValue); ppw->m_Stat.oxygenAlarmValue->SetValue(FLOATDATA(false, &pchar[190]).fValue); //ppw->m_RunCfg->SetOxygenAlarmValue(ppw->m_Stat.oxygenAlarmValue); //ppw->m_RunCfg->SetOxygenTargeValue(ppw->m_Stat.printCleanOxygenSetValue); ppw->m_RunCfg->m_AlarmOxygen = ppw->m_Stat.oxygenAlarmValue->GetValue(); ppw->m_RunCfg->m_TargeOxygen = ppw->m_Stat.printCleanOxygenSetValue->GetValue() + 50; FanFit* al = ppw->m_ExtCfg->m_FanWindFit[ppw->m_ExtCfg->m_SelectedFanWindFit]; al->alarmWind = (ppw->m_Stat.windSetValue->GetValue() > 10.0f) ? (ppw->m_Stat.windSetValue->GetValue() - 10.0f) : 0.0f; ppw->m_Stat.filterTotalUseTime->SetValue(((pchar[194] & 0xff) << 8) + (pchar[195] & 0xff)); ppw->m_Stat.usedTimeFromlastBowBack->SetValue(((pchar[196] & 0xff) << 8) + (pchar[197] & 0xff)); ppw->m_Stat.bowBackTimes->SetValue(((pchar[198] & 0xff) << 8) + (pchar[199] & 0xff)); ppw->m_Stat.hopperTimeLastClean->SetValue(((pchar[204] & 0xff) << 8) + (pchar[205] & 0xff)); if (ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm) { if (ppw->m_Stat.filterOxygenValue->GetValue() > ppw->m_RunCfg->m_FilterOxygenAlarmValue) { if (ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm->m_AlarmContinueTick > ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm->m_CheckAlarmSetTick) { ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm->m_AlarmInfo = to_string(ppw->m_Stat.filterOxygenValue->GetValue()); SignalService::GetInstance().SetAlarm(ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm, true); } else { ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm->m_AlarmContinueTick++; } } else { ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm->m_AlarmContinueTick = 0; SignalService::GetInstance().SetAlarm(ppw->m_AlarmCfgWrapper->m_PurifierOxygenAlarm, false); } } } if (pAlarm.Result == 0) { unsigned char* arr = (unsigned char*)pAlarm.pdata; unsigned char pdata1 = arr[0]; unsigned char pdata2 = arr[1]; ppw->m_Stat.midTempOverLimitAlarm->SetValue(((pdata1 & 0x1) > 0 ? true : false)); ppw->m_Stat.midHighTempOverLimitAlarm->SetValue(((pdata1 & 0x2) > 0 ? true : false)); ppw->m_Stat.hopperUseLongTimeAlarm->SetValue(((pdata1 & 0x4) > 0 ? true : false)); ppw->m_Stat.highPressureLackValveAlarm->SetValue(((pdata1 & 0x8) > 0 ? true : false)); ppw->m_Stat.inverterPowerBreak->SetValue(((pdata1 & 0x10) > 0 ? true : false)); ppw->m_Stat.inverterAlarm->SetValue(((pdata1 & 0x20) > 0 ? true : false)); ppw->m_Stat.innerfilterOpenAlarm->SetValue(((pdata1 & 0x40) > 0 ? true : false)); ppw->m_Stat.inverterComException->SetValue(((pdata1 & 0x80) > 0 ? true : false)); ppw->m_Stat.cycleInValveOpenAlarm->SetValue(((pdata2 & 0x1) > 0 ? true : false)); ppw->m_Stat.cycleOutValueOpenAlarm->SetValue(((pdata2 & 0x2) > 0 ? true : false)); ppw->m_Stat.midHighValveOpenAlarm->SetValue(((pdata2 & 0x4) > 0 ? true : false)); ppw->m_Stat.innerFilterInValveException->SetValue(((pdata2 & 0x8) > 0 ? true : false)); ppw->m_Stat.midUnionValveException->SetValue(((pdata2 & 0x10) > 0 ? true : false)); ppw->m_Stat.innerFilterOutValveException->SetValue(((pdata2 & 0x20) > 0 ? true : false)); ppw->m_Stat.midFilterBlockAlarm->SetValue(((pdata2 & 0x40) > 0 ? true : false)); ppw->m_Stat.highFilterBlockAlarm->SetValue(((pdata2 & 0x80) > 0 ? true : false)); if (ppw->m_AlarmCfgWrapper->m_PurifierMidTempAlarm) SignalService::GetInstance().SetAlarm(ppw->m_AlarmCfgWrapper->m_PurifierMidTempAlarm, ppw->m_Stat.midTempOverLimitAlarm); /*ppw->m_Stat.d1Alarm = ((pdata2 & 0x1)>0?true:false); ppw->m_Stat.d2Alarm = ((pdata2 & 0x2)>0 ? true : false); ppw->m_Stat.d3Alarm = ((pdata2 & 0x4)>0 ? true : false); ppw->m_Stat.b1Alarm = ((pdata2 & 0x8)>0 ? true : false); ppw->m_Stat.b2Alarm = ((pdata2 & 0x10)>0 ? true : false); ppw->m_Stat.b3Alarm = ((pdata2 & 0x20)>0 ? true : false); ppw->m_Stat.midBlockAlarm = ((pdata2 & 0x40)>0 ? true : false); ppw->m_Stat.highBlockAlarm = ((pdata2 & 0x80)>0 ? true : false); ppw->m_Stat.midHighTempAlarm = ((pdata1 & 0x1)>0 ? true : false); ppw->m_Stat.midUtralHighTempAlarm = ((pdata1 & 0x2)>0 ? true : false); ppw->m_Stat.highHighTempAlarm = ((pdata1 & 0x4)>0 ? true : false); // ppw->m_Stat.highUtralHighTempAlarm = ((pdata1 & 0x8)>0 ? true : false); ppw->m_Stat.freqConvBreakerAlarm = ((pdata1 & 0x10)>0 ? true : false); ppw->m_Stat.fanAlarm = ((pdata1 & 0x20)>0 ? true : false);*/ } LeaveCriticalSection(&ppw->m_ValueCS); } void PurifierClient::ProcReadInfoXT2(void *pobject, Command* pcommand) { S7Command* s7Command = (S7Command*)pcommand; TS7DataItem* pdataItems = s7Command->getDataItems(); int itemcount = s7Command->getItemCount(); if (pobject == NULL || itemcount != READ_ITEM_COUNT2)return; PurifierClient* ppw = (PurifierClient*)pobject; TS7DataItem pAlarm = pdataItems[0]; TS7DataItem pMaxWind = pdataItems[1]; TS7DataItem pSignal = pdataItems[2]; TS7DataItem pType = pdataItems[3]; TS7DataItem pCoverWindOffset = pdataItems[4]; TS7DataItem pFreq = pdataItems[5]; EnterCriticalSection(&ppw->m_ValueCS); if (pAlarm.Result == 0) { unsigned char* arr = (unsigned char*)pAlarm.pdata; unsigned char pdata1 = arr[0]; unsigned char pdata2 = arr[1]; ppw->m_Stat.midTempOverLimitAlarm->SetValue(((pdata1 & 0x1) > 0 ? true : false)); ppw->m_Stat.midHighTempOverLimitAlarm->SetValue(((pdata1 & 0x2) > 0 ? true : false)); ppw->m_Stat.hopperUseLongTimeAlarm->SetValue(((pdata1 & 0x4) > 0 ? true : false)); ppw->m_Stat.highPressureLackValveAlarm->SetValue(((pdata1 & 0x8) > 0 ? true : false)); ppw->m_Stat.inverterPowerBreak->SetValue(((pdata1 & 0x10) > 0 ? true : false)); ppw->m_Stat.inverterAlarm->SetValue(((pdata1 & 0x20) > 0 ? true : false)); ppw->m_Stat.innerfilterOpenAlarm->SetValue(((pdata1 & 0x40) > 0 ? true : false)); ppw->m_Stat.inverterComException->SetValue(((pdata1 & 0x80) > 0 ? true : false)); ppw->m_Stat.cycleInValveOpenAlarm->SetValue(((pdata2 & 0x1) > 0 ? true : false)); ppw->m_Stat.cycleOutValueOpenAlarm->SetValue(((pdata2 & 0x2) > 0 ? true : false)); ppw->m_Stat.midHighValveOpenAlarm->SetValue(((pdata2 & 0x4) > 0 ? true : false)); ppw->m_Stat.innerFilterInValveException->SetValue(((pdata2 & 0x8) > 0 ? true : false)); ppw->m_Stat.midUnionValveException->SetValue(((pdata2 & 0x10) > 0 ? true : false)); ppw->m_Stat.innerFilterOutValveException->SetValue(((pdata2 & 0x20) > 0 ? true : false)); ppw->m_Stat.midFilterBlockAlarm->SetValue(((pdata2 & 0x40) > 0 ? true : false)); ppw->m_Stat.highFilterBlockAlarm->SetValue(((pdata2 & 0x80) > 0 ? true : false)); } if (pMaxWind.Result == 0) { unsigned char* pchar = (unsigned char*)pMaxWind.pdata; ppw->m_Stat.maxWindSetValue->SetValue(FLOATDATA(false, &pchar[0]).fValue); ppw->m_Stat.useArgon->SetValue((pchar[7] & 0x2) > 0 ? true : false); ppw->m_ExtCfg->m_SelectedFanWindFit = ppw->m_Stat.useArgon->GetValue() ? 1 : 0; ppw->m_Stat.isCoverWind->SetValue(((pchar[7] & 0x40) > 0 ? true : false)); } if (pSignal.Result == 0) { unsigned char* pchar = (unsigned char*)pSignal.pdata; ppw->m_Stat.coverWindSlowFinish->SetValue(((pchar[0] & 0x40) > 0 ? true : false)); ppw->m_Stat.coverWindResumeFinish->SetValue(((pchar[0] & 0x80) > 0 ? true : false)); } if (pType.Result == 0) { unsigned char* pchar = (unsigned char*)pType.pdata; ppw->m_Stat.purifierType->SetValue(((pchar[0] & 0xff) << 8) + (pchar[1] & 0xff)); ppw->m_Stat.keepAlive->SetValue(((pchar[2] & 0xff) << 8) + (pchar[3] & 0xff)); } if (pCoverWindOffset.Result == 0) { unsigned char* pchar = (unsigned char*)pCoverWindOffset.pdata; ppw->m_Stat.coverWindSpeedOffset->SetValue(FLOATDATA(false, &pchar[0]).fValue); } if (pFreq.Result == 0) { unsigned char* pchar = (unsigned char*)pFreq.pdata; ppw->m_Stat.fanFreq->SetValue(FLOATDATA(false, &pchar[0]).fValue); } LeaveCriticalSection(&ppw->m_ValueCS); } void PurifierClient::ProcWriteValueXT(void *pobject, Command* pcommand) { } void PurifierClient::ProcSetOxygenValue(void *pobject, Command* pcommand) { if (pobject == NULL)return; PurifierClient* ppw = (PurifierClient*)pobject; S7FLOATDATA fdata; S7FLOATDATA fpressuredata; EnterCriticalSection(&g_SystemInfo->m_InfoCs); fdata.fValue = (g_SystemInfo->m_ComPrintOxygen1>g_SystemInfo->m_ComPrintOxygen2? g_SystemInfo->m_ComPrintOxygen1: g_SystemInfo->m_ComPrintOxygen2); fpressuredata.fValue = g_SystemInfo->m_EnvState.m_PrintPressureAnalog; LeaveCriticalSection(&g_SystemInfo->m_InfoCs); ppw->m_OxygenWriteValue[0] = fdata.data[3]; ppw->m_OxygenWriteValue[1] = fdata.data[2]; ppw->m_OxygenWriteValue[2] = fdata.data[1]; ppw->m_OxygenWriteValue[3] = fdata.data[0]; ppw->m_PressureWriteValue[0] = fpressuredata.data[3]; ppw->m_PressureWriteValue[1] = fpressuredata.data[2]; ppw->m_PressureWriteValue[2] = fpressuredata.data[1]; ppw->m_PressureWriteValue[3] = fpressuredata.data[0]; } void PurifierClient::SetMKBit(int dindex, unsigned int waittime) { EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaMK; items[0].DBNumber = 1; items[0].Start = dindex; items[0].WordLen = S7WLBit; items[0].Amount = 1; bool* tempv = new bool[1]; tempv[0] = false; items[0].pdata = tempv; pcommand->m_Ref = this; pcommand->m_waitTime = waittime; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; S7Command* pcommand2 = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items2 = pcommand2->getDataItems(); items2[0].Area = S7AreaMK; items2[0].DBNumber = 1; items2[0].Start = dindex; items2[0].WordLen = S7WLBit; items2[0].Amount = 1; bool* tempv2 = new bool[1]; tempv2[0] = true; items2[0].pdata = tempv2; pcommand2->m_Ref = this; pcommand2->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand2); m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetDedust(bool bvalue) { if (g_isDebug) { m_Stat.isDedusting->SetValue(bvalue); } if (!IsServerConnected())return; if (bvalue)SetMKBit(10 * 8 + 0,500); else SetMKBit(10 * 8 + 1, 500); } void PurifierClient::SetBlowBack(bool bvalue) { if (!IsServerConnected())return; if (bvalue)SetMKBit(10 * 8 + 2, 500); else SetMKBit(10 * 8 + 3, 500); } void PurifierClient::SetFilterDiscard(bool bvalue) { if (!IsServerConnected())return; if (bvalue)SetMKBit(10 * 8 + 4, 500); else SetMKBit(10 * 8 + 5, 500); } void PurifierClient::SetBoxClean(bool bvalue) { if (!IsServerConnected())return; if (bvalue)SetMKBit(4, 500); else SetMKBit(5, 500); } void PurifierClient::SetFilterClean(bool bvalue) { if (!IsServerConnected())return; if (bvalue)SetMKBit(10 * 8 + 6, 500); else SetMKBit(10 * 8 + 7, 500); } void PurifierClient::SetHopperClean(bool bvalue) { if (!IsServerConnected())return; if (bvalue)SetMKBit(11 * 8 + 0, 500); else SetMKBit(11 * 8 + 1, 500); } void PurifierClient::SetPurify(bool bvalue) { if (g_isDebug) { m_Stat.isPurifying->SetValue(bvalue); } if (!IsServerConnected())return; if (bvalue)SetMKBit(4 * 8 + 6, 3000); else SetMKBit(4 * 8 + 7, 3000); } void PurifierClient::ResetFilterTime() { if (!IsServerConnected())return; SetMKBit(4 * 8 , 500); } void PurifierClient::ClearHopperAlarm() { if (!IsServerConnected())return; SetMKBit(2 * 8, 500); } void PurifierClient::SetDBFloat(int dindex, float fvalue) { EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = dindex; items[0].WordLen = S7WLByte; items[0].Amount = 4; unsigned char* pfloat = new unsigned char[4]; S7FLOATDATA fdata; fdata.fValue = fvalue; pfloat[0] = fdata.data[3]; pfloat[1] = fdata.data[2]; pfloat[2] = fdata.data[1]; pfloat[3] = fdata.data[0]; items[0].pdata = pfloat; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetBit(int dindex, bool v) { EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = dindex; items[0].WordLen = S7WLBit; items[0].Amount = 1; bool* tempv = new bool[1]; tempv[0] = v; items[0].pdata = tempv; pcommand->m_Ref = this; pcommand->m_waitTime = 0; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetBoxPressureUpLimit(float fvalue) { if (!IsServerConnected())return; SetDBFloat(28, fvalue); } void PurifierClient::SetBoxPressureDownLimit(float fvalue) { if (!IsServerConnected())return; SetDBFloat(32, fvalue); } void PurifierClient::SetMidPressureDifAlarmValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(64, fvalue); } void PurifierClient::SetHighPressureDifAlarmValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(68, fvalue); } void PurifierClient::SetPrintCleanOxygenSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(142, fvalue); } void PurifierClient::SetWindValue(float fvalue) { if (g_isDebug)m_Stat.windActualValue->SetValue(fvalue); if (!IsServerConnected())return; SetDBFloat(146, fvalue); } void PurifierClient::SetPrintOxygenDownSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(154, fvalue); } void PurifierClient::SetPrintOxygenUpSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(76, fvalue); } void PurifierClient::SetfilterCleanOxygenSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(158, fvalue); } void PurifierClient::SetMidTempHighSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(166, fvalue); } void PurifierClient::SetMidTempUltraSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(170, fvalue); } void PurifierClient::SetHighTempHighSetValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(174, fvalue); } void PurifierClient::SetMaxWindValue(float fvalue) { if (!IsServerConnected())return; SetDBFloat(550, fvalue); } /*void PurifierClient::SetHighTempUltraSetValue(float fvalue) { SetDBFloat(178, fvalue); }*/ void PurifierClient::SetHopperCleanRemind(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 118; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata= new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetBoxWashDelayTime(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 114; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetDedustingWashDelayTime(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 116; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::GetStat(Purifierstat_XT& stat) { EnterCriticalSection(&m_ValueCS); //memcpy_s(&stat, sizeof(Purifierstat_XT), &m_Stat, sizeof(Purifierstat_XT)); stat.isPurifying = m_Stat.isPurifying->GetValue(); stat.isDedusting = m_Stat.isDedusting->GetValue(); stat.isBoxCleaning = m_Stat.isBoxCleaning->GetValue(); stat.isBlowBack = m_Stat.isBlowBack->GetValue(); stat.isFilterDiscarding = m_Stat.isFilterDiscarding->GetValue(); stat.isFilterCleaning = m_Stat.isFilterCleaning->GetValue(); stat.isHopperCleaning = m_Stat.isHopperCleaning->GetValue(); stat.midPressureValue = m_Stat.midPressureValue->GetValue(); stat.midPressureDifValue = m_Stat.midPressureDifValue->GetValue(); stat.midTemperatureValue = m_Stat.midTemperatureValue->GetValue(); stat.highPressureDifValue = m_Stat.highPressureDifValue->GetValue(); stat.anemometerActualValue = m_Stat.anemometerActualValue->GetValue(); stat.printPressureValue = m_Stat.printPressureValue->GetValue(); stat.boxPressureUpLimit = m_Stat.boxPressureUpLimit->GetValue(); stat.boxPressureDownLimit = m_Stat.boxPressureDownLimit->GetValue(); stat.filterOxygenValue = m_Stat.filterOxygenValue->GetValue(); stat.printOxygenValue = m_Stat.printOxygenValue->GetValue(); stat.midPressureDifAlarmValue = m_Stat.midPressureDifAlarmValue->GetValue(); stat.highPressureDifAlarmValue = m_Stat.highPressureDifAlarmValue->GetValue(); stat.filterTotalUseTime = m_Stat.filterTotalUseTime->GetValue(); stat.usedTimeFromlastBowBack = m_Stat.usedTimeFromlastBowBack->GetValue(); stat.bowBackTimes = m_Stat.bowBackTimes->GetValue(); stat.hopperTimeLastClean = m_Stat.hopperTimeLastClean->GetValue(); stat.boxWashTime = m_Stat.boxWashTime->GetValue(); stat.filterWashTime = m_Stat.filterWashTime->GetValue(); stat.boxWashDelayTime = m_Stat.boxWashDelayTime->GetValue(); stat.dedustingWashDelayTime = m_Stat.dedustingWashDelayTime->GetValue(); stat.hopperCleanRemind = m_Stat.hopperCleanRemind->GetValue(); stat.printCleanOxygenSetValue = m_Stat.printCleanOxygenSetValue->GetValue(); stat.windSetValue = m_Stat.windSetValue->GetValue(); stat.windActualValue = m_Stat.windActualValue->GetValue(); stat.maxWindSetValue = m_Stat.maxWindSetValue->GetValue(); stat.useArgon = m_Stat.useArgon->GetValue(); stat.printOxygenUpSetValue = m_Stat.printOxygenUpSetValue->GetValue(); stat.oxygenAlarmValue = m_Stat.oxygenAlarmValue->GetValue(); stat.filterCleanOxygenSetValue = m_Stat.filterCleanOxygenSetValue->GetValue(); stat.midTempHighSetValue = m_Stat.midTempHighSetValue->GetValue(); stat.midTempUltraSetValue = m_Stat.midTempUltraSetValue->GetValue(); stat.pressureRangeUpLimit = m_Stat.pressureRangeUpLimit->GetValue(); stat.pressureRangeDownLimit = m_Stat.pressureRangeDownLimit->GetValue(); stat.fanFreq = m_Stat.fanFreq->GetValue(); stat.midTempOverLimitAlarm = m_Stat.midTempOverLimitAlarm->GetValue(); stat.midHighTempOverLimitAlarm = m_Stat.midHighTempOverLimitAlarm->GetValue(); stat.hopperUseLongTimeAlarm = m_Stat.hopperUseLongTimeAlarm->GetValue(); stat.highPressureLackValveAlarm = m_Stat.highPressureLackValveAlarm->GetValue(); stat.protectionTestFail = m_Stat.protectionTestFail->GetValue(); stat.inverterPowerBreak = m_Stat.inverterPowerBreak->GetValue(); stat.inverterAlarm = m_Stat.inverterAlarm->GetValue(); stat.whirlwindJarIsFull = m_Stat.whirlwindJarIsFull->GetValue(); stat.midInValveOpenAlarm = m_Stat.midInValveOpenAlarm->GetValue(); stat.midOutValveOpenAlarm = m_Stat.midOutValveOpenAlarm->GetValue(); stat.anemometerException = m_Stat.anemometerException->GetValue(); stat.oxygenSelfTestFail = m_Stat.oxygenSelfTestFail->GetValue(); stat.innerfilterOpenAlarm = m_Stat.innerfilterOpenAlarm->GetValue(); stat.inverterComException = m_Stat.inverterComException->GetValue(); stat.purifierSevereAbnormalExhaust = m_Stat.purifierSevereAbnormalExhaust->GetValue(); stat.cycleInValveOpenAlarm = m_Stat.cycleInValveOpenAlarm->GetValue(); stat.cycleOutValueOpenAlarm = m_Stat.cycleOutValueOpenAlarm->GetValue(); stat.midHighValveOpenAlarm = m_Stat.midHighValveOpenAlarm->GetValue(); stat.innerFilterInValveException = m_Stat.innerFilterInValveException->GetValue(); stat.midUnionValveException = m_Stat.midUnionValveException->GetValue(); stat.innerFilterOutValveException = m_Stat.innerFilterOutValveException->GetValue(); stat.midFilterBlockAlarm = m_Stat.midFilterBlockAlarm->GetValue(); stat.highFilterBlockAlarm = m_Stat.highFilterBlockAlarm->GetValue(); stat.highPressureLackAlarm = m_Stat.highPressureLackAlarm->GetValue(); stat.protectedPressureLackAlarm = m_Stat.protectedPressureLackAlarm->GetValue(); stat.midConnectException = m_Stat.midConnectException->GetValue(); stat.carbinDoorOpenException = m_Stat.carbinDoorOpenException->GetValue(); stat.busOutValveNotOpenAlarm = m_Stat.busOutValveNotOpenAlarm->GetValue(); stat.busOutValveNotCloseAlarm = m_Stat.busOutValveNotCloseAlarm->GetValue(); stat.busOutValveNotInPosAlarm = m_Stat.busOutValveNotInPosAlarm->GetValue(); stat.printOutValveNotOpenAlarm = m_Stat.printOutValveNotOpenAlarm->GetValue(); stat.printOutValveNotCloseAlarm = m_Stat.printOutValveNotCloseAlarm->GetValue(); stat.printOutValveNotInPosAlarm = m_Stat.printOutValveNotInPosAlarm->GetValue(); stat.inverterDonotWorkWhenDedust = m_Stat.inverterDonotWorkWhenDedust->GetValue(); stat.printOxygenExceptWhenDedust = m_Stat.printOxygenExceptWhenDedust->GetValue(); stat.tempExceptWhenDedust = m_Stat.tempExceptWhenDedust->GetValue(); stat.highPressureExceptWhenDedust = m_Stat.highPressureExceptWhenDedust->GetValue(); stat.windExceptWhenDedust = m_Stat.windExceptWhenDedust->GetValue(); stat.coverWindSpeedOffset = m_Stat.coverWindSpeedOffset->GetValue(); stat.isCoverWind = m_Stat.isCoverWind->GetValue(); stat.shieldMonitorPrintPressure = m_Stat.shieldMonitorPrintPressure->GetValue(); stat.coverWindSlowFinish = m_Stat.coverWindSlowFinish->GetValue(); stat.coverWindResumeFinish = m_Stat.coverWindResumeFinish->GetValue(); stat.purifierType = m_Stat.purifierType->GetValue(); stat.keepAlive = m_Stat.keepAlive->GetValue(); stat.protectionPressureEnable = m_Stat.protectionPressureEnable->GetValue(); stat.ProtectionPressureTestRelFail = m_Stat.ProtectionPressureTestRelFail->GetValue(); stat.oxygenSelfTestRelFail = m_Stat.oxygenSelfTestRelFail->GetValue(); stat.ProtectionPressuring = m_Stat.ProtectionPressuring->GetValue(); stat.ProtectionPressureSetTime = m_Stat.ProtectionPressureSetTime->GetValue(); stat.blowBackSetTimes = m_Stat.blowBackSetTimes->GetValue(); stat.blowBackBlowTime = m_Stat.blowBackBlowTime->GetValue(); memcpy_s(&stat.baseStat, sizeof(BaseStat), &m_BaseStat, sizeof(BaseStat)); LeaveCriticalSection(&m_ValueCS); } void PurifierClient::SetPressureRangeUpLimit(float value) { if (!IsServerConnected())return; SetDBFloat(182, value); } void PurifierClient::SetPressureRangeDownLimit(float value) { if (!IsServerConnected())return; SetDBFloat(186, value); } void PurifierClient::SetOxygenAlarmValue(float value) { if (!IsServerConnected())return; SetDBFloat(190, value); } void PurifierClient::SetUseArgon(bool buse) { if (!IsServerConnected())return; SetBit(557 * 8 + 1, buse); } void PurifierClient::SetCoverWind(bool bvalue) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 557 * 8 + 6; items[0].WordLen = S7WLBit; items[0].Amount = 1; bool* tempv = new bool[1]; tempv[0] = bvalue; items[0].pdata = tempv; pcommand->m_Ref = this; pcommand->m_waitTime = 0; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetCoverWindOffset(float offset) { if (!IsServerConnected())return; SetDBFloat(812, offset); } void PurifierClient::SetShieldMonitorPrintPressure(bool bvalue) { if (g_isDebug)m_Stat.shieldMonitorPrintPressure->SetValue(bvalue); if (!IsServerConnected())return; SetBit(557 * 8, bvalue); } void PurifierClient::SetWindSlowFinishSignal(bool bvalue) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 594 * 8 + 6; items[0].WordLen = S7WLBit; items[0].Amount = 1; bool* tempv = new bool[1]; tempv[0] = bvalue; items[0].pdata = tempv; pcommand->m_Ref = this; pcommand->m_waitTime = 0; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetWindResumeFinishSignal(bool bvalue) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 594 * 8 + 7; items[0].WordLen = S7WLBit; items[0].Amount = 1; bool* tempv = new bool[1]; tempv[0] = bvalue; items[0].pdata = tempv; pcommand->m_Ref = this; pcommand->m_waitTime = 0; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetBlowBackBlowTime(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 430; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetBlowBackSetTimes(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 434; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetProtectionPressureSetTime(unsigned short value) { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 658; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = (unsigned char)(value >> 8); pdata[1] = (unsigned char)value; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } void PurifierClient::SetUnLock() { if (!IsServerConnected())return; EnterCriticalSection(&m_RtcCS); S7Command* pcommand = new S7Command(S7_COMMAND_WRITE, 1); TS7DataItem* items = pcommand->getDataItems(); items[0].Area = S7AreaDB; items[0].DBNumber = 1; items[0].Start = 660; items[0].WordLen = S7WLByte; items[0].Amount = 2; unsigned char* pdata = new unsigned char[2]; pdata[0] = 0; pdata[1] = 0; items[0].pdata = pdata; pcommand->m_Ref = this; pcommand->m_Fun = &PurifierClient::ProcWriteValueXT; m_RTCommands.push(pcommand); LeaveCriticalSection(&m_RtcCS); } //void PurifierClient::SetParamByKey(const ReadData& rd) { // if (rd.nameKey == "SetDedust") { // SetDedust((bool)atoi(rd.strValue.c_str())); // } // else if (rd.nameKey == "SetBlowBack") { // SetBlowBack((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetFilterDiscard") { // SetFilterDiscard((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetFilterClean") { // SetFilterClean((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetHopperClean") { // SetHopperClean((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetPurify") { // SetPurify((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetBoxClean") { // SetBoxClean((bool)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "ResetFilterTime") { // ResetFilterTime(); // } // else if (rd.nameKey == "ClearHopperAlarm") { // ClearHopperAlarm(); // } // // else if (rd.nameKey == "SetBoxPressureUpLimit") { // SetBoxPressureUpLimit((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetBoxPressureDownLimit") { // SetBoxPressureDownLimit((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetMidPressureDifAlarmValue") { // SetMidPressureDifAlarmValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetHighPressureDifAlarmValue") { // SetHighPressureDifAlarmValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetPrintCleanOxygenSetValue") { // SetPrintCleanOxygenSetValue((float)atof(rd.strValue.data())); // } // // else if (rd.nameKey == "SetWindValue") { // SetWindValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetMaxWindValue") { // SetMaxWindValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetPrintOxygenDownSetValue") { // SetPrintOxygenDownSetValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetPrintOxygenUpSetValue") { // SetPrintOxygenUpSetValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetfilterCleanOxygenSetValue") { // SetfilterCleanOxygenSetValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetMidTempHighSetValue") { // SetMidTempHighSetValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetMidTempUltraSetValue") { // SetMidTempUltraSetValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetHighTempHighSetValue") { // SetHighTempHighSetValue((float)atof(rd.strValue.data())); // } // // else if (rd.nameKey == "SetHopperCleanRemind") { // SetHopperCleanRemind((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetBoxWashDelayTime") { // SetBoxWashDelayTime((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetDedustingWashDelayTime") { // SetDedustingWashDelayTime((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetPressureRangeUpLimit") { // SetPressureRangeUpLimit((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetPressureRangeDownLimit") { // SetPressureRangeDownLimit((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetOxygenAlarmValue") { // SetOxygenAlarmValue((float)atof(rd.strValue.data())); // } // else if (rd.nameKey == "SetUseArgon") { // SetUseArgon((bool)atoi(rd.strValue.data())); // } // // else if (rd.nameKey == "SetBlowBackBlowTime") { // SetBlowBackBlowTime((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetBlowBackSetTimes") { // SetBlowBackSetTimes((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetProtectionPressureSetTime") { // SetProtectionPressureSetTime((unsigned short)atoi(rd.strValue.data())); // } // else if (rd.nameKey == "SetUnLock") { // SetUnLock(); // } // else { // printf("%s key do not exist...", rd.nameKey.data()); // } // // //}