KeySlave485.c 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138
  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,20230109};
  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 (
  580. (((flag_En_BlankSeal == 0x01) || (IO_Date.IO_unload_switch & (1 << i))))
  581. &&
  582. (((Full_Oil_allinfo.Break_sealing_Id&(1<<i)) == 0) //判断当前仓是否处于破封状态,boly add 20221121
  583. ||((Config_info_all.Config_fun_id & 0x08) == 0x08) ) //==0x08对应于bit3-----可以重复施封
  584. )
  585. { //允许空仓施封
  586. //if ((Full_Oil_allinfo.Break_sealing_Id & (1 << i)) == (1 << i))
  587. {
  588. if (((IO_Date.IO_state[0] & (0x0f << (i * 4))) == 0))
  589. {
  590. Full_Oil_allinfo.Break_sealing_Id &= ~(1 << i); //清除本仓破封信息
  591. Full_Oil_allinfo.Auto_sealedOK_ID |= 1 << i; //本仓可以重新施封
  592. Sealing_Data.Sealing_up_datetype = 2; //上报报平台,进行施封
  593. FM25L16B_WriteByte(ADDR_Auto_sealedOK_ID, Full_Oil_allinfo.Auto_sealedOK_ID); //保存施封状态20200428
  594. FM25L16B_WriteByte(ADDR_Break_sealing_Id, (uint8_t)Full_Oil_allinfo.Break_sealing_Id); //保存破封状态20200428
  595. }
  596. }
  597. } //允许空仓施封
  598. #if 0
  599. else
  600. { //不允许空仓施封
  601. if (/*((Full_Oil_allinfo.Break_sealing_Id & (1 << i)) == (1 << i)) &&*/ ())
  602. {
  603. if (((~IO_Date.IO_state[0]) & (0x0f << (i * 4))) == (0x0f << (i * 4)))
  604. {
  605. Full_Oil_allinfo.Break_sealing_Id &= ~(1 << i); //清除本仓破封信息
  606. Full_Oil_allinfo.Auto_sealedOK_ID |= 1 << i; //本仓可以重新施封
  607. Sealing_Data.Sealing_up_datetype = 2; //上报报平台,进行施封
  608. FM25L16B_WriteByte(ADDR_Auto_sealedOK_ID, Full_Oil_allinfo.Auto_sealedOK_ID); //保存施封状态20200428
  609. FM25L16B_WriteByte(ADDR_Break_sealing_Id, (uint8_t)Full_Oil_allinfo.Break_sealing_Id); //保存破封状态20200428
  610. }
  611. }
  612. } //不允许空仓施封
  613. #endif
  614. }
  615. }
  616. }
  617. break;
  618. case 0x03: //F3 设置
  619. #if 1
  620. tmrForPrinter = 3; //立即取消打印机时间限制,按下打印按键可以立即打印
  621. /*if (1 == 1)
  622. {
  623. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  624. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  625. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  626. }
  627. else*/
  628. {
  629. Set_Select_flag = 1;
  630. Jump_page_id(38); //登录
  631. Dispay_login(0, 0);
  632. }
  633. #else
  634. Jump_page_id(Run_mode_key_info.Liquid_id); //进入模拟量数据
  635. #endif
  636. break;
  637. case 0x7f: //清除键 键盘的清除键
  638. // uni_TempRealtime001.flo_Data=0.1;
  639. input_Arr[0] = 0; //input_Arr[1];
  640. input_Arr[1] = 0; //Run_mode_key_info.key-0x30;
  641. FunDebugCode = 0;
  642. input_ArrFunDebugCode[0] = 0; //input_ArrFunDebugCode[1];
  643. input_ArrFunDebugCode[1] = 0; //input_ArrFunDebugCode[2];
  644. input_ArrFunDebugCode[2] = 0; //input_ArrFunDebugCode[3];
  645. input_ArrFunDebugCode[3] = 0; //input_ArrFunDebugCode[4];
  646. input_ArrFunDebugCode[4] = 0; //input_Arr[1];
  647. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  648. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  649. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  650. //实时温度用户输入显示
  651. // sd000=uni_TempRealtime001.farray[3]<<24 | uni_TempRealtime001.farray[2]<<16 |uni_TempRealtime001.farray[1]<<8 | uni_TempRealtime001.farray[0];
  652. // WrDwinCmd32(0x2080,sd000);
  653. break;
  654. case 0x2e: //键盘的.键码
  655. ManualSign = ManualSign * (-1.0f);
  656. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  657. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  658. tmrForTemp_ManualInput = SPAN_Manual_Input_Temp; //手工输入温度定时器为20分钟
  659. break;
  660. case 0x30: //按下数字键0
  661. case 0x31: //按下数字键1
  662. case 0x32: //按下数字键2
  663. case 0x34: //按下数字键4
  664. case 0x35: //按下数字键5
  665. case 0x36: //按下数字键6
  666. case 0x37: //按下数字键7
  667. case 0x38: //按下数字键8
  668. case 0x39: //按下数字键9
  669. case 0x33: //按下数字键3
  670. input_Arr[0] = input_Arr[1];
  671. input_Arr[1] = Run_mode_key_info.key - 0x30;
  672. uni_TempRealtime001.flo_Data = input_Arr[0] * 10.0f + input_Arr[1];
  673. uni_TempRealtime001.flo_Data = uni_TempRealtime001.flo_Data * (ManualSign);
  674. tmrForPrinter = 3; //立即取消打印机时间限制,按下打印按键可以立即打印
  675. //功能码匹配,类似于手机号码的*#06#;功能码必须为9开头。避开温度输入的区间
  676. input_ArrFunDebugCode[0] = input_ArrFunDebugCode[1];
  677. input_ArrFunDebugCode[1] = input_ArrFunDebugCode[2];
  678. input_ArrFunDebugCode[2] = input_ArrFunDebugCode[3];
  679. input_ArrFunDebugCode[3] = input_ArrFunDebugCode[4];
  680. input_ArrFunDebugCode[4] = input_Arr[1]; //input_ArrFunDebugCode[1];
  681. FunDebugCode = input_ArrFunDebugCode[0] * 10000 + input_ArrFunDebugCode[1] * 1000 + input_ArrFunDebugCode[2] * 100 +
  682. input_ArrFunDebugCode[3] * 10 + input_ArrFunDebugCode[4];
  683. break;
  684. case 0x06: //F4 查询----2020年12月更改为打印功能
  685. if (1) //李伟更改20210109----将F4更改为打印功能,替换掉之前未实现的查询功能
  686. {
  687. //taskENTER_CRITICAL();
  688. if (tmrForPrinter == 0)
  689. {
  690. tmrForPrinter = 15000; //启动定时器,15s内只能打印一次
  691. //xSemaphoreTake( xSemaphore_uart4, portMAX_DELAY );
  692. flag_Uart4_Busy = 1;
  693. #if (Printer_En)
  694. PrintInfo(); //打印相关信息:液位,阀门状态,车牌号,温度等
  695. #endif
  696. flag_Uart4_Busy = 0;
  697. //xSemaphoreGive( xSemaphore_uart4 );
  698. }
  699. //taskEXIT_CRITICAL();
  700. }
  701. else
  702. {
  703. Set_Select_flag = 2;
  704. Jump_page_id(38); //登录
  705. Dispay_login(0, 0);
  706. }
  707. break;
  708. case 0x10: //上
  709. // if()
  710. break;
  711. case 0x11: //下
  712. break;
  713. case 0x12: //确认
  714. if (Full_Oil_allinfo.Auto_sealedOK_ID != 0) //有施封
  715. {
  716. Jump_page_id(40); //选择油品
  717. }
  718. break;
  719. default:
  720. break;
  721. }
  722. } //主界面判断结束 李伟修改 20210212
  723. else if (Run_mode_key_info.current_page == Run_mode_key_info.Full_oil_id)
  724. { //如果是装油界面
  725. if (Run_mode_key_info.key == 0x1b)
  726. {
  727. if (Full_Oil_allinfo.Real_operation_ID == 0) //没有装油操作,标志清零
  728. Full_Oil_allinfo.Start_Full_flag = 0;
  729. Jump_page_id(Run_mode_key_info.Main_Page_id);
  730. }
  731. if (Run_mode_key_info.key == 0x02) //F2按键 F2键
  732. {
  733. if (Full_Oil_allinfo.Real_operation_ID == 0) //没有装油操作,标志清零
  734. Full_Oil_allinfo.Start_Full_flag = 0;
  735. else
  736. Full_Oil_allinfo.Start_Seal_flag = 1; //施封
  737. //20210104强制按下F2键就可以施封 李伟更改
  738. //Full_Oil_allinfo.Start_Seal_flag = 1;
  739. Jump_page_id(Run_mode_key_info.Main_Page_id);
  740. ////==0x08对应于bit3-----可以重复施封
  741. if (((Config_info_all.Config_fun_id & 0x08) == 0x08))
  742. Full_Oil_allinfo.Start_Seal_flag = 1;
  743. }
  744. //李伟修改 装油界面按下F3强制解除20分钟计时
  745. if (Run_mode_key_info.key == 0x03) //F3按键 F3键
  746. {
  747. tmrForTemp_ManualInput = 10; //强制10ms之后采用采集器或者平台下发的温度,而非手工输入的温度
  748. }
  749. }
  750. else if (Run_mode_key_info.current_page == Run_mode_key_info.offLoading_oil_id)
  751. { //卸油界面
  752. if (Run_mode_key_info.key == 0x1b)
  753. {
  754. Jump_page_id(Run_mode_key_info.Main_Page_id);
  755. }
  756. }
  757. else if (Run_mode_key_info.current_page == 40)
  758. {
  759. switch (Run_mode_key_info.key)
  760. {
  761. case 0x10: //上
  762. SetOilPagePoint++;
  763. if (SetOilPagePoint > 5)
  764. SetOilPagePoint = 0;
  765. Jump_page_id(40 + SetOilPagePoint);
  766. break;
  767. case 0x11: //下
  768. SetOilPagePoint--;
  769. if (SetOilPagePoint > 5)
  770. SetOilPagePoint = 0;
  771. Jump_page_id(40 + SetOilPagePoint);
  772. break;
  773. case 0x12: //确认
  774. if (Run_mode_key_info.current_page == 40) //当前界面是油品选择
  775. {
  776. Jump_page_id(46);
  777. }
  778. break;
  779. default:
  780. break;
  781. }
  782. }
  783. else if (Run_mode_key_info.current_page == 46)
  784. {
  785. switch (Run_mode_key_info.key)
  786. {
  787. case 0x10: //上
  788. SetStorePagePoint++;
  789. if (SetStorePagePoint > 7)
  790. SetOilPagePoint = 0;
  791. Jump_page_id(46 + SetStorePagePoint);
  792. break;
  793. case 0x11: //下
  794. SetStorePagePoint--;
  795. if (SetStorePagePoint > 7)
  796. SetStorePagePoint = 0;
  797. Jump_page_id(46 + SetStorePagePoint);
  798. break;
  799. case 0x12: //确认
  800. Jump_page_id(Run_mode_key_info.Main_Page_id);
  801. PlatformCalibrat.SetOilStyleFlag = True;
  802. PlatformCalibrat.OilStyleStore = SetStorePagePoint + 1; //仓号
  803. PlatformCalibrat.OilStyle = SetOilPagePoint + 1; //油品
  804. break;
  805. default:
  806. break;
  807. }
  808. }
  809. else if (Run_mode_key_info.current_page == Run_mode_key_info.Liquid_id)
  810. {
  811. Jump_page_id(Run_mode_key_info.Main_Page_id);
  812. }
  813. else //公用页面
  814. {
  815. switch (Run_mode_key_info.current_page)
  816. {
  817. case 32: //系统设置界面
  818. {
  819. switch (Run_mode_key_info.key)
  820. {
  821. case 0x1b: //F1
  822. memset(Input_date, 0, 20);
  823. Set_Select_flag = 0;
  824. Jump_page_id(Run_mode_key_info.Main_Page_id);
  825. break;
  826. case 0x30:
  827. break;
  828. case 0x31:
  829. memset(Input_date, 0, 20);
  830. Jump_page_id(39); //时间设置
  831. break;
  832. case 0x32:
  833. case 0x33:
  834. case 0x34:
  835. case 0x35:
  836. case 0x36:
  837. case 0x37:
  838. case 0x38:
  839. case 0x39:
  840. break;
  841. default:
  842. break;
  843. }
  844. }
  845. break;
  846. case 38: //用户登录
  847. {
  848. uint8_t i = 0;
  849. switch (Run_mode_key_info.key)
  850. {
  851. case 0x1b: //F1
  852. memset(Input_date, 0, 20);
  853. Set_Select_flag = 0;
  854. Jump_page_id(Run_mode_key_info.Main_Page_id);
  855. break;
  856. case 0x02: //F2 登录 比较密码
  857. {
  858. uint8_t length = 0;
  859. uint8_t pawd[6] = {0x38, 0x35, 0x32, 0x38, 0x37, 0x39}; //852879
  860. length = strlen((char *)Input_date); //
  861. if (memcmp(pawd, Input_date, 6) == 0) //密码一致
  862. {
  863. if (Set_Select_flag == 1) //如果是设置进入设置
  864. {
  865. Set_Select_flag = 0;
  866. Jump_page_id(32); //进入设置界面
  867. }
  868. else if (Set_Select_flag == 2) //否则进入查询
  869. {
  870. Set_Select_flag = 0;
  871. }
  872. memset(Input_date, 0, 20);
  873. }
  874. else //密码不一致,重新输入
  875. {
  876. if (length <= 6)
  877. Dispay_login(1, length);
  878. else
  879. Dispay_login(1, 6);
  880. }
  881. }
  882. break;
  883. case 0x03: //F3
  884. memset(Input_date, 0, 20);
  885. Dispay_login(0, 0);
  886. break;
  887. case 0x7f: //clear (char*)
  888. {
  889. uint8_t length = 0;
  890. length = strlen((char *)Input_date);
  891. if (length > 0)
  892. {
  893. Input_date[length - 1] = 0;
  894. length = length - 1;
  895. Dispay_login(0, length);
  896. }
  897. }
  898. break;
  899. case 0x30:
  900. case 0x31:
  901. case 0x32:
  902. case 0x33:
  903. case 0x34:
  904. case 0x35:
  905. case 0x36:
  906. case 0x37:
  907. case 0x38:
  908. case 0x39:
  909. for (i = 0; i < 6; i++)
  910. {
  911. if (Input_date[i] == 0)
  912. {
  913. Input_date[i] = Run_mode_key_info.key; //,Input_date+i
  914. Dispay_login(0, i + 1);
  915. break;
  916. }
  917. }
  918. break;
  919. default:
  920. break;
  921. }
  922. break;
  923. }
  924. case 39: //时间设置
  925. {
  926. uint8_t i = 0;
  927. switch (Run_mode_key_info.key)
  928. {
  929. case 0x1b: //F1
  930. memset(Input_date, 0, 20);
  931. Jump_page_id(Run_mode_key_info.Main_Page_id);
  932. break;
  933. case 0x02: //F2
  934. Display_input_time(1, Input_date);
  935. break;
  936. case 0x03: //F3
  937. memset(Input_date, 0, 20);
  938. Display_input_time(0, Input_date);
  939. break;
  940. case 0x7f: //clear (char*)
  941. {
  942. uint8_t length = 0;
  943. length = strlen((char *)Input_date);
  944. if (length > 0)
  945. {
  946. Input_date[length - 1] = 0;
  947. Display_input_time(0, Input_date);
  948. }
  949. }
  950. break;
  951. case 0x30:
  952. case 0x31:
  953. case 0x32:
  954. case 0x33:
  955. case 0x34:
  956. case 0x35:
  957. case 0x36:
  958. case 0x37:
  959. case 0x38:
  960. case 0x39:
  961. for (i = 0; i < 12; i++)
  962. {
  963. if (Input_date[i] == 0)
  964. {
  965. Input_date[i] = Run_mode_key_info.key; //,Input_date+i
  966. Display_input_time(0, Input_date);
  967. break;
  968. }
  969. }
  970. break;
  971. default:
  972. break;
  973. }
  974. break;
  975. }
  976. default:
  977. break;
  978. }
  979. }
  980. Run_mode_key_info.key = 0;
  981. } //如果有按键按下--开始
  982. //Send_alarm10S();//破封报警发送
  983. }
  984. //void About_KeyFunction(void)
  985. //{
  986. // Get_keyvalue();
  987. // Mode_key_pageID();
  988. //}