KeySlave485.c 36 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133
  1. #include "KeySlave485.h"
  2. #include "CollectMaster485.h"
  3. #include "TerminalSlave485.h"
  4. #include "usart.h"
  5. #include "cmsis_os.h"
  6. #include "spi.h"
  7. #include "Elec_Seal.h"
  8. #include "Dwin.h"
  9. #include <stdio.h>
  10. #include <string.h>
  11. #include "FreeRTOS.h"
  12. #include "task.h"
  13. #include "Data_deal.h"
  14. //#include <absacc.h>
  15. #define __noinit__ __attribute__((zero_init))
  16. #define Max_QingJiao_Print ((float)5.01) //倾角限制,超过该倾角则不允许打印
  17. //////////////////////////////////////////////////////////////////////////////////
  18. /*********此处关于设置参数以及参数设置后赋值处理,后续有更合适的方法时配置代码不应在按键串口里(如在终端里配置)**************/
  19. /*******************油品设置界面BEGIN***********************/
  20. #define Set_92_Oil_Id 40
  21. #define Set_95_Oil_Id 41
  22. #define Set_97_Oil_Id 42
  23. #define Set_98_Oil_Id 43
  24. #define Set_Diesel_Oil_Id 44
  25. #define Set_Other_Oil_Id 45
  26. /*******************油品设置界面END***********************/
  27. #define Calibration_ID 0x81
  28. Config_INFO_TypeDef Config_info_all;
  29. uint8_t Baseval_ID = 1; //采集板ID号
  30. uint8_t Set_CollectPara_Flag = 0;
  31. uint8_t com_name[20] = "Hangzhou jialong"; //公司名称
  32. uint8_t Version_hardware[32] = "V2.0.0 STM32F746VGT6"; //硬件版本
  33. uint8_t product_code[20] = "JL-SIMS-CJ-V2.1"; //产品代码
  34. uint8_t product_ID[20] = "20210730001"; //产品ID
  35. char Version_software[30] = "KZB09A0_20220210_Temp1";
  36. uint32_t Version_Soft[8] = {2,2,3,13,1,1,0,20221025};
  37. uint8_t flag_exitReset = 0; //终止复位命令
  38. uint8_t flag_Uart4_Busy = 0; //表明打印机占用了总线,暂停语音播报
  39. uint8_t flag_Sw_VoicePlay = 1; //表明默认上电时启用语音播报
  40. uint8_t flag_ShowValveRaw = 0; //默认显示打开、关闭、异常等汉字信息
  41. uint8_t flag_Sw_DisplaySensorData = 1; //默认不显示模拟量类传感器信息数据
  42. uint8_t flag_En_BlankSeal = 0; //0表明默认上电禁止空仓施封 1=允许空仓施封
  43. uint8_t flag_Sw_DispSysInfo = 1; //表明默认上电显示系统信息否 1=显示 0=不显示
  44. /******************************************END**********************************************************************/
  45. uint8_t flag_Seal_Break; //破封蜂鸣器报警标志
  46. uint16_t Sleep_Timer_cnt3 = 0; //小屏10分钟没有操作息屏处理标志
  47. uint16_t PrintCnt __attribute__((at(0X20000000))); // =99;// __attribute__((at(0x20000000))); //__attribute__((at(0x1000A000)));//打印流水号
  48. uint16_t tmrForPrinter = 0; //打印机定时——避免死机重启(因为打印机启动瞬间电流非常大,24V供电可达0.7A以上)。一定时间内内只能打印一次
  49. uint32_t tmrForKeyPad = 0; //按键定时器,判断一定时间内是否有按键操作。如果有则强制屏幕进行唤醒
  50. uint32_t tmrForRemoteCali; //远程标定定时器 如果有远程标定命令则封闭一段时间不发送轮训传感器的数据
  51. uint32_t tmrForTemp_ManualInput = 0; //手工输入温度之后开启定时器
  52. float ManualSign = 1.0f; //默认的手工输入温度的符号位。
  53. int16_t input_Arr[5]; //获取用户的按键输入温度
  54. uint32_t input_ArrFunDebugCode[5]; //用于输入功能码----5位功能码,主要用于在屏幕上打印调试信息 9开头,剩下4位为数字
  55. uint32_t FunDebugCode = 0;
  56. //该参数修正液位高度,使得液位高度与真实的量油尺量出的高度一致
  57. int16_t OffsetYewei[8]; //offsetLeiDa004;//修正零点,可以通过按键口进行标定。
  58. //根据罐容反推的液位高度修正误差,可以通过按键口进行标定。
  59. //该参数修正容量(罐容)系统误差,使得计算的罐容与实际发油量或者卸油量一致
  60. //当液位高度超过50mm之后,强制加上此偏移
  61. int16_t OffsetTankCapacity[8]; //1仓罐容零点,两字节定时发给采集器
  62. float ExpansionRatio[8] = {0.0008, 0.0008, 0.0008, 0.0008, 0.0008, 0.0008, 0.0008, 0.0008}; //膨胀比
  63. float Vt_Disp[8], V20_Disp[8]; //[8]
  64. float Tempe_For_V20[8] = {20, 20, 20, 20, 20, 20, 20, 20}; //,V20_Disp[8];//[8]
  65. float Vt_Local[8] = {40000.1, 40000.1, 40000.1, 40000.1, 40000.1, 40000.1, 40000.1, 40000.1};
  66. uint8_t Auto_sealedOK_ID_bak;
  67. float V20_Seal[8],Vt_Seal[8],Ht_Seal[8];
  68. float V20_Break[8],Vt_Break[8],Ht_Break[8];
  69. uint32_t data_Src_To_Disp = 0; //待显示数据源----0-来自采集器,1-来自平台下发
  70. float Vt_Local_Disp, V20_Local_Disp;
  71. float V20_Local[8] = {40005.99, 40005.99, 40005.99, 40005.99, 40005.99, 40005.99, 40005.99, 40005.99}; //控制器计算的结果或者采集器传来的结果
  72. char PrintBuff[64]; //打印机缓存
  73. int LenOfPrint = 0; //打印的字符数
  74. uint8_t dbgArray[8]; //调试状态下是否执行某些命令
  75. //李伟修改 湖南润安项目 新增传感器与报警信息
  76. float AlarmOfTempeThreshold_Upper,AlarmOfTempeThreshold_Lower;
  77. float AlarmOfPressureThreshold_Upper,AlarmOfPressureThreshold_Lower;
  78. float AlarmArrayData[11];
  79. float BiasOfTempe;//温度修正
  80. float PressureWindowsSpan;//压力窗口时长
  81. float PressurePositiveThreshold;//压力正偏门限
  82. float PressureNegativeThreshold;//压力负偏门限
  83. float BiasOfPressure;//压力修正
  84. uint32_t AlgType;//算法类型配置
  85. uint32_t usart_timeout=0,usart_timesec=0;
  86. /*
  87. #define PRINTER_TYPE 0x00
  88. //创鑫公司起始符为 1b 64 01,结束符为1b 64 00;
  89. 济南HOE公司为
  90. //HOE9200-2 打印机分两种模式
  91. 1、无协议,发什么打印什么
  92. 2、带起始字符和结束字符:起始 0355 ;结束 03AA。
  93. */
  94. //默认打印机型号为创鑫公司=0x00;0x01=济南HOE公司;二者通信命令不同,仅在于起始符号与结束符
  95. uint8_t PrinterType = 0x00; //该参数可以通过平台或者串口进行配置
  96. void PrintInfo(void)
  97. {
  98. int i000 = 0;
  99. //20210103打印机打印程序---走纸顺序是反的,所以开始和结束是反的
  100. //HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  101. //HAL_Delay(200);
  102. if (1 == 0) //倾角太大则不打印,直接报警退出
  103. {
  104. if (uni_QingJiao001.flo_Data > Max_QingJiao_Print)
  105. {
  106. for (i000 = 0; i000 < 20; i000++)
  107. {
  108. //HAL_GPIO_TogglePin(GPIOE, BEEP_Pin);
  109. //HAL_Delay(50);
  110. osDelay(50);
  111. //HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  112. }
  113. HAL_GPIO_WritePin(GPIOE, BEEP_Pin, GPIO_PIN_SET);
  114. //return;
  115. }
  116. }
  117. //HAL_Delay(10);
  118. osDelay(10);
  119. KeySlave485_Send_Data((uint8_t *)PrintBuff, 3);
  120. memset(PrintBuff, 0, sizeof(PrintBuff));
  121. if (PrinterType == 0x00)
  122. {
  123. // PrintBuff[0]=0x03;//禁止打印,济南公司
  124. // PrintBuff[1]=0xaa;
  125. // KeySlave485_Send_Data((uint8_t *)PrintBuff,2);
  126. memset(PrintBuff, 0, sizeof(PrintBuff));
  127. HAL_Delay(30);
  128. PrintBuff[0] = 0x1b; //允许打印命令 1b 64 01 创鑫公司
  129. PrintBuff[1] = 0x64;
  130. PrintBuff[2] = 0x01;
  131. KeySlave485_Send_Data((uint8_t *)PrintBuff, 3);
  132. }
  133. else
  134. { //济南打印机HOE公司
  135. PrintBuff[0] = 0x1b; //禁止打印,创鑫公司
  136. PrintBuff[1] = 0x64;
  137. PrintBuff[2] = 0x00;
  138. KeySlave485_Send_Data((uint8_t *)PrintBuff, 3);
  139. memset(PrintBuff, 0, sizeof(PrintBuff));
  140. HAL_Delay(30);
  141. PrintBuff[0] = 0x03; //允许打印命令 1b 64 01 济南公司
  142. PrintBuff[1] = 0x55;
  143. KeySlave485_Send_Data((uint8_t *)PrintBuff, 2);
  144. }
  145. //HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  146. //HAL_Delay(20);
  147. memset(PrintBuff, 0, sizeof(PrintBuff));
  148. LenOfPrint = sprintf(PrintBuff, "-----------%s 结束\r\n", "########");
  149. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  150. memset(PrintBuff, 0, sizeof(PrintBuff));
  151. LenOfPrint = sprintf(PrintBuff, "罐车牌号:%s \r\n", CarLicensePlate);
  152. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  153. memset(PrintBuff, 0, sizeof(PrintBuff));
  154. LenOfPrint = sprintf(PrintBuff, "罐车仓数:%d \r\n", StoreNumber);
  155. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  156. memset(PrintBuff, 0, sizeof(PrintBuff));
  157. for (i000 = 0; i000 < StoreNumber; i000++)
  158. {
  159. LenOfPrint = sprintf(PrintBuff, "Vt:%6.2f. V20: %6.2f.\r\n", Vt_Local[i000], V20_Local[i000]);
  160. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  161. memset(PrintBuff, 0, sizeof(PrintBuff));
  162. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  163. // HAL_Delay(20);
  164. }
  165. #if (PrintDateTime)
  166. //打印年月日时分秒 打印时间 打印当前时间
  167. LenOfPrint = sprintf(PrintBuff, "时间:%04x-%02x-%02x.%02x:%02x:%02x .\r\n",
  168. pT2C_SetupData->year, pT2C_SetupData->month, pT2C_SetupData->day,
  169. pT2C_SetupData->hour, pT2C_SetupData->minute, pT2C_SetupData->second);
  170. #endif
  171. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  172. memset(PrintBuff, 0, sizeof(PrintBuff));
  173. LenOfPrint = sprintf(PrintBuff, "倾角x:%3.2f;倾角y:%3.2f;\r\n", Stor[0].QingJiaoFlo, Stor[1].QingJiaoFlo);
  174. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  175. memset(PrintBuff, 0, sizeof(PrintBuff));
  176. HAL_Delay(20);
  177. LenOfPrint = sprintf(PrintBuff, "温度:%3.2f.液位:%3.2f \r\n", uni_temper001.flo_Data, uni_LiqLev001.flo_Data);
  178. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  179. memset(PrintBuff, 0, sizeof(PrintBuff));
  180. //打印液位波动数据
  181. //?△▽▲▼
  182. LenOfPrint = sprintf(PrintBuff, "最高:%4.2f;最低:%4.2f;\r\n", Yewei_max000, Yewei_min000);
  183. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  184. memset(PrintBuff, 0, sizeof(PrintBuff));
  185. LenOfPrint = sprintf(PrintBuff, "差值△:%4.2f mm\r\n", Yewei_peak000);
  186. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  187. memset(PrintBuff, 0, sizeof(PrintBuff));
  188. //HAL_Delay(10);
  189. //HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  190. if (Stor[0].xyf_state)
  191. {
  192. LenOfPrint = sprintf(PrintBuff, "卸油阀1:打开. \r\n");
  193. }
  194. else
  195. {
  196. LenOfPrint = sprintf(PrintBuff, "卸油阀1:关闭. \r\n");
  197. }
  198. HAL_Delay(20);
  199. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  200. memset(PrintBuff, 0, sizeof(PrintBuff));
  201. if (Stor[1].xyf_state)
  202. {
  203. LenOfPrint = sprintf(PrintBuff, "卸油阀2:打开. \r\n");
  204. }
  205. else
  206. {
  207. LenOfPrint = sprintf(PrintBuff, "卸油阀2:关闭. \r\n");
  208. }
  209. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  210. memset(PrintBuff, 0, sizeof(PrintBuff));
  211. if (Stor[2].xyf_state)
  212. {
  213. LenOfPrint = sprintf(PrintBuff, "卸油阀3:打开. \r\n");
  214. }
  215. else
  216. {
  217. LenOfPrint = sprintf(PrintBuff, "卸油阀3:关闭. \r\n");
  218. }
  219. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  220. memset(PrintBuff, 0, sizeof(PrintBuff));
  221. if (Stor[0].hdf_state)
  222. {
  223. LenOfPrint = sprintf(PrintBuff, "海底阀1:打开. \r\n");
  224. }
  225. else
  226. {
  227. LenOfPrint = sprintf(PrintBuff, "海底阀1:关闭. \r\n");
  228. }
  229. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  230. memset(PrintBuff, 0, sizeof(PrintBuff));
  231. LenOfPrint = sprintf(PrintBuff, "流水号 :%5d \r\n", PrintCnt);
  232. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  233. memset(PrintBuff, 0, sizeof(PrintBuff));
  234. HAL_Delay(10);
  235. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  236. LenOfPrint = sprintf(PrintBuff, "开始_____________\r\n");
  237. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  238. memset(PrintBuff, 0, sizeof(PrintBuff));
  239. ///*
  240. // DateDwin[0]=USART3_RX_BUF[7];//年月日
  241. // DateDwin[1]=USART3_RX_BUF[8];
  242. // DateDwin[2]=USART3_RX_BUF[9];
  243. // DateDwin[3]=USART3_RX_BUF[10];//星期
  244. // DateDwin[4]=USART3_RX_BUF[11];//时分秒
  245. // DateDwin[5]=USART3_RX_BUF[12];
  246. // DateDwin[6]=USART3_RX_BUF[13];
  247. LenOfPrint = sprintf(PrintBuff, "_____________\r\n");
  248. //LenOfPrint=sprintf(PrintBuff,"20%02d-%02d-%02d;%02d:%02d:%02d\r\n",DateDwin[0],DateDwin[1],DateDwin[2],DateDwin[4],DateDwin[5],DateDwin[6]);
  249. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  250. memset(PrintBuff, 0, sizeof(PrintBuff));
  251. //*/
  252. HAL_Delay(20);
  253. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  254. LenOfPrint = sprintf(PrintBuff, "_____________\r\n");
  255. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  256. memset(PrintBuff, 0, sizeof(PrintBuff));
  257. LenOfPrint = sprintf(PrintBuff, "_____________\r\n");
  258. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  259. KeySlave485_Send_Data((uint8_t *)PrintBuff, LenOfPrint);
  260. memset(PrintBuff, 0, sizeof(PrintBuff));
  261. PrintCnt++;
  262. HAL_Delay(10);
  263. pT2C_SetupData_Con2Server->year = pT2C_SetupData->year;
  264. pT2C_SetupData_Con2Server->month = pT2C_SetupData->month;
  265. pT2C_SetupData_Con2Server->day = pT2C_SetupData->day;
  266. pT2C_SetupData_Con2Server->hour = pT2C_SetupData->hour;
  267. pT2C_SetupData_Con2Server->minute = pT2C_SetupData->minute;
  268. pT2C_SetupData_Con2Server->second = pT2C_SetupData->second;
  269. pT2C_SetupData_Con2Server->longitude = pT2C_SetupData->longitude;
  270. pT2C_SetupData_Con2Server->latitude = pT2C_SetupData->latitude;
  271. pT2C_SetupData_Con2Server->Capacity_Vt = pT2C_SetupData->Capacity_Vt;
  272. pT2C_SetupData_Con2Server->Capacity_V20 = pT2C_SetupData->Capacity_V20;
  273. pT2C_SetupData_Con2Server->liquid_level = pT2C_SetupData->liquid_level;
  274. pT2C_SetupData_Con2Server->temperature = pT2C_SetupData->temperature;
  275. pT2C_SetupData_Con2Server->inclination_angle_x = pT2C_SetupData->inclination_angle_x;
  276. pT2C_SetupData_Con2Server->inclination_angle_y = pT2C_SetupData->inclination_angle_y;
  277. pT2C_SetupData_Con2Server->pressure = pT2C_SetupData->pressure;
  278. pT2C_SetupData_Con2Server->density = pT2C_SetupData->density;
  279. pT2C_SetupData_Con2Server->Reserved_parameters_1 = pT2C_SetupData->Reserved_parameters_1;
  280. pT2C_SetupData_Con2Server->Reserved_parameters_2 = pT2C_SetupData->Reserved_parameters_2;
  281. pT2C_SetupData_Con2Server->Reserved_parameters_3 = pT2C_SetupData->Reserved_parameters_3;
  282. pT2C_SetupData_Con2Server->Reserved_parameters_4 = pT2C_SetupData->Reserved_parameters_4;
  283. if (PrinterType == 0x00) //禁止打印命令
  284. { //创鑫公司
  285. PrintBuff[0] = 0x1b; //
  286. PrintBuff[1] = 0x64;
  287. PrintBuff[2] = 0x00;
  288. KeySlave485_Send_Data((uint8_t *)PrintBuff, 3);
  289. }
  290. else
  291. { //济南打印机HOE公司
  292. PrintBuff[0] = 0x03; //
  293. PrintBuff[1] = 0xaa;
  294. KeySlave485_Send_Data((uint8_t *)PrintBuff, 2);
  295. }
  296. memset(PrintBuff, 0, sizeof(PrintBuff));
  297. // HAL_GPIO_TogglePin(GPIOC, DWI_Pin); //看门狗sp706
  298. }
  299. void TestUsart4_Receive(void)
  300. {
  301. if (usart4_rx_flag && UART4_RX_BUF[0] == 0x12)
  302. {
  303. usart4_rx_flag = 0;
  304. uart4RxCounter = 0;
  305. KeySlave485_Send_Data(UART4_RX_BUF, rx4_len);
  306. rx4_len = 0;
  307. }
  308. }
  309. //RS485发送len个字节.
  310. //buf:发送区首地址
  311. //len:发送的字节数(为了和本代码的接收匹配,这里建议不要超过64个字节)
  312. void KeySlave485_Send_Data(uint8_t *buf, uint8_t len)
  313. {
  314. while(1)
  315. {
  316. if(huart4.gState == HAL_UART_STATE_READY)
  317. break;
  318. osDelay(1);
  319. }
  320. KeySlave485_TX_Set(1); //设置为发送模式
  321. //osDelay(1); //阻塞时间
  322. //HAL_UART_Transmit(&huart4, buf, len, 1000); //串口4发送数据
  323. if(HAL_UART_Transmit_IT(&huart4,buf,len)!=HAL_OK)
  324. {
  325. KeySlave485_TX_Set(0); //设置为接收模式
  326. }
  327. }
  328. //RS485模式控制.
  329. //en:0,接收;1,发送.
  330. void KeySlave485_TX_Set(uint8_t en)
  331. {
  332. //int i000 = 0;
  333. if (en == 1)
  334. HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0, GPIO_PIN_RESET);
  335. else
  336. HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0, GPIO_PIN_SET);
  337. /*
  338. while (i000 < 20000)
  339. {
  340. i000++;
  341. __nop();
  342. }*/
  343. }
  344. uint8_t arr_alarm[7] = {0xAA, 0x07, 0xBE, 0xC8, 0x01, 0x0d, 0x0a};
  345. void Send_alarm10S(void)
  346. {
  347. // if(flag_Seal_Break == 1)
  348. // {
  349. KeySlave485_Send_Data(arr_alarm, 7);
  350. // }
  351. }
  352. float f001_uart4;
  353. uni_float uni_flo001_uart4; //标定数据用联合体 float格式存储 但是int16类型传过来
  354. uint16_t FnKey = 0x0000; //组合键
  355. uint8_t Get_keyvalue(void) //获取当前按键值50 81 00 01 04(仓数)00 80 00 00
  356. {
  357. uint8_t ret00 = 0;
  358. if (usart4_rx_flag)
  359. {
  360. usart4_rx_flag = 0;
  361. tmrForKeyPad = SPAN_KeyPress_Time; //记录按键的时间 如果60秒内有按键操作则强制进行屏幕唤醒
  362. //AA 04 A2 1B 01 6B C6 0D 0A ----F1
  363. if ((UART4_RX_BUF[0] == 0xAA) && (UART4_RX_BUF[2] == 0xA2))
  364. {
  365. Run_mode_key_info.key = UART4_RX_BUF[3];
  366. FnKey = ((uint16_t)UART4_RX_BUF[3] << 8) + UART4_RX_BUF[4];
  367. ret00 = UART4_RX_BUF[3]; //
  368. }
  369. //控制器参数标定:大盖、小盖、卸油阀、海底阀数量
  370. else if ((UART4_RX_BUF[0] == 0x50) && (UART4_RX_BUF[1] == 0x81)) //设置控制器参数:buf2
  371. {
  372. Config_info_all.Config_fun_id = UART4_RX_BUF[2]; //功能配置ID
  373. FM25L16B_WriteByte(ADDR_Config_fun_id, Config_info_all.Config_fun_id);
  374. Config_info_all.Collection_id = UART4_RX_BUF[3];
  375. Baseval_ID = Config_info_all.Collection_id; //默认一个初始化
  376. FM25L16B_WriteByte(ADDR_Baseval_ID, Baseval_ID);
  377. Config_info_all.All_number = UART4_RX_BUF[4];
  378. StoreNumber = Config_info_all.All_number;
  379. FM25L16B_WriteByte(ADDR_StoreNumber, StoreNumber);
  380. Config_info_all.ManHole_Big_info = UART4_RX_BUF[5]; //人孔盖信息(大盖)bit7标定大盖有没有 1没有 0有
  381. FM25L16B_WriteByte(ADDR_ManHole_Big_info, Config_info_all.ManHole_Big_info);
  382. Config_info_all.ManHole_small_info = UART4_RX_BUF[6]; //小盖单独标定,bit7标定大盖有没有 1没有 0有
  383. FM25L16B_WriteByte(ADDR_ManHole_small_info, Config_info_all.ManHole_small_info);
  384. Config_info_all.Dump_info = UART4_RX_BUF[7]; //卸油阀标定bit7=0常规一仓一个,bit7=1特殊一仓两个
  385. FM25L16B_WriteByte(ADDR_Dump_info, Config_info_all.Dump_info);
  386. Config_info_all.HaiDiFa_info = UART4_RX_BUF[8]; //底阀标定bit7=0气阀,bit7=1特殊485(日后可能会改)
  387. FM25L16B_WriteByte(ADDR_Foot_info, Config_info_all.HaiDiFa_info);
  388. all_Store = StoreNumber;
  389. Go_homepage(); //回到首页
  390. }
  391. else if ((UART4_RX_BUF[0] == 0x50) && (UART4_RX_BUF[1] == 0x82)) //设置车牌号罐车牌号
  392. { // 50 82 00 01 03 03 03 03 03
  393. //50 82为固定的帧头 第三字节代表省域代码;接下来的6位表示
  394. //新AB0808
  395. //FM25L16B_WriteByte(30,UART4_RX_BUF[2]);
  396. FM25L16B_WriteByte(ADDR_CarPlate_Number, UART4_RX_BUF[2]);
  397. /*
  398. switch (UART4_RX_BUF[2]) //车牌号的省域代码
  399. {
  400. case 00:
  401. break;
  402. default:
  403. break;
  404. }
  405. */
  406. //省域代码,一个汉字2字节
  407. CarLicensePlate[0] = CarLicCodeArray[UART4_RX_BUF[2]][6];
  408. CarLicensePlate[1] = CarLicCodeArray[UART4_RX_BUF[2]][7];
  409. memcpy(&CarLicensePlate[2], &UART4_RX_BUF[3], 6); //6位车牌号
  410. // FM25L16B_WriteByte(31,UART4_RX_BUF[3]);
  411. // FM25L16B_WriteByte(32,UART4_RX_BUF[4]);
  412. // FM25L16B_WriteByte(33,UART4_RX_BUF[5]);
  413. // FM25L16B_WriteByte(34,UART4_RX_BUF[6]);
  414. // FM25L16B_WriteByte(35,UART4_RX_BUF[7]);
  415. // FM25L16B_WriteByte(36,UART4_RX_BUF[8]);
  416. FM25L16B_WriteByte(ADDR_CarPlate_Number + 2, UART4_RX_BUF[3]);
  417. FM25L16B_WriteByte(ADDR_CarPlate_Number + 3, UART4_RX_BUF[4]);
  418. FM25L16B_WriteByte(ADDR_CarPlate_Number + 4, UART4_RX_BUF[5]);
  419. FM25L16B_WriteByte(ADDR_CarPlate_Number + 5, UART4_RX_BUF[6]);
  420. FM25L16B_WriteByte(ADDR_CarPlate_Number + 6, UART4_RX_BUF[7]);
  421. FM25L16B_WriteByte(ADDR_CarPlate_Number + 7, UART4_RX_BUF[8]);
  422. }
  423. else if ((UART4_RX_BUF[0] == 0x50) && (UART4_RX_BUF[1] == 0x83)) //调试状态标记,
  424. { // 50 83 00 01 03 03 03 03 03
  425. //50 83为固定的帧头 接下来7个字节为调试状态位,控制调试信息
  426. // FM25L16B_WriteByte(37,UART4_RX_BUF[2]);
  427. // FM25L16B_WriteByte(38,UART4_RX_BUF[3]);
  428. // FM25L16B_WriteByte(39,UART4_RX_BUF[4]);
  429. // FM25L16B_WriteByte(40,UART4_RX_BUF[5]);
  430. // FM25L16B_WriteByte(41,UART4_RX_BUF[6]);
  431. // FM25L16B_WriteByte(42,UART4_RX_BUF[7]);
  432. // FM25L16B_WriteByte(43,UART4_RX_BUF[8]);
  433. FM25L16B_WriteByte(ADDR_DebugControll + 0, UART4_RX_BUF[2]);
  434. FM25L16B_WriteByte(ADDR_DebugControll + 1, UART4_RX_BUF[3]);
  435. FM25L16B_WriteByte(ADDR_DebugControll + 2, UART4_RX_BUF[4]);
  436. FM25L16B_WriteByte(ADDR_DebugControll + 3, UART4_RX_BUF[5]);
  437. FM25L16B_WriteByte(ADDR_DebugControll + 4, UART4_RX_BUF[6]);
  438. FM25L16B_WriteByte(ADDR_DebugControll + 5, UART4_RX_BUF[7]);
  439. FM25L16B_WriteByte(ADDR_DebugControll + 6, UART4_RX_BUF[8]);
  440. // dbgArray[0]=UART4_RX_BUF[2];
  441. // dbgArray[1]=UART4_RX_BUF[3];
  442. // dbgArray[2]=UART4_RX_BUF[4];
  443. // dbgArray[3]=UART4_RX_BUF[5];
  444. // dbgArray[4]=UART4_RX_BUF[6];
  445. // dbgArray[5]=UART4_RX_BUF[7];
  446. // dbgArray[6]=UART4_RX_BUF[8];
  447. // dbgArray[7]=UART4_RX_BUF[8];
  448. // dbgArray[0]=FM25L16B_ReadByte(37);
  449. // dbgArray[1]=FM25L16B_ReadByte(38);
  450. // dbgArray[2]=FM25L16B_ReadByte(39);
  451. // dbgArray[3]=FM25L16B_ReadByte(40);
  452. // dbgArray[4]=FM25L16B_ReadByte(41);
  453. // dbgArray[5]=FM25L16B_ReadByte(42);
  454. // dbgArray[6]=FM25L16B_ReadByte(43);
  455. // dbgArray[7]=FM25L16B_ReadByte(43);
  456. dbgArray[0] = FM25L16B_ReadByte(ADDR_DebugControll + 0);
  457. dbgArray[1] = FM25L16B_ReadByte(ADDR_DebugControll + 1);
  458. dbgArray[2] = FM25L16B_ReadByte(ADDR_DebugControll + 2);
  459. dbgArray[3] = FM25L16B_ReadByte(ADDR_DebugControll + 3);
  460. dbgArray[4] = FM25L16B_ReadByte(ADDR_DebugControll + 4);
  461. dbgArray[5] = FM25L16B_ReadByte(ADDR_DebugControll + 5);
  462. dbgArray[6] = FM25L16B_ReadByte(ADDR_DebugControll + 6);
  463. dbgArray[7] = FM25L16B_ReadByte(ADDR_DebugControll + 7);
  464. }
  465. //参数标定 雷达液位计偏移 零点参数
  466. else if ((UART4_RX_BUF[0] == 0x50) && (UART4_RX_BUF[1] == 0x84)) //设置雷达液位计偏移
  467. { // 50 84 00 01 03 03 03 03 03
  468. //50 84为固定的帧头 接下来7个字节为调试状态位,控制调试信息
  469. // FM25L16B_WriteByte(44,UART4_RX_BUF[2]);
  470. // FM25L16B_WriteByte(45,UART4_RX_BUF[3]);
  471. // FM25L16B_WriteByte(46,UART4_RX_BUF[4]);
  472. // FM25L16B_WriteByte(47,UART4_RX_BUF[5]);
  473. OffsetYewei[0] = (UART4_RX_BUF[2] << 8) + UART4_RX_BUF[3];
  474. OffsetTankCapacity[0] = (UART4_RX_BUF[4] << 8) + UART4_RX_BUF[5];
  475. f001_uart4 = (1.00000f) * (int16_t)OffsetYewei[0]; //强制转换为浮点数
  476. uni_flo001_uart4.flo_Data = f001_uart4;
  477. __nop();
  478. FM25L16B_WriteByte(ADDR_Zero_Of_LiquidMeter + 0, uni_flo001_uart4.array_u8[0]);
  479. FM25L16B_WriteByte(ADDR_Zero_Of_LiquidMeter + 1, uni_flo001_uart4.array_u8[1]);
  480. FM25L16B_WriteByte(ADDR_Zero_Of_LiquidMeter + 2, uni_flo001_uart4.array_u8[2]);
  481. FM25L16B_WriteByte(ADDR_Zero_Of_LiquidMeter + 3, uni_flo001_uart4.array_u8[3]);
  482. uni_flo001_uart4.flo_Data = (1.000000f) * (int16_t)OffsetTankCapacity[0];
  483. __nop();
  484. FM25L16B_WriteByte(ADDR_Zero_Of_TankCapacity + 0, uni_flo001_uart4.array_u8[0]);
  485. FM25L16B_WriteByte(ADDR_Zero_Of_TankCapacity + 1, uni_flo001_uart4.array_u8[1]);
  486. FM25L16B_WriteByte(ADDR_Zero_Of_TankCapacity + 2, uni_flo001_uart4.array_u8[2]);
  487. FM25L16B_WriteByte(ADDR_Zero_Of_TankCapacity + 3, uni_flo001_uart4.array_u8[3]);
  488. }
  489. else if ((UART4_RX_BUF[0] == 0x50) && (UART4_RX_BUF[1] == 0x85)) //读取雷达液位计偏移
  490. { // 50 85 00 01 03 03 03 03 03 //第一仓的液位计零点,罐容零点数据
  491. //50 85为固定的帧头 接下来7个字节为调试状态位,控制调试信息
  492. // UART4_RX_BUF[2]=FM25L16B_ReadByte(44);
  493. // UART4_RX_BUF[3]=FM25L16B_ReadByte(45);
  494. // UART4_RX_BUF[4]=FM25L16B_ReadByte(46);
  495. // UART4_RX_BUF[5]=FM25L16B_ReadByte(47);
  496. // UART4_RX_BUF[2]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+0);
  497. // UART4_RX_BUF[3]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+1);
  498. //
  499. UART4_RX_BUF[2] = OffsetYewei[0] >> 8; //FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+0);
  500. UART4_RX_BUF[3] = OffsetYewei[0] & 0x00ff; //FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+1);
  501. // UART4_RX_BUF[4]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+2);
  502. // UART4_RX_BUF[5]=FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+3);
  503. UART4_RX_BUF[4] = OffsetTankCapacity[0] >> 8; //FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+0);
  504. UART4_RX_BUF[5] = OffsetTankCapacity[0] & 0x00ff; //FM25L16B_ReadByte(ADDR_Zero_Of_LiquidMeter+1);
  505. //offsetLeiDa004=(UART4_RX_BUF[2]<<8) + UART4_RX_BUF[3];
  506. }
  507. else if ((UART4_RX_BUF[0] == 0x05) && (UART4_RX_BUF[1] == 0x20)) //设置采集器参数(写仓数,写大盖小盖参数,写卸油阀底阀参数)
  508. {
  509. Set_CollectPara_Flag = True;
  510. }
  511. //HAL_Delay(10);
  512. uart4RxCounter = 0;
  513. //扬声器的命令例外,不用回复 语音播报器
  514. if ((UART4_RX_BUF[0] != 0x03) && (rx4_len > 2))
  515. {
  516. KeySlave485_Send_Data(UART4_RX_BUF, rx4_len);
  517. }
  518. rx4_len = 0;
  519. // HAL_Delay(200);
  520. // KeySlave485_Send_Data(UART4_RX_BUF,rx4_len);
  521. }
  522. return ret00;
  523. }
  524. uint8_t SetOilPagePoint = 0;
  525. uint8_t SetStorePagePoint = 0;
  526. uint8_t Input_date[20] = {0};
  527. uint8_t Set_Select_flag = 0; //登录设置或者查询标记 0 默认 1设置 2查询
  528. #include "FreeRTOS.h"
  529. #include "semphr.h"
  530. extern SemaphoreHandle_t xSemaphore_uart4;
  531. void Mode_key_pageID(void)
  532. {
  533. uint8_t i = 0;
  534. if (Run_mode_key_info.key != 0)
  535. { //如果有按键按下--开始
  536. if (Lcd_sleep_flag == 1)
  537. {
  538. Run_mode_key_info.key = 0;
  539. }
  540. Sleep_Timer_cnt3 = 0;
  541. Lcd_sleep_flag = 2;
  542. //如果是状态界面,也就是主界面 //主界面判断开始 李伟修改 20210212
  543. if (Run_mode_key_info.current_page == Run_mode_key_info.Main_Page_id)
  544. {
  545. __nop(); //
  546. switch (Run_mode_key_info.key)
  547. {
  548. case 0x1b: //F1
  549. if (Full_Oil_allinfo.Start_Decrease_flag == 0)
  550. {
  551. Jump_page_id(Run_mode_key_info.Full_oil_id); //进入装油界面
  552. Full_Oil_allinfo.Start_Full_flag = 1;
  553. }
  554. else //弹出警告,正在卸油
  555. WrDwinCmd16(0x103e, 0x01); //卸油油警告,弹窗
  556. //PopWinCmdFunc(PopWinCmd1Buf);
  557. if (FunDebugCode == DebugFun__Restart_ContBoard01)
  558. {
  559. //停止重启 取消重启
  560. flag_exitReset = 1;
  561. }
  562. break;
  563. case 0x02: //F2
  564. // if(Full_Oil_allinfo.Start_Full_flag!=1)
  565. // Jump_page_id(Run_mode_key_info.offLoading_oil_id);//进入卸油界面
  566. // else//弹出警告if(((IO_Date.IO_unload_switch&(1<<i))==(1<<i))&&((Full_Oil_allinfo.Break_sealing_Id&(1<<i))==(1<<i)))//有油&破封
  567. // WrDwinCmd16(0x103c,0x01);//装油警告,弹窗
  568. //==0x08对应于bit3-----可以重复施封
  569. //if(((Config_info_all.Config_fun_id&0x08) == 0x08))
  570. //Full_Oil_allinfo.Start_Seal_flag = 1;
  571. //20210104强制按下F2键就可以施封 李伟更改
  572. //Full_Oil_allinfo.Start_Seal_flag = 1;
  573. //if (Full_Oil_allinfo.Break_sealing_Id > 0)
  574. {
  575. if (((Config_info_all.Config_fun_id & 0x08) == 0x08) || (Full_Oil_allinfo.Break_sealing_Id==0)) //==0x08对应于bit3-----可以重复施封
  576. {
  577. for (i = 0; i < StoreNumber; i++)
  578. {
  579. if (((flag_En_BlankSeal == 0x01) || (IO_Date.IO_unload_switch & (1 << i))))
  580. { //允许空仓施封
  581. //if ((Full_Oil_allinfo.Break_sealing_Id & (1 << i)) == (1 << i))
  582. {
  583. if (((IO_Date.IO_state[0] & (0x0f << (i * 4))) == 0))
  584. {
  585. Full_Oil_allinfo.Break_sealing_Id &= ~(1 << i); //清除本仓破封信息
  586. Full_Oil_allinfo.Auto_sealedOK_ID |= 1 << i; //本仓可以重新施封
  587. Sealing_Data.Sealing_up_datetype = 2; //上报报平台,进行施封
  588. FM25L16B_WriteByte(ADDR_Auto_sealedOK_ID, Full_Oil_allinfo.Auto_sealedOK_ID); //保存施封状态20200428
  589. FM25L16B_WriteByte(ADDR_Break_sealing_Id, (uint8_t)Full_Oil_allinfo.Break_sealing_Id); //保存破封状态20200428
  590. }
  591. }
  592. } //允许空仓施封
  593. #if 0
  594. else
  595. { //不允许空仓施封
  596. if (/*((Full_Oil_allinfo.Break_sealing_Id & (1 << i)) == (1 << i)) &&*/ ())
  597. {
  598. if (((~IO_Date.IO_state[0]) & (0x0f << (i * 4))) == (0x0f << (i * 4)))
  599. {
  600. Full_Oil_allinfo.Break_sealing_Id &= ~(1 << i); //清除本仓破封信息
  601. Full_Oil_allinfo.Auto_sealedOK_ID |= 1 << i; //本仓可以重新施封
  602. Sealing_Data.Sealing_up_datetype = 2; //上报报平台,进行施封
  603. FM25L16B_WriteByte(ADDR_Auto_sealedOK_ID, Full_Oil_allinfo.Auto_sealedOK_ID); //保存施封状态20200428
  604. FM25L16B_WriteByte(ADDR_Break_sealing_Id, (uint8_t)Full_Oil_allinfo.Break_sealing_Id); //保存破封状态20200428
  605. }
  606. }
  607. } //不允许空仓施封
  608. #endif
  609. }
  610. }
  611. }
  612. break;
  613. case 0x03: //F3 设置
  614. #if 1
  615. tmrForPrinter = 3; //立即取消打印机时间限制,按下打印按键可以立即打印
  616. /*if (1 == 1)
  617. {
  618. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  619. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  620. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  621. }
  622. else*/
  623. {
  624. Set_Select_flag = 1;
  625. Jump_page_id(38); //登录
  626. Dispay_login(0, 0);
  627. }
  628. #else
  629. Jump_page_id(Run_mode_key_info.Liquid_id); //进入模拟量数据
  630. #endif
  631. break;
  632. case 0x7f: //清除键 键盘的清除键
  633. // uni_TempRealtime001.flo_Data=0.1;
  634. input_Arr[0] = 0; //input_Arr[1];
  635. input_Arr[1] = 0; //Run_mode_key_info.key-0x30;
  636. FunDebugCode = 0;
  637. input_ArrFunDebugCode[0] = 0; //input_ArrFunDebugCode[1];
  638. input_ArrFunDebugCode[1] = 0; //input_ArrFunDebugCode[2];
  639. input_ArrFunDebugCode[2] = 0; //input_ArrFunDebugCode[3];
  640. input_ArrFunDebugCode[3] = 0; //input_ArrFunDebugCode[4];
  641. input_ArrFunDebugCode[4] = 0; //input_Arr[1];
  642. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  643. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  644. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  645. //实时温度用户输入显示
  646. // sd000=uni_TempRealtime001.farray[3]<<24 | uni_TempRealtime001.farray[2]<<16 |uni_TempRealtime001.farray[1]<<8 | uni_TempRealtime001.farray[0];
  647. // WrDwinCmd32(0x2080,sd000);
  648. break;
  649. case 0x2e: //键盘的.键码
  650. ManualSign = ManualSign * (-1.0f);
  651. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  652. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  653. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  654. break;
  655. case 0x30: //按下数字键0
  656. case 0x31: //按下数字键1
  657. case 0x32: //按下数字键2
  658. case 0x34: //按下数字键4
  659. case 0x35: //按下数字键5
  660. case 0x36: //按下数字键6
  661. case 0x37: //按下数字键7
  662. case 0x38: //按下数字键8
  663. case 0x39: //按下数字键9
  664. case 0x33: //按下数字键3
  665. input_Arr[0] = input_Arr[1];
  666. input_Arr[1] = Run_mode_key_info.key - 0x30;
  667. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  668. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  669. tmrForPrinter = 3; //立即取消打印机时间限制,按下打印按键可以立即打印
  670. //功能码匹配,类似于手机号码的*#06#;功能码必须为9开头。避开温度输入的区间
  671. input_ArrFunDebugCode[0] = input_ArrFunDebugCode[1];
  672. input_ArrFunDebugCode[1] = input_ArrFunDebugCode[2];
  673. input_ArrFunDebugCode[2] = input_ArrFunDebugCode[3];
  674. input_ArrFunDebugCode[3] = input_ArrFunDebugCode[4];
  675. input_ArrFunDebugCode[4] = input_Arr[1]; //input_ArrFunDebugCode[1];
  676. FunDebugCode = input_ArrFunDebugCode[0] * 10000 + input_ArrFunDebugCode[1] * 1000 + input_ArrFunDebugCode[2] * 100 +
  677. input_ArrFunDebugCode[3] * 10 + input_ArrFunDebugCode[4];
  678. break;
  679. case 0x06: //F4 查询----2020年12月更改为打印功能
  680. if (1) //李伟更改20210109----将F4更改为打印功能,替换掉之前未实现的查询功能
  681. {
  682. //taskENTER_CRITICAL();
  683. if (tmrForPrinter == 0)
  684. {
  685. tmrForPrinter = 15000; //启动定时器,15s内只能打印一次
  686. //xSemaphoreTake( xSemaphore_uart4, portMAX_DELAY );
  687. flag_Uart4_Busy = 1;
  688. #if (Printer_En)
  689. PrintInfo(); //打印相关信息:液位,阀门状态,车牌号,温度等
  690. #endif
  691. flag_Uart4_Busy = 0;
  692. //xSemaphoreGive( xSemaphore_uart4 );
  693. }
  694. //taskEXIT_CRITICAL();
  695. }
  696. else
  697. {
  698. Set_Select_flag = 2;
  699. Jump_page_id(38); //登录
  700. Dispay_login(0, 0);
  701. }
  702. break;
  703. case 0x10: //上
  704. // if()
  705. break;
  706. case 0x11: //下
  707. break;
  708. case 0x12: //确认
  709. if (Full_Oil_allinfo.Auto_sealedOK_ID != 0) //有施封
  710. {
  711. Jump_page_id(40); //选择油品
  712. }
  713. break;
  714. default:
  715. break;
  716. }
  717. } //主界面判断结束 李伟修改 20210212
  718. else if (Run_mode_key_info.current_page == Run_mode_key_info.Full_oil_id)
  719. { //如果是装油界面
  720. if (Run_mode_key_info.key == 0x1b)
  721. {
  722. if (Full_Oil_allinfo.Real_operation_ID == 0) //没有装油操作,标志清零
  723. Full_Oil_allinfo.Start_Full_flag = 0;
  724. Jump_page_id(Run_mode_key_info.Main_Page_id);
  725. }
  726. if (Run_mode_key_info.key == 0x02) //F2按键 F2键
  727. {
  728. if (Full_Oil_allinfo.Real_operation_ID == 0) //没有装油操作,标志清零
  729. Full_Oil_allinfo.Start_Full_flag = 0;
  730. else
  731. Full_Oil_allinfo.Start_Seal_flag = 1; //施封
  732. //20210104强制按下F2键就可以施封 李伟更改
  733. //Full_Oil_allinfo.Start_Seal_flag = 1;
  734. Jump_page_id(Run_mode_key_info.Main_Page_id);
  735. ////==0x08对应于bit3-----可以重复施封
  736. if (((Config_info_all.Config_fun_id & 0x08) == 0x08))
  737. Full_Oil_allinfo.Start_Seal_flag = 1;
  738. }
  739. //李伟修改 装油界面按下F3强制解除20分钟计时
  740. if (Run_mode_key_info.key == 0x03) //F3按键 F3键
  741. {
  742. tmrForTemp_ManualInput = 10; //强制10ms之后采用采集器或者平台下发的温度,而非手工输入的温度
  743. }
  744. }
  745. else if (Run_mode_key_info.current_page == Run_mode_key_info.offLoading_oil_id)
  746. { //卸油界面
  747. if (Run_mode_key_info.key == 0x1b)
  748. {
  749. Jump_page_id(Run_mode_key_info.Main_Page_id);
  750. }
  751. }
  752. else if (Run_mode_key_info.current_page == 40)
  753. {
  754. switch (Run_mode_key_info.key)
  755. {
  756. case 0x10: //上
  757. SetOilPagePoint++;
  758. if (SetOilPagePoint > 5)
  759. SetOilPagePoint = 0;
  760. Jump_page_id(40 + SetOilPagePoint);
  761. break;
  762. case 0x11: //下
  763. SetOilPagePoint--;
  764. if (SetOilPagePoint > 5)
  765. SetOilPagePoint = 0;
  766. Jump_page_id(40 + SetOilPagePoint);
  767. break;
  768. case 0x12: //确认
  769. if (Run_mode_key_info.current_page == 40) //当前界面是油品选择
  770. {
  771. Jump_page_id(46);
  772. }
  773. break;
  774. default:
  775. break;
  776. }
  777. }
  778. else if (Run_mode_key_info.current_page == 46)
  779. {
  780. switch (Run_mode_key_info.key)
  781. {
  782. case 0x10: //上
  783. SetStorePagePoint++;
  784. if (SetStorePagePoint > 7)
  785. SetOilPagePoint = 0;
  786. Jump_page_id(46 + SetStorePagePoint);
  787. break;
  788. case 0x11: //下
  789. SetStorePagePoint--;
  790. if (SetStorePagePoint > 7)
  791. SetStorePagePoint = 0;
  792. Jump_page_id(46 + SetStorePagePoint);
  793. break;
  794. case 0x12: //确认
  795. Jump_page_id(Run_mode_key_info.Main_Page_id);
  796. PlatformCalibrat.SetOilStyleFlag = True;
  797. PlatformCalibrat.OilStyleStore = SetStorePagePoint + 1; //仓号
  798. PlatformCalibrat.OilStyle = SetOilPagePoint + 1; //油品
  799. break;
  800. default:
  801. break;
  802. }
  803. }
  804. else if (Run_mode_key_info.current_page == Run_mode_key_info.Liquid_id)
  805. {
  806. Jump_page_id(Run_mode_key_info.Main_Page_id);
  807. }
  808. else //公用页面
  809. {
  810. switch (Run_mode_key_info.current_page)
  811. {
  812. case 32: //系统设置界面
  813. {
  814. switch (Run_mode_key_info.key)
  815. {
  816. case 0x1b: //F1
  817. memset(Input_date, 0, 20);
  818. Set_Select_flag = 0;
  819. Jump_page_id(Run_mode_key_info.Main_Page_id);
  820. break;
  821. case 0x30:
  822. break;
  823. case 0x31:
  824. memset(Input_date, 0, 20);
  825. Jump_page_id(39); //时间设置
  826. break;
  827. case 0x32:
  828. case 0x33:
  829. case 0x34:
  830. case 0x35:
  831. case 0x36:
  832. case 0x37:
  833. case 0x38:
  834. case 0x39:
  835. break;
  836. default:
  837. break;
  838. }
  839. }
  840. break;
  841. case 38: //用户登录
  842. {
  843. uint8_t i = 0;
  844. switch (Run_mode_key_info.key)
  845. {
  846. case 0x1b: //F1
  847. memset(Input_date, 0, 20);
  848. Set_Select_flag = 0;
  849. Jump_page_id(Run_mode_key_info.Main_Page_id);
  850. break;
  851. case 0x02: //F2 登录 比较密码
  852. {
  853. uint8_t length = 0;
  854. uint8_t pawd[6] = {0x38, 0x35, 0x32, 0x38, 0x37, 0x39}; //852879
  855. length = strlen((char *)Input_date); //
  856. if (memcmp(pawd, Input_date, 6) == 0) //密码一致
  857. {
  858. if (Set_Select_flag == 1) //如果是设置进入设置
  859. {
  860. Set_Select_flag = 0;
  861. Jump_page_id(32); //进入设置界面
  862. }
  863. else if (Set_Select_flag == 2) //否则进入查询
  864. {
  865. Set_Select_flag = 0;
  866. }
  867. memset(Input_date, 0, 20);
  868. }
  869. else //密码不一致,重新输入
  870. {
  871. if (length <= 6)
  872. Dispay_login(1, length);
  873. else
  874. Dispay_login(1, 6);
  875. }
  876. }
  877. break;
  878. case 0x03: //F3
  879. memset(Input_date, 0, 20);
  880. Dispay_login(0, 0);
  881. break;
  882. case 0x7f: //clear (char*)
  883. {
  884. uint8_t length = 0;
  885. length = strlen((char *)Input_date);
  886. if (length > 0)
  887. {
  888. Input_date[length - 1] = 0;
  889. length = length - 1;
  890. Dispay_login(0, length);
  891. }
  892. }
  893. break;
  894. case 0x30:
  895. case 0x31:
  896. case 0x32:
  897. case 0x33:
  898. case 0x34:
  899. case 0x35:
  900. case 0x36:
  901. case 0x37:
  902. case 0x38:
  903. case 0x39:
  904. for (i = 0; i < 6; i++)
  905. {
  906. if (Input_date[i] == 0)
  907. {
  908. Input_date[i] = Run_mode_key_info.key; //,Input_date+i
  909. Dispay_login(0, i + 1);
  910. break;
  911. }
  912. }
  913. break;
  914. default:
  915. break;
  916. }
  917. break;
  918. }
  919. case 39: //时间设置
  920. {
  921. uint8_t i = 0;
  922. switch (Run_mode_key_info.key)
  923. {
  924. case 0x1b: //F1
  925. memset(Input_date, 0, 20);
  926. Jump_page_id(Run_mode_key_info.Main_Page_id);
  927. break;
  928. case 0x02: //F2
  929. Display_input_time(1, Input_date);
  930. break;
  931. case 0x03: //F3
  932. memset(Input_date, 0, 20);
  933. Display_input_time(0, Input_date);
  934. break;
  935. case 0x7f: //clear (char*)
  936. {
  937. uint8_t length = 0;
  938. length = strlen((char *)Input_date);
  939. if (length > 0)
  940. {
  941. Input_date[length - 1] = 0;
  942. Display_input_time(0, Input_date);
  943. }
  944. }
  945. break;
  946. case 0x30:
  947. case 0x31:
  948. case 0x32:
  949. case 0x33:
  950. case 0x34:
  951. case 0x35:
  952. case 0x36:
  953. case 0x37:
  954. case 0x38:
  955. case 0x39:
  956. for (i = 0; i < 12; i++)
  957. {
  958. if (Input_date[i] == 0)
  959. {
  960. Input_date[i] = Run_mode_key_info.key; //,Input_date+i
  961. Display_input_time(0, Input_date);
  962. break;
  963. }
  964. }
  965. break;
  966. default:
  967. break;
  968. }
  969. break;
  970. }
  971. default:
  972. break;
  973. }
  974. }
  975. Run_mode_key_info.key = 0;
  976. } //如果有按键按下--开始
  977. //Send_alarm10S();//破封报警发送
  978. }
  979. //void About_KeyFunction(void)
  980. //{
  981. // Get_keyvalue();
  982. // Mode_key_pageID();
  983. //}