Module_LcmControl.c 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077
  1. #include <stdio.h> /*標準輸入輸出定義*/
  2. #include <stdlib.h> /*標準函數庫定義*/
  3. #include <stdint.h>
  4. #include <string.h>
  5. #include <unistd.h>
  6. #include <termios.h>
  7. #include <fcntl.h>
  8. #include <time.h>
  9. #include <sys/ioctl.h>
  10. #include <sys/timeb.h>
  11. #include "Module_LcmControl.h"
  12. #include "../Log/log.h"
  13. #include "../ShareMemory/shmMem.h"
  14. #include "../Define/define.h"
  15. #include "../Config.h"
  16. #include "../SelectGun/SelectGun.h"
  17. #define uSEC_VAL (1000000)
  18. //------------------------------------------------------------------------------
  19. //struct SysConfigAndInfo *ShmSysConfigAndInfo;
  20. //struct StatusCodeData *ShmStatusCodeData;
  21. static struct SysConfigData *pSysConfig = NULL;
  22. static struct SysInfoData *pSysInfo = NULL;
  23. static struct WARNING_CODE_INFO *pSysWarning = NULL;
  24. static struct FanModuleData *ShmFanModuleData;
  25. static struct PrimaryMcuData *ShmPrimaryMcuData;
  26. static SelectGunInfo *ShmSelectGunInfo = NULL;
  27. static struct ChargingInfoData *pDcChargingInfo = NULL;
  28. short _currentPage = _LCM_NONE;
  29. uint8_t _totalCount;
  30. uint8_t _showInformIndex = 0;
  31. float ChargeMaxPower_0 = 0;
  32. float ChargeMaxPower_1 = 0;
  33. int _port;
  34. //char* pPortName = "/dev/ttyO2";
  35. char *pPortName = "/dev/ttyS3";
  36. char *moduleName = "DMT80480T070_09WT";
  37. bool is_show = false;
  38. //==========================================
  39. // Open and Close RS232 and R/W
  40. //==========================================
  41. unsigned long GetClockTimeoutValue(struct timespec _start_time)
  42. {
  43. struct timespec ts_end;
  44. unsigned long ret = 0;
  45. clock_gettime(CLOCK_MONOTONIC, &ts_end);
  46. ret = ((unsigned long)(ts_end.tv_sec - _start_time.tv_sec) * 1000000) + ((unsigned long)((ts_end.tv_nsec / 1000) - (_start_time.tv_nsec/ 1000)));
  47. return ret;
  48. }
  49. int CreateCommunicationLcmPort()
  50. {
  51. int fd;
  52. struct termios tios;
  53. fd = open(pPortName, O_RDWR);
  54. if (fd <= 0) {
  55. log_error("open /dev/ttyS3 NG ");
  56. return -1;
  57. }
  58. ioctl(fd, TCGETS, &tios);
  59. tios.c_cflag = B115200 | CS8 | CLOCAL | CREAD;
  60. tios.c_lflag = 0;
  61. tios.c_iflag = 0;
  62. tios.c_oflag = 0;
  63. tios.c_cc[VMIN] = 0;
  64. tios.c_cc[VTIME] = (uint8_t) 5;
  65. tios.c_lflag = 0;
  66. tcflush(fd, TCIFLUSH);
  67. ioctl(fd, TCSETS, &tios);
  68. return fd;
  69. }
  70. void CloseCommunicationLcmPort()
  71. {
  72. close(_port);
  73. }
  74. void WriteCmdToLcm(uint8_t *cmd, uint8_t cmdLen)
  75. {
  76. int len = write(_port, cmd, cmdLen);
  77. if (len < sizeof(cmd)) {
  78. log_error("Write cmd to LCM Failure. ");
  79. }
  80. }
  81. void ReadMsgFromLcm(uint8_t *msg, uint8_t readLen)
  82. {
  83. read(_port, msg, readLen);
  84. if (*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2) {
  85. if (*(msg + 3) == CMD_WRITE) {
  86. switch (*(msg + 4)) {
  87. case CMD_REGISTER: {
  88. // 頁面
  89. strcpy((char *)pSysInfo->LcmHwRev, moduleName);
  90. }
  91. break;
  92. }
  93. } else if (*(msg + 3) == CMD_MULTI_READ) {
  94. // switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
  95. // {
  96. // case BUTTON_GUN_INDEX:
  97. // {
  98. // // 當前選的槍號
  99. // _curGunIndex = (*(msg + 8));
  100. // }
  101. // break;
  102. // }
  103. }
  104. }
  105. }
  106. void GetHrFormTimeString(char* time,char* hr)
  107. {
  108. //char tm[] = "2021-12-06 17:29:08:084";
  109. for(int i = 0 ; i < 2 ; i++) {
  110. hr[i] = time[i+11];
  111. }
  112. if( atoi(hr) == NULL ) {
  113. strcmp(hr,"");
  114. }
  115. }
  116. void GetMinFormTimeString(char* time,char* min)
  117. {
  118. //char tm[] = "2021-12-06 17:29:08:084";
  119. for(int i = 0 ; i < 2 ; i++) {
  120. min[i] = time[i+14];
  121. }
  122. if( atoi(min) == NULL || atoi(min) > 60) {
  123. strcmp(min,"");
  124. }
  125. }
  126. //================================================
  127. // Function
  128. //================================================
  129. void ChangeToOtherPage(short newPage)
  130. {
  131. uint8_t cmd[7];
  132. memset(cmd, 0x00, sizeof(cmd));
  133. cmd[0] = CMD_TITLE_1;
  134. cmd[1] = CMD_TITLE_2;
  135. cmd[2] = 0x02 + sizeof(newPage);
  136. cmd[3] = CMD_READ;
  137. cmd[4] = CMD_REGISTER;
  138. cmd[5] = newPage >> 8;
  139. cmd[6] = newPage & 0x00FF;
  140. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  141. usleep(100000);
  142. }
  143. void ChangeBackLight(bool islight)
  144. {
  145. uint8_t value = 0x01;
  146. if (islight) {
  147. value = 0x20;
  148. }
  149. uint8_t cmd[7];
  150. memset(cmd, 0x00, sizeof(cmd));
  151. cmd[0] = CMD_TITLE_1;
  152. cmd[1] = CMD_TITLE_2;
  153. cmd[2] = 0x03;
  154. cmd[3] = CMD_READ;
  155. cmd[4] = CMD_BACKLIGHT;
  156. cmd[5] = value;
  157. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  158. usleep(100000);
  159. }
  160. void GetCurrentPage()
  161. {
  162. uint8_t cmd[6];
  163. memset(cmd, 0x00, sizeof(cmd));
  164. uint8_t msg[8];
  165. memset(msg, 0x00, sizeof(msg));
  166. cmd[0] = CMD_TITLE_1;
  167. cmd[1] = CMD_TITLE_2;
  168. cmd[2] = 0x03; // 底下總長度
  169. cmd[3] = CMD_WRITE;
  170. cmd[4] = CMD_REGISTER;
  171. cmd[5] = 0x02;
  172. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  173. usleep(5000);
  174. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  175. }
  176. void DisplayValueToLcm(short address, uint8_t *data, uint8_t len)
  177. {
  178. uint8_t cmd[256];
  179. memset(cmd, 0x00, sizeof(cmd));
  180. cmd[0] = CMD_TITLE_1;
  181. cmd[1] = CMD_TITLE_2;
  182. cmd[2] = 0x03 + len;
  183. cmd[3] = CMD_MULTI_WRITE;
  184. cmd[4] = address >> 8;
  185. cmd[5] = address & 0x00FF;
  186. for (uint8_t count = 0; count < len; count++) {
  187. cmd[6 + count] = *(data + count);
  188. }
  189. WriteCmdToLcm(cmd, cmd[2] + 3);
  190. }
  191. void ChangeDisplay2Value(short address, short value)
  192. {
  193. uint8_t data[2];
  194. data[0] = value >> 8;
  195. data[1] = value & 0x00FF;
  196. //log_info("Addr:0x%x, value:%d",address,value);
  197. DisplayValueToLcm(address, data, sizeof(data));
  198. }
  199. //================================================
  200. // Warning process
  201. //================================================
  202. void string2ByteArray(uint8_t *input, uint8_t *output)
  203. {
  204. int loop;
  205. int i;
  206. loop = 0;
  207. i = 0;
  208. while (input[loop] != '\0') {
  209. output[i++] = input[loop++];
  210. }
  211. output[loop] = '\0';
  212. }
  213. //================================================
  214. // Change current page
  215. //================================================
  216. void ChangeCurPage()
  217. {
  218. //log_info("cur = %d ,system = %d, lcm = %d ",_currentPage, pSysInfo->SystemPage, pSysInfo->PageIndex);
  219. struct ChargingInfoData *pDcChargingInfo_0 = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  220. struct ChargingInfoData *pDcChargingInfo_1 = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  221. if (_currentPage != pSysInfo->SystemPage) {
  222. switch (pSysInfo->SystemPage) {
  223. case _LCM_VIEW:
  224. if (pDcChargingInfo_0->SystemStatus == S_IDLE && pDcChargingInfo_1->SystemStatus == S_IDLE ) {
  225. pSysInfo->PageIndex = __VIEW_ALL_IDLE_;
  226. } else if(pDcChargingInfo_0->SystemStatus == S_CHARGING && pDcChargingInfo_1->SystemStatus != S_CHARGING) {
  227. pSysInfo->PageIndex = __VIEW_LEFT_CHARGE_;
  228. } else if(pDcChargingInfo_0->SystemStatus != S_CHARGING && pDcChargingInfo_1->SystemStatus == S_CHARGING) {
  229. pSysInfo->PageIndex = __VIEW_RIGHT_CHARGE_;
  230. } else if(pDcChargingInfo_0->SystemStatus == S_CHARGING && pDcChargingInfo_1->SystemStatus == S_CHARGING) {
  231. pSysInfo->PageIndex = __VIEW_ALL_CHARGE_;
  232. } else
  233. pSysInfo->PageIndex = __VIEW_ALL_IDLE_;
  234. break;
  235. case _LCM_START_SCAN:
  236. pSysInfo->PageIndex = __START_SCAN_;
  237. break;
  238. case _LCM_START_AUTHORIZING:
  239. pSysInfo->PageIndex = __START_AUTHORIZE_;
  240. break;
  241. case _LCM_START_AUTHORIZE_FAIL:
  242. pSysInfo->PageIndex = __START_AUTHORIZE_FAIL_;
  243. break;
  244. case _LCM_WAIT_PLUGIN:
  245. pSysInfo->PageIndex = __WAIT_PLUGIN_;
  246. break;
  247. case _LCM_PRECHARGE:
  248. pSysInfo->PageIndex =__PRE_CHARGE_;
  249. break;
  250. case _LCM_LINK_ERROR:
  251. pSysInfo->PageIndex =__LINKING_ERROR_;
  252. break;
  253. case _LCM_DETAIL_VIEW:
  254. pSysInfo->PageIndex =__DETAIL_VIEW_;
  255. break;
  256. case _LCM_STOP_RFID:
  257. pSysInfo->PageIndex =__STOP_SCAN_RFID_;
  258. break;
  259. case _LCM_STOP_APP:
  260. pSysInfo->PageIndex =__STOP_SCAN_APP_;
  261. break;
  262. case _LCM_STOP_RFID_FAIL:
  263. pSysInfo->PageIndex =__STOP_RFID_FAIL_;
  264. break;
  265. case _LCM_STOPPING:
  266. pSysInfo->PageIndex =__STOP_AUTHORIZE_;
  267. break;
  268. case _LCM_WAIT_PLUGOUT:
  269. pSysInfo->PageIndex =__WAIT_PLUGOUT_;
  270. break;
  271. case _LCM_SUMMARY:
  272. pSysInfo->PageIndex =__SUMMARY_;
  273. break;
  274. case _LCM_MAINTAIN:
  275. pSysInfo->PageIndex =__MAINTAIN_PAGE_;
  276. break;
  277. case _LCM_ERROR:
  278. pSysInfo->PageIndex =__ERROR_PAGE_;
  279. break;
  280. case _LCM_EMERGENCY:
  281. pSysInfo->PageIndex =__EMERGENCY_BUTTON_;
  282. break;
  283. }
  284. _currentPage = pSysInfo->SystemPage;
  285. ChangeToOtherPage(pSysInfo->PageIndex);
  286. }
  287. }
  288. /*
  289. * View Page
  290. *
  291. */
  292. void ShowViewChargingSoc(uint8_t gunIndex,int soc)
  293. {
  294. uint8_t digits = soc % 10;
  295. uint8_t tens = (soc / 10) %10;
  296. uint8_t hundreds = soc / 100;
  297. if (gunIndex == LEFT_GUN_NUM) {
  298. ChangeDisplay2Value(_LeftGun_Soc_Digits,(short)_ICON_Red_Num_0+digits);
  299. ChangeDisplay2Value(_LeftGun_Soc_Tens,(short)_ICON_Red_Num_0+tens);
  300. if (hundreds == 0 ) {
  301. ChangeDisplay2Value(_LeftGun_Soc_Hundreds,(short)_ICON_Empty);
  302. if (tens == 0 )
  303. ChangeDisplay2Value(_LeftGun_Soc_Tens,(short)_ICON_Empty);
  304. }
  305. else
  306. ChangeDisplay2Value(_LeftGun_Soc_Hundreds,(short)_ICON_Red_Num_1);
  307. } else {
  308. //log_info("%d %d %d",hundreds,tens,digits);
  309. ChangeDisplay2Value(_RightGun_Soc_Digits,(short)_ICON_Red_Num_0+digits);
  310. ChangeDisplay2Value(_RightGun_Soc_Tens,(short)_ICON_Red_Num_0+tens);
  311. if (hundreds == 0 ) {
  312. ChangeDisplay2Value(_RightGun_Soc_Hundreds,(short)_ICON_Empty);
  313. if (tens == 0)
  314. ChangeDisplay2Value(_RightGun_Soc_Tens,(short)_ICON_Empty);
  315. }
  316. else
  317. ChangeDisplay2Value(_RightGun_Soc_Hundreds,(short)_ICON_Red_Num_1);
  318. }
  319. }
  320. void ShowViewChargingTime(uint8_t gunIndex,int time)
  321. {
  322. uint8_t value[10] = {0};
  323. int min;
  324. min = time/60;
  325. sprintf((char *)value,"%d",min);
  326. if (gunIndex == LEFT_GUN_NUM) {
  327. DisplayValueToLcm(_LeftGun_info_time, (uint8_t *)value, sizeof(value));
  328. } else
  329. DisplayValueToLcm(_RightGun_info_time, (uint8_t *)value, sizeof(value));
  330. }
  331. void ShowViewCharingMoney(uint8_t gunIndex,float money)
  332. {
  333. uint8_t value[10] = {0};
  334. sprintf((char *)value,"%.1f",money);
  335. if (gunIndex == LEFT_GUN_NUM) {
  336. DisplayValueToLcm(_LeftGun_info_money, (uint8_t *)value, sizeof(value));
  337. } else
  338. DisplayValueToLcm(_RightGun_info_money, (uint8_t *)value, sizeof(value));
  339. }
  340. void ShowViewChargingPower(uint8_t gunIndex,float power)
  341. {
  342. uint8_t value[10] = {0};
  343. sprintf((char *)value,"%.1f",power);
  344. if (power >= 0 && power <= POWER_MAX_KW) {
  345. if (gunIndex == LEFT_GUN_NUM) {
  346. DisplayValueToLcm(_LeftGun_info_power_number, (uint8_t *)value, sizeof(value));
  347. } else
  348. DisplayValueToLcm(_RightGun_info_power_number, (uint8_t *)value, sizeof(value));
  349. }
  350. }
  351. void ShowViewLeftGunInfo()
  352. {
  353. char value[5];
  354. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  355. if (pDcChargingInfo->SystemStatus == S_IDLE ) {
  356. switch (pDcChargingInfo->CCSGunType) {
  357. case _TYPE_CCS1_Liquid:
  358. case _TYPE_CCS1_Natural:
  359. ChangeDisplay2Value(_LeftGun_type_pic_U,_ICON_CCS1_GUN_U);
  360. ChangeDisplay2Value(_LeftGun_type_pic_L,_ICON_CCS1_GUN_L);
  361. ChangeDisplay2Value(_LeftGun_type_name,_ICON_CCS1_Name);
  362. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid) {
  363. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_High_Speed);
  364. } else {
  365. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_Speed);
  366. }
  367. break;
  368. case _TYPE_CCS2_Liquid:
  369. case _TYPE_CCS2_Natural:
  370. ChangeDisplay2Value(_LeftGun_type_pic_U,_ICON_CCS2_GUN_U);
  371. ChangeDisplay2Value(_LeftGun_type_pic_U,_ICON_CCS2_GUN_L);
  372. ChangeDisplay2Value(_LeftGun_type_name,_ICON_CCS2_Name);
  373. if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid) {
  374. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_High_Speed);
  375. } else {
  376. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_Speed);
  377. }
  378. break;
  379. default:
  380. log_error("CCS Gun Type Error! Not Show in LCM!!");
  381. }
  382. memset(value, 0x00, sizeof(value));
  383. sprintf((char *)value,"1A");
  384. DisplayValueToLcm(_LeftGun_location, (uint8_t *)value, sizeof(value));
  385. } else if (pDcChargingInfo->SystemStatus == S_CHARGING ) {
  386. ShowViewChargingSoc(LEFT_GUN_NUM,pDcChargingInfo->EvBatterySoc);
  387. ShowViewChargingTime(LEFT_GUN_NUM,pDcChargingInfo->PresentChargedDuration);
  388. ShowViewCharingMoney(LEFT_GUN_NUM,pDcChargingInfo->ChargingFee);
  389. ShowViewChargingPower(LEFT_GUN_NUM,pDcChargingInfo->PresentChargingPower);
  390. }
  391. }
  392. void ShowViewRightGunInfo()
  393. {
  394. char value[5];
  395. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  396. if (pDcChargingInfo->SystemStatus == S_IDLE ) {
  397. switch (pDcChargingInfo->CCSGunType) {
  398. case _TYPE_CCS1_Liquid:
  399. case _TYPE_CCS1_Natural:
  400. ChangeDisplay2Value(_RightGun_type_pic_U,_ICON_CCS1_GUN_U);
  401. ChangeDisplay2Value(_RightGun_type_pic_L,_ICON_CCS1_GUN_L);
  402. ChangeDisplay2Value(_RightGun_type_name,_ICON_CCS1_Name);
  403. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid) {
  404. ChangeDisplay2Value(_RightGun_type_speed,_ICON_High_Speed);
  405. } else {
  406. ChangeDisplay2Value(_RightGun_type_speed,_ICON_Speed);
  407. }
  408. break;
  409. case _TYPE_CCS2_Liquid:
  410. case _TYPE_CCS2_Natural:
  411. ChangeDisplay2Value(_RightGun_type_pic_U,_ICON_CCS2_GUN_U);
  412. ChangeDisplay2Value(_RightGun_type_pic_L,_ICON_CCS2_GUN_L);
  413. ChangeDisplay2Value(_RightGun_type_name,_ICON_CCS2_Name);
  414. if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid) {
  415. ChangeDisplay2Value(_RightGun_type_speed,_ICON_High_Speed);
  416. } else {
  417. ChangeDisplay2Value(_RightGun_type_speed,_ICON_Speed);
  418. }
  419. break;
  420. default:
  421. log_error("CCS Gun Type Error! Not Show in LCM!!");
  422. }
  423. memset(value, 0x00, sizeof(value));
  424. sprintf((char *)value,"1B");
  425. DisplayValueToLcm(_RightGun_location, (uint8_t *)value, sizeof(value));
  426. } else if (pDcChargingInfo->SystemStatus == S_CHARGING ) {
  427. ShowViewChargingSoc(RIGHT_GUN_NUM,pDcChargingInfo->EvBatterySoc);
  428. ShowViewChargingTime(RIGHT_GUN_NUM,pDcChargingInfo->PresentChargedDuration);
  429. ShowViewCharingMoney(RIGHT_GUN_NUM,pDcChargingInfo->ChargingFee);
  430. ShowViewChargingPower(RIGHT_GUN_NUM,pDcChargingInfo->PresentChargingPower);
  431. }
  432. }
  433. void SetViewPage()
  434. {
  435. // Set Background pic.
  436. if (pSysConfig->TotalConnectorCount == 1) {
  437. } else if (pSysConfig->TotalConnectorCount == 2) {
  438. ShowViewLeftGunInfo();
  439. ShowViewRightGunInfo();
  440. }
  441. }
  442. void ShowSelectGunIcon()
  443. {
  444. uint8_t value[5] = {0};
  445. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  446. if (pSysInfo->CurGunSelected == LEFT_GUN_NUM) {
  447. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  448. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  449. ChangeDisplay2Value(_Confirm_Gun_Left_symbol,_ICON_CCS1_Symbol);
  450. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  451. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  452. ChangeDisplay2Value(_Confirm_Gun_Left_symbol,_ICON_CCS2_Symbol);
  453. }
  454. ChangeDisplay2Value(_Confirm_Gun_Right_symbol,_ICON_Empty);
  455. sprintf((char *)value,"%s",LEFT_GUN_LOCAL_NAME);
  456. DisplayValueToLcm(_Confirm_Gun_Left_name, (uint8_t *)value, sizeof(value));
  457. memset(value, 0x00, sizeof(value));
  458. DisplayValueToLcm(_Confirm_Gun_Right_name, (uint8_t *)value, sizeof(value));
  459. } else if (pSysInfo->CurGunSelected == RIGHT_GUN_NUM) {
  460. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  461. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  462. ChangeDisplay2Value(_Confirm_Gun_Right_symbol,_ICON_CCS1_Symbol);
  463. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  464. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  465. ChangeDisplay2Value(_Confirm_Gun_Right_symbol,_ICON_CCS2_Symbol);
  466. }
  467. ChangeDisplay2Value(_Confirm_Gun_Left_symbol,_ICON_Empty);
  468. sprintf((char *)value,"%s",RIGHT_GUN_LOCAL_NAME);
  469. DisplayValueToLcm(_Confirm_Gun_Right_name, (uint8_t *)value, sizeof(value));
  470. memset(value, 0x00, sizeof(value));
  471. DisplayValueToLcm(_Confirm_Gun_Left_name, (uint8_t *)value, sizeof(value));
  472. }
  473. }
  474. /*
  475. * Detail View Page
  476. */
  477. void SetDetailViewPage()
  478. {
  479. uint8_t data;
  480. float float_data;
  481. uint8_t value[10] = {0};
  482. ShowSelectGunIcon();
  483. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  484. uint8_t digits = pDcChargingInfo->EvBatterySoc % 10;
  485. uint8_t tens = (pDcChargingInfo->EvBatterySoc / 10) %10;
  486. uint8_t hundreds = pDcChargingInfo->EvBatterySoc / 100;
  487. // Show Numbers.
  488. ChangeDisplay2Value(_Percent_Number_Digits,_ICON_White_Num_0+digits);
  489. ChangeDisplay2Value(_Percent_Number_Tens,_ICON_White_Num_0+tens);
  490. if (hundreds == 0 ) {
  491. ChangeDisplay2Value(_Percent_Number_Hundreds,_ICON_Empty);
  492. if (tens == 0)
  493. ChangeDisplay2Value(_Percent_Number_Tens,_ICON_Empty);
  494. } else {
  495. ChangeDisplay2Value(_Percent_Number_Hundreds,_ICON_White_Num_1);
  496. }
  497. // Show Progress Bar
  498. ChangeDisplay2Value(_ProgressBar_LEVEL,_ICON_ProgressBar_10+(pDcChargingInfo->EvBatterySoc/10)-1);
  499. // Show Power
  500. if (pDcChargingInfo->PresentChargingPower >= 0 &&
  501. pDcChargingInfo->PresentChargingPower <= POWER_MAX_KW) {
  502. float_data = pDcChargingInfo->PresentChargingPower;
  503. } else {
  504. float_data = 0;
  505. }
  506. sprintf((char *)value,"%.1f",float_data);
  507. DisplayValueToLcm(_Detail_Power_Num,value, sizeof(value));
  508. // Show Time
  509. data = (pDcChargingInfo->PresentChargedDuration)/60;
  510. sprintf((char *)value,"%d",data);
  511. DisplayValueToLcm(_Detail_Time_Num,value, sizeof(value));
  512. // Show Energy
  513. if (pDcChargingInfo->PresentChargedEnergy >= 0.1 &&
  514. pDcChargingInfo->PresentChargedEnergy <= ENERGY_MAX_KWH) {
  515. data = pDcChargingInfo->PresentChargedEnergy;
  516. } else
  517. data = 0;
  518. sprintf((char *)value,"%d",data);
  519. DisplayValueToLcm(_Detail_Cap_Num,value, sizeof(value));
  520. // Show Money
  521. //data = pDcChargingInfo->ChargingFee;
  522. sprintf((char *)value,"%.1f",pDcChargingInfo->ChargingFee);
  523. DisplayValueToLcm(_Detail_Money_Num,value, sizeof(value));
  524. }
  525. void ShowCountDownTimer()
  526. {
  527. int min,sec;
  528. uint8_t value[10] = {0};
  529. int tm = 120 - (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL);
  530. // GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL
  531. min = tm/60;
  532. sec = tm%60;
  533. sprintf((char *)value,"%02d:%02d",min,sec);
  534. DisplayValueToLcm(_Count_Down_Time, (uint8_t *)value, sizeof(value));
  535. }
  536. unsigned long GetTimeoutValue(struct timeval _sour_time)
  537. {
  538. struct timeval _end_time;
  539. gettimeofday(&_end_time, NULL);
  540. return 1000000 * (_end_time.tv_sec - _sour_time.tv_sec) + _end_time.tv_usec - _sour_time.tv_usec;
  541. }
  542. void ShowGunCountDownTimer()
  543. {
  544. int min,sec;
  545. uint8_t value[10] = {0};
  546. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  547. int tm = 30 - (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL);
  548. // GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL
  549. min = tm/60;
  550. sec = tm%60;
  551. sprintf((char *)value,"%02d:%02d",min,sec);
  552. DisplayValueToLcm(_Count_Down_Time, (uint8_t *)value, sizeof(value));
  553. }
  554. void ShowProgressBar()
  555. {
  556. for(int i = 0 ; i <= 9 ; i++) {
  557. ChangeDisplay2Value(_ProgressBar_LEVEL,_ICON_ProgressBar_10+i);
  558. usleep(200000);
  559. }
  560. }
  561. void ShowSummaryPage()
  562. {
  563. float data;
  564. uint8_t value[10] = {0};
  565. char start_hr[3],start_min[3],end_hr[3],end_min[3];
  566. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  567. // Show Money
  568. data = pDcChargingInfo->ChargingFee;
  569. sprintf((char *)value,"%.1f",data);
  570. int discount,settlement = 0;
  571. DisplayValueToLcm(_Summary_total_money, (uint8_t *)value, sizeof(value));
  572. DisplayValueToLcm(_Summary_cal_Total_money, (uint8_t *)value, sizeof(value));
  573. /*
  574. log_info("start time:%s",pDcChargingInfo->StartDateTime);
  575. log_info("stop time:%s",pDcChargingInfo->StopDateTime);*/
  576. GetHrFormTimeString(pDcChargingInfo->StartDateTime,start_hr);
  577. GetMinFormTimeString(pDcChargingInfo->StartDateTime,start_min);
  578. GetHrFormTimeString(pDcChargingInfo->StopDateTime,end_hr);
  579. GetMinFormTimeString(pDcChargingInfo->StopDateTime,end_min);
  580. DisplayValueToLcm(_Summary_Start_time_hr, (uint8_t *)start_hr, sizeof(start_hr));
  581. DisplayValueToLcm(_Summary_Start_time_min, (uint8_t *)start_min, sizeof(start_min));
  582. DisplayValueToLcm(_Summary_end_time_hr, (uint8_t *)end_hr, sizeof(end_hr));
  583. DisplayValueToLcm(_Summary_end_time_min, (uint8_t *)end_min, sizeof(end_min));
  584. uint8_t min = (pDcChargingInfo->PresentChargedDuration)/60;
  585. sprintf((char *)value,"%d",min);
  586. DisplayValueToLcm(_Summary_duration_time, (uint8_t *)value, sizeof(value));
  587. if (pDcChargingInfo->PresentChargedEnergy >= 0.1 &&
  588. pDcChargingInfo->PresentChargedEnergy <= ENERGY_MAX_KWH) {
  589. data = pDcChargingInfo->PresentChargedEnergy;
  590. } else
  591. data = 0;
  592. sprintf((char *)value,"%d",data);
  593. DisplayValueToLcm(_Summary_cap, (uint8_t *)value, sizeof(value));
  594. sprintf((char *)value,"%.1f",discount);
  595. DisplayValueToLcm(_Summary_cal_discount, (uint8_t *)value, sizeof(value));
  596. settlement = pDcChargingInfo->ChargingFee - discount;
  597. sprintf((char *)value,"%.1f",settlement);
  598. DisplayValueToLcm(_Summary_cal_Settlement, (char *)value, sizeof(value));
  599. if(pSysInfo->CurGunSelected == LEFT_GUN_NUM) {
  600. sprintf((char *)value,"%.1f",ChargeMaxPower_0);
  601. } else if (pSysInfo->CurGunSelected == RIGHT_GUN_NUM) {
  602. sprintf((char *)value,"%.1f",ChargeMaxPower_1);
  603. }
  604. DisplayValueToLcm(_Summary_max_power, (uint8_t *)value, sizeof(value));
  605. if (pDcChargingInfo->PresentChargedEnergy >= 0.1 &&
  606. pDcChargingInfo->PresentChargedEnergy <= ENERGY_MAX_KWH) {
  607. data = pDcChargingInfo->PresentChargedEnergy * pDcChargingInfo->PresentChargedDuration /3600;
  608. } else
  609. data = 0;
  610. sprintf((char *)value,"%.1f",data);
  611. DisplayValueToLcm(_Summary_average_power, (uint8_t *)value, sizeof(value));
  612. }
  613. void ProcessPageInfo()
  614. {
  615. switch (pSysInfo->SystemPage) {
  616. case _LCM_VIEW:
  617. // Confirm Charging Gun Number.
  618. SetViewPage();
  619. break;
  620. case _LCM_DETAIL_VIEW:
  621. ShowGunCountDownTimer();
  622. SetDetailViewPage();
  623. break;
  624. case _LCM_START_SCAN:
  625. case _LCM_STOP_RFID:
  626. case _LCM_STOP_APP:
  627. ShowSelectGunIcon();
  628. ShowCountDownTimer();
  629. break;
  630. case _LCM_START_AUTHORIZING:
  631. case _LCM_PRECHARGE:
  632. case _LCM_STOPPING:
  633. ShowProgressBar();
  634. break;
  635. case _LCM_START_AUTHORIZE_FAIL:
  636. case _LCM_STOP_RFID_FAIL:
  637. case _LCM_LINK_ERROR:
  638. ShowCountDownTimer();
  639. break;
  640. case _LCM_SUMMARY:
  641. ShowCountDownTimer();
  642. ShowSummaryPage();
  643. break;
  644. case _LCM_ERROR:
  645. case _LCM_MAINTAIN:
  646. case _LCM_WAIT_PLUGIN:
  647. case _LCM_WAIT_PLUGOUT:
  648. break;
  649. case _LCM_EMERGENCY:
  650. break;
  651. }
  652. }
  653. void DemoFunction()
  654. {
  655. int i,j;
  656. uint8_t value[10];
  657. struct timeb SeqEndTime;
  658. struct tm *tm;
  659. switch (pSysInfo->PageIndex) {
  660. case __VIEW_ALL_IDLE_:
  661. memset(value, 0x00, sizeof(value));
  662. sprintf((char *)value,"1A");
  663. DisplayValueToLcm(_LeftGun_location, (uint8_t *)value, sizeof(value));
  664. sprintf((char *)value,"1B");
  665. DisplayValueToLcm(_RightGun_location, (uint8_t *)value, sizeof(value));
  666. sleep(1);
  667. ChangeDisplay2Value(_LeftGun_type_pic_U,_ICON_CCS2_GUN_U);
  668. ChangeDisplay2Value(_LeftGun_type_pic_L,_ICON_CCS2_GUN_L);
  669. ChangeDisplay2Value(_LeftGun_type_name,_ICON_CCS2_Name);
  670. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_High_Speed);
  671. ChangeDisplay2Value(_RightGun_type_pic_U,_ICON_CCS2_GUN_U);
  672. ChangeDisplay2Value(_RightGun_type_pic_L,_ICON_CCS2_GUN_L);
  673. ChangeDisplay2Value(_RightGun_type_name,_ICON_CCS2_Name);
  674. ChangeDisplay2Value(_RightGun_type_speed,_ICON_High_Speed);
  675. sleep(1);
  676. ChangeDisplay2Value(_LeftGun_type_pic_U,_ICON_CCS1_GUN_U);
  677. ChangeDisplay2Value(_LeftGun_type_pic_L,_ICON_CCS1_GUN_L);
  678. ChangeDisplay2Value(_LeftGun_type_name,_ICON_CCS1_Name);
  679. ChangeDisplay2Value(_LeftGun_type_speed,_ICON_Speed);
  680. ChangeDisplay2Value(_RightGun_type_pic_U,_ICON_CCS1_GUN_U);
  681. ChangeDisplay2Value(_RightGun_type_pic_L,_ICON_CCS1_GUN_L);
  682. ChangeDisplay2Value(_RightGun_type_name,_ICON_CCS1_Name);
  683. ChangeDisplay2Value(_RightGun_type_speed,_ICON_Speed);
  684. break;
  685. case __VIEW_LEFT_CHARGE_:
  686. for(i=0;i<=100;i++) {
  687. ShowViewChargingSoc(LEFT_GUN_NUM,i);
  688. ShowViewChargingTime(LEFT_GUN_NUM,i*60);
  689. ShowViewCharingMoney(LEFT_GUN_NUM,i);
  690. ShowViewChargingPower(LEFT_GUN_NUM,i);
  691. usleep(200000);
  692. }
  693. break;
  694. case __VIEW_RIGHT_CHARGE_:
  695. for(i=0;i<=100;i++) {
  696. ShowViewChargingSoc(RIGHT_GUN_NUM,i);
  697. ShowViewChargingTime(RIGHT_GUN_NUM,i*60);
  698. ShowViewCharingMoney(RIGHT_GUN_NUM,i);
  699. ShowViewChargingPower(RIGHT_GUN_NUM,i);
  700. usleep(200000);
  701. }
  702. break;
  703. case __VIEW_ALL_CHARGE_:
  704. for(i=0;i<=100;i++) {
  705. ShowViewChargingSoc(LEFT_GUN_NUM,i);
  706. ShowViewChargingTime(LEFT_GUN_NUM,i*60);
  707. ShowViewCharingMoney(LEFT_GUN_NUM,i);
  708. ShowViewChargingPower(LEFT_GUN_NUM,i);
  709. ShowViewChargingSoc(RIGHT_GUN_NUM,i);
  710. ShowViewChargingTime(RIGHT_GUN_NUM,i*60);
  711. ShowViewCharingMoney(RIGHT_GUN_NUM,i);
  712. ShowViewChargingPower(RIGHT_GUN_NUM,i);
  713. usleep(200000);
  714. }
  715. break;
  716. case __START_SCAN_:
  717. case 7:
  718. case 9:
  719. break;
  720. case 11:
  721. for(i = 0 ; i <= 100 ; i++) {
  722. ChangeDisplay2Value(_ProgressBar_LEVEL,_ICON_ProgressBar_10+(i/10)-1);
  723. uint8_t digits = i % 10;
  724. uint8_t tens = (i / 10) %10;
  725. uint8_t hundreds = i / 100;
  726. ChangeDisplay2Value(_Percent_Number_Digits,(short)_ICON_White_Num_0+digits);
  727. ChangeDisplay2Value(_Percent_Number_Tens,(short)_ICON_White_Num_0+tens);
  728. if (hundreds == 0 )
  729. ChangeDisplay2Value(_Percent_Number_Hundreds,(short)_ICON_Empty);
  730. else
  731. ChangeDisplay2Value(_Percent_Number_Hundreds,(short)_ICON_White_Num_1);
  732. sprintf((char *)value,"%03d",i);
  733. DisplayValueToLcm(_Detail_Power_Num, (uint8_t *)value, sizeof(value));
  734. DisplayValueToLcm(_Detail_Time_Num, (uint8_t *)value, sizeof(value));
  735. DisplayValueToLcm(_Detail_Cap_Num, (uint8_t *)value, sizeof(value));
  736. DisplayValueToLcm(_Detail_Money_Num, (uint8_t *)value, sizeof(value));
  737. if (i%2 == 0 ) {
  738. ChangeDisplay2Value(_Confirm_Gun_Left_symbol,_ICON_CCS1_Symbol);
  739. ChangeDisplay2Value(_Confirm_Gun_Right_symbol,_ICON_Empty);
  740. memset(value, 0x00, sizeof(value));
  741. DisplayValueToLcm(_Confirm_Gun_Right_name, (uint8_t *)value, sizeof(value));
  742. sprintf((char *)value,"1A");
  743. DisplayValueToLcm(_Confirm_Gun_Left_name, (uint8_t *)value, sizeof(value));
  744. } else {
  745. ChangeDisplay2Value(_Confirm_Gun_Left_symbol,_ICON_Empty);
  746. ChangeDisplay2Value(_Confirm_Gun_Right_symbol,_ICON_CCS2_Symbol);
  747. memset(value, 0x00, sizeof(value));
  748. DisplayValueToLcm(_Confirm_Gun_Left_name, (uint8_t *)value, sizeof(value));
  749. sprintf((char *)value,"1B");
  750. DisplayValueToLcm(_Confirm_Gun_Right_name, (uint8_t *)value, sizeof(value));
  751. }
  752. usleep(200000);
  753. }
  754. break;
  755. case 12:
  756. case 13:
  757. case 15:
  758. case 17:
  759. ftime(&SeqEndTime);
  760. SeqEndTime.time = time(NULL);
  761. tm = localtime(&SeqEndTime.time);
  762. memset(value, 0x00, sizeof(value));
  763. sprintf((char *)value,"%02d:%02d",tm->tm_hour,tm->tm_min);
  764. DisplayValueToLcm(_Count_Down_Time, (uint8_t *)value, sizeof(value));
  765. if (pSysInfo->PageIndex == 11 ) {
  766. for( i = 12 ; i <= 21 ; i++) {
  767. ChangeDisplay2Value(_ProgressBar_LEVEL,i);
  768. usleep(200000);
  769. }
  770. }
  771. if (pSysInfo->PageIndex == 17 ) {
  772. }
  773. break;
  774. case __START_AUTHORIZE_:
  775. case 10:
  776. case 14:
  777. for( i = 12 ; i <= 21 ; i++) {
  778. ChangeDisplay2Value(_ProgressBar_LEVEL,i);
  779. usleep(200000);
  780. }
  781. break;
  782. case 8:
  783. case 16:
  784. case 18:
  785. case 19:
  786. case 20:
  787. break;
  788. case 21:
  789. break;
  790. case 22:
  791. ShowDispenserVersion();
  792. break;
  793. }
  794. }
  795. void ShowCabientVersionDefaultText()
  796. {
  797. char value[16];
  798. memset(value, 0x00, sizeof(value));
  799. sprintf((char *)value,"%s","Cabient:");
  800. DisplayValueToLcm(_Version_Cabient_Name_Text, (uint8_t *)value, sizeof(value));
  801. sprintf((char *)value,"%s","BootLoader:");
  802. DisplayValueToLcm(_Version_Cabient_BootLoader_Text, (uint8_t *)value, sizeof(value));
  803. sprintf((char *)value,"%s","Kernel Fw:");
  804. DisplayValueToLcm(_Version_Cabient_Kernel_Text, (uint8_t *)value, sizeof(value));
  805. sprintf((char *)value,"%s","CSU Fw:");
  806. DisplayValueToLcm(_Version_Cabient_CSU_Text, (uint8_t *)value, sizeof(value));
  807. sprintf((char *)value,"%s","Priamry Fw:");
  808. DisplayValueToLcm(_Version_Cabient_Priamry_Text, (uint8_t *)value, sizeof(value));
  809. sprintf((char *)value,"%s","Relay(0) Fw:");
  810. DisplayValueToLcm(_Version_Cabient_Relay0_Text, (uint8_t *)value, sizeof(value));
  811. sprintf((char *)value,"%s","Relay(1) Fw:");
  812. DisplayValueToLcm(_Version_Cabient_Relay1_Text, (uint8_t *)value, sizeof(value));
  813. sprintf((char *)value,"%s","Fan Fw:");
  814. DisplayValueToLcm(_Version_Cabient_Fan_Text, (uint8_t *)value, sizeof(value));
  815. sprintf((char *)value,"%s","IP Addr:");
  816. DisplayValueToLcm(_Version_Cabient_IPAddr_Text, (uint8_t *)value, sizeof(value));
  817. sprintf((char *)value,"%s","PSU Prim(1):");
  818. DisplayValueToLcm(_Version_Cabient_PSU_Prim1_Text, (uint8_t *)value, sizeof(value));
  819. sprintf((char *)value,"%s","PSU Prim(2):");
  820. DisplayValueToLcm(_Version_Cabient_PSU_Prim2_Text, (uint8_t *)value, sizeof(value));
  821. sprintf((char *)value,"%s","PSU Prim(3):");
  822. DisplayValueToLcm(_Version_Cabient_PSU_Prim3_Text, (uint8_t *)value, sizeof(value));
  823. sprintf((char *)value,"%s","PSU Prim(4):");
  824. DisplayValueToLcm(_Version_Cabient_PSU_Prim4_Text, (uint8_t *)value, sizeof(value));
  825. sprintf((char *)value,"%s","PSU Prim(5):");
  826. DisplayValueToLcm(_Version_Cabient_PSU_Prim5_Text, (uint8_t *)value, sizeof(value));
  827. sprintf((char *)value,"%s","PSU Prim(6):");
  828. DisplayValueToLcm(_Version_Cabient_PSU_Prim6_Text, (uint8_t *)value, sizeof(value));
  829. sprintf((char *)value,"%s","PSU Sec(1):");
  830. DisplayValueToLcm(_Version_Cabient_PSU_Sec1_Text, (uint8_t *)value, sizeof(value));
  831. sprintf((char *)value,"%s","PSU Sec(2):");
  832. DisplayValueToLcm(_Version_Cabient_PSU_Sec2_Text, (uint8_t *)value, sizeof(value));
  833. sprintf((char *)value,"%s","PSU Sec(3):");
  834. DisplayValueToLcm(_Version_Cabient_PSU_Sec3_Text, (uint8_t *)value, sizeof(value));
  835. sprintf((char *)value,"%s","PSU Sec(4):");
  836. DisplayValueToLcm(_Version_Cabient_PSU_Sec4_Text, (uint8_t *)value, sizeof(value));
  837. sprintf((char *)value,"%s","PSU Sec(5):");
  838. DisplayValueToLcm(_Version_Cabient_PSU_Sec5_Text, (uint8_t *)value, sizeof(value));
  839. sprintf((char *)value,"%s","PSU Sec(6):");
  840. DisplayValueToLcm(_Version_Cabient_PSU_Sec6_Text, (uint8_t *)value, sizeof(value));
  841. }
  842. void ShowDispenserVersionDefautlText()
  843. {
  844. char value[16];
  845. memset(value, 0x00, sizeof(value));
  846. sprintf((char *)value,"%s","Dispenser:");
  847. DisplayValueToLcm(_Version_Dispenser_Name_Text, (uint8_t *)value, sizeof(value));
  848. sprintf((char *)value,"%s","BootLoader:");
  849. DisplayValueToLcm(_Version_Dispenser_BootLoader_Text, (uint8_t *)value, sizeof(value));
  850. sprintf((char *)value,"%s","Kernel Fw:");
  851. DisplayValueToLcm(_Version_Dispenser_Kernel_Text, (uint8_t *)value, sizeof(value));
  852. sprintf((char *)value,"%s","CSU Fw:");
  853. DisplayValueToLcm(_Version_Dispenser_CSU_Text, (uint8_t *)value, sizeof(value));
  854. sprintf((char *)value,"%s","Relay Fw:");
  855. DisplayValueToLcm(_Version_Dispenser_Relay_Text, (uint8_t *)value, sizeof(value));
  856. sprintf((char *)value,"%s","Fan Fw:");
  857. DisplayValueToLcm(_Version_Dispenser_Fan_Text, (uint8_t *)value, sizeof(value));
  858. sprintf((char *)value,"%s","Prim Fw:");
  859. DisplayValueToLcm(_Version_Dispenser_Priamry_Text, (uint8_t *)value, sizeof(value));
  860. sprintf((char *)value,"%s","LCM Hw:");
  861. DisplayValueToLcm(_Version_Dispenser_LCM_Text, (uint8_t *)value, sizeof(value));
  862. sprintf((char *)value,"%s","LED Fw:");
  863. DisplayValueToLcm(_Version_Dispenser_LED_Text, (uint8_t *)value, sizeof(value));
  864. sprintf((char *)value,"%s","Connector(0):");
  865. DisplayValueToLcm(_Version_Dispenser_Connector0_Text, (uint8_t *)value, sizeof(value));
  866. sprintf((char *)value,"%s","Connector(1):");
  867. DisplayValueToLcm(_Version_Dispenser_Connector1_Text, (uint8_t *)value, sizeof(value));
  868. sprintf((char *)value,"%s","IP Addr:");
  869. DisplayValueToLcm(_Version_Dispenser_IPAddr_Text, (uint8_t *)value, sizeof(value));
  870. }
  871. void ShowCabientVersion()
  872. {
  873. }
  874. void ShowDispenserVersion()
  875. {
  876. char value[32];
  877. memset(value, 0x00, sizeof(value));
  878. sprintf((char *)value,"%s",pSysConfig->ModelName);
  879. DisplayValueToLcm(_Version_Dispenser_Model_value, (uint8_t *)value, sizeof(value));
  880. sprintf((char *)value,"%s",pSysInfo->CsuBootLoadFwRev);
  881. DisplayValueToLcm(_Version_Dispenser_BootLoader_value, (uint8_t *)value, sizeof(value));
  882. sprintf((char *)value,"%s",pSysInfo->CsuKernelFwRev);
  883. DisplayValueToLcm(_Version_Dispenser_Kernel_value, (uint8_t *)value, sizeof(value));
  884. sprintf((char *)value,"%s",pSysInfo->CsuRootFsFwRev);
  885. DisplayValueToLcm(_Version_Dispenser_CSU_value, (uint8_t *)value, sizeof(value));
  886. sprintf((char *)value,"%s",pSysInfo->RelayModuleFwRev);
  887. DisplayValueToLcm(_Version_Dispenser_Relay_value, (uint8_t *)value, sizeof(value));
  888. sprintf((char *)value,"%s",pSysInfo->FanModuleFwRev);
  889. DisplayValueToLcm(_Version_Dispenser_Fan_value, (uint8_t *)value, sizeof(value));
  890. sprintf((char *)value,"%s",pSysInfo->CsuPrimFwRev);
  891. DisplayValueToLcm(_Version_Dispenser_Priamry_value, (uint8_t *)value, sizeof(value));
  892. sprintf((char *)value,"%s",pSysInfo->LcmHwRev);
  893. DisplayValueToLcm(_Version_Dispenser_LCM_value, (uint8_t *)value, sizeof(value));
  894. sprintf((char *)value,"%s",pSysInfo->LedModuleFwRev);
  895. DisplayValueToLcm(_Version_Dispenser_LED_value, (uint8_t *)value, sizeof(value));
  896. sprintf((char *)value,"%s",pSysInfo->Connector1FwRev);
  897. DisplayValueToLcm(_Version_Dispenser_Connector0_value, (uint8_t *)value, sizeof(value));
  898. sprintf((char *)value,"%s",pSysInfo->Connector2FwRev);
  899. DisplayValueToLcm(_Version_Dispenser_Connector1_value, (uint8_t *)value, sizeof(value));
  900. sprintf((char *)value,"%s",pSysConfig->Eth0Interface.EthIpAddress);
  901. DisplayValueToLcm(_Version_Dispenser_IPAddr_value, (uint8_t *)value, sizeof(value));
  902. }
  903. void InformationShow()
  904. {
  905. is_show = true;
  906. if (_showInformIndex == 0 ) {
  907. pSysInfo->PageIndex = __SHOW_CABIENT_VERSION;
  908. } else {
  909. pSysInfo->PageIndex = __SHOW_DISPENSER_VERASION;
  910. ShowDispenserVersion();
  911. }
  912. }
  913. int main(void)
  914. {
  915. bool defaulttext = false;
  916. if (CreateAllCsuShareMemory() == FAIL) {
  917. log_error("create share memory error");
  918. return FAIL;
  919. }
  920. MappingGunChargingInfo("LCM Control Task");
  921. pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
  922. pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
  923. pSysWarning = (struct WARNING_CODE_INFO *)GetShmSysWarningInfo();
  924. ShmFanModuleData = (struct FanModuleData *)GetShmFanModuleData();;
  925. ShmPrimaryMcuData = (struct PrimaryMcuData *)GetShmPrimaryMcuData();
  926. ShmSelectGunInfo = (SelectGunInfo *)GetShmSelectGunInfo();
  927. struct StatusCodeData *ShmStatusCodeData = (struct StatusCodeData *)GetShmStatusCodeData();;
  928. struct ChargingInfoData *pDcChargingInfo_0 = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  929. struct ChargingInfoData *pDcChargingInfo_1 = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  930. _port = CreateCommunicationLcmPort();
  931. uint8_t changeWarningPriority = 0;
  932. uint8_t curWarningCount = 255;
  933. ChangeBackLight(true);
  934. _totalCount = pSysConfig->TotalConnectorCount;
  935. //Initialization();
  936. //printf("_LCM_COMPLETE ");
  937. //ChangeToOtherPage(_LCM_COMPLETE);
  938. //return 0;
  939. uint8_t index = 21;
  940. while (_port != -1) {
  941. if (strcmp((char *)pSysInfo->LcmHwRev, moduleName) != 0x00) {
  942. GetCurrentPage();
  943. sleep(1);
  944. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = true;
  945. } else {
  946. // Show Default Text
  947. if (!defaulttext) {
  948. ShowCabientVersionDefaultText();
  949. ShowDispenserVersionDefautlText();
  950. defaulttext = true;
  951. }
  952. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = false;
  953. //pSysInfo->PageIndex = index;
  954. if(pSysConfig->TotalConnectorCount>=2) {
  955. if (pDcChargingInfo_0->SystemStatus == S_IDLE) {
  956. ChargeMaxPower_0 = 0;
  957. } else if (pDcChargingInfo_0->SystemStatus == S_CHARGING) {
  958. if (pDcChargingInfo_0->PresentChargingPower > ChargeMaxPower_0 &&
  959. pDcChargingInfo_0->PresentChargingPower >= 0 &&
  960. pDcChargingInfo_0->PresentChargingPower <= POWER_MAX_KW)
  961. ChargeMaxPower_0 = pDcChargingInfo_0->PresentChargingPower;
  962. }
  963. if (pDcChargingInfo_1->SystemStatus == S_IDLE) {
  964. ChargeMaxPower_1 = 0;
  965. } else if (pDcChargingInfo_1->SystemStatus == S_CHARGING) {
  966. if (pDcChargingInfo_1->PresentChargingPower > ChargeMaxPower_1 &&
  967. pDcChargingInfo_1->PresentChargingPower >= 0 &&
  968. pDcChargingInfo_1->PresentChargingPower <= POWER_MAX_KW)
  969. ChargeMaxPower_1 = pDcChargingInfo_1->PresentChargingPower;
  970. }
  971. }
  972. // 頁面資訊處理
  973. ProcessPageInfo();
  974. // 換頁處理
  975. //GetCurrentPage(); //DS60-120 add
  976. if (pSysConfig->ShowInformation == YES && pSysInfo->SystemPage == _LCM_VIEW) {
  977. InformationShow();
  978. ChangeToOtherPage(pSysInfo->PageIndex);
  979. usleep(100000);
  980. continue;
  981. } else {
  982. if (is_show)
  983. _showInformIndex >= 1 ? _showInformIndex = 0 : _showInformIndex++;
  984. is_show = false;
  985. }
  986. GetCurrentPage(); //DS60-120 add
  987. ChangeCurPage();
  988. //ChangeToOtherPage(index);
  989. //DemoFunction();
  990. usleep(100000);
  991. //usleep(10000000);
  992. //index >= 22 ? index = 21 : index++;
  993. }
  994. } //while
  995. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = true;
  996. log_info("Close LCM Uart Port");
  997. CloseCommunicationLcmPort();
  998. return FAIL;
  999. }