Module_LcmControl.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904
  1. #include "Module_LcmContro.h"
  2. void PRINTF_FUNC(char *string, ...);
  3. int StoreLogMsg(const char *fmt, ...);
  4. #define DEBUG_INFO(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  5. #define DEBUG_WARN(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  6. #define DEBUG_ERROR(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  7. char* getTimeString(void);
  8. //=================================
  9. // Common routine
  10. //=================================
  11. int StoreLogMsg(const char *fmt, ...)
  12. {
  13. char Buf[4096+256];
  14. char buffer[4096];
  15. time_t CurrentTime;
  16. struct tm *tm;
  17. va_list args;
  18. va_start(args, fmt);
  19. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  20. va_end(args);
  21. memset(Buf,0,sizeof(Buf));
  22. CurrentTime = time(NULL);
  23. tm=localtime(&CurrentTime);
  24. sprintf(Buf,"echo \"%04d-%02d-%02d %02d:%02d:%02d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog",
  25. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,
  26. buffer,
  27. tm->tm_year+1900,tm->tm_mon+1);
  28. system(Buf);
  29. return rc;
  30. }
  31. char* getTimeString(void)
  32. {
  33. char *result=malloc(21);
  34. time_t timep;
  35. struct tm *p;
  36. time(&timep);
  37. p=gmtime(&timep);
  38. sprintf(result, "[%04d-%02d-%02d %02d:%02d:%02d]", (1900+p->tm_year), (1+p->tm_mon), p->tm_mday, p->tm_hour, p->tm_hour, p->tm_sec);
  39. return result;
  40. }
  41. void PRINTF_FUNC(char *string, ...)
  42. {
  43. if (DEBUG)
  44. {
  45. va_list args;
  46. char buffer[4096];
  47. va_start(args, string);
  48. vsnprintf(buffer, sizeof(buffer), string, args);
  49. va_end(args);
  50. printf("%s \n", buffer);
  51. }
  52. }
  53. //==========================================
  54. // Init all share memory
  55. //==========================================
  56. int InitShareMemory()
  57. {
  58. int result = PASS;
  59. int MeterSMId;
  60. //creat ShmSysConfigAndInfo
  61. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  62. {
  63. #ifdef SystemLogMessage
  64. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  65. #endif
  66. result = FAIL;
  67. }
  68. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  69. {
  70. #ifdef SystemLogMessage
  71. DEBUG_ERROR("shmat ShmSysConfigAndInfo NG\n");
  72. #endif
  73. result = FAIL;
  74. }
  75. else
  76. {}
  77. //creat ShmStatusCodeData
  78. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  79. {
  80. #ifdef SystemLogMessage
  81. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  82. #endif
  83. result = FAIL;
  84. }
  85. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  86. {
  87. #ifdef SystemLogMessage
  88. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  89. #endif
  90. result = FAIL;
  91. }
  92. else
  93. {}
  94. return result;
  95. }
  96. //==========================================
  97. // Open and Close RS232 and R/W
  98. //==========================================
  99. int CreateCommunicationLcmPort()
  100. {
  101. int fd;
  102. struct termios tios;
  103. fd = open(pPortName, O_RDWR);
  104. if (fd <= 0) {
  105. #ifdef SystemLogMessage
  106. DEBUG_ERROR("open /dev/ttyS3 NG \n");
  107. #endif
  108. return -1;
  109. }
  110. ioctl(fd, TCGETS, &tios);
  111. tios.c_cflag = B115200 | CS8 | CLOCAL | CREAD;
  112. tios.c_lflag = 0;
  113. tios.c_iflag = 0;
  114. tios.c_oflag = 0;
  115. tios.c_cc[VMIN] = 0;
  116. tios.c_cc[VTIME] = (unsigned char) 5;
  117. tios.c_lflag = 0;
  118. tcflush(fd, TCIFLUSH);
  119. ioctl(fd, TCSETS, &tios);
  120. return fd;
  121. }
  122. void CloseCommunicationLcmPort()
  123. {
  124. close(_port);
  125. }
  126. void WriteCmdToLcm(byte *cmd, byte cmdLen)
  127. {
  128. int len = write(_port, cmd, cmdLen);
  129. if(len >= sizeof(cmd))
  130. {
  131. //PRINTF_FUNC("Write cmd to LCM successfully. \n");
  132. }
  133. }
  134. void ReadMsgFromLcm(byte *msg, byte readLen)
  135. {
  136. read(_port, msg, readLen);
  137. if(*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2)
  138. {
  139. if(*(msg + 3) == CMD_WRITE)
  140. {
  141. switch (*(msg + 4))
  142. {
  143. case CMD_REGISTER:
  144. {
  145. // 頁面
  146. _currentPage = (unsigned short) (*(msg + 6) << 8) + (unsigned short) *(msg + 7);
  147. }
  148. break;
  149. }
  150. }
  151. else if (*(msg + 3) == CMD_MULTI_READ)
  152. {
  153. // switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
  154. // {
  155. // case BUTTON_GUN_INDEX:
  156. // {
  157. // // 當前選的槍號
  158. // _curGunIndex = (*(msg + 8));
  159. // }
  160. // break;
  161. // }
  162. }
  163. }
  164. // for (byte idx = 0; idx < len; idx++)
  165. // PRINTF_FUNC("[system_command]-RX: %X\n", *(msg + idx));
  166. }
  167. //================================================
  168. // Function
  169. //================================================
  170. void ChangeToOtherPage(short newPage)
  171. {
  172. byte cmd[7];
  173. memset(cmd, 0x00, sizeof(cmd));
  174. cmd[0] = CMD_TITLE_1;
  175. cmd[1] = CMD_TITLE_2;
  176. cmd[2] = 0x02 + sizeof(newPage);
  177. cmd[3] = CMD_READ;
  178. cmd[4] = CMD_REGISTER;
  179. cmd[5] = newPage >> 8;
  180. cmd[6] = newPage & 0x00FF;
  181. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  182. usleep(100000);
  183. }
  184. void ChangeBackLight(bool islight)
  185. {
  186. byte value = 0x01;
  187. if (islight)
  188. {
  189. value = 0x20;
  190. }
  191. byte cmd[7];
  192. memset(cmd, 0x00, sizeof(cmd));
  193. cmd[0] = CMD_TITLE_1;
  194. cmd[1] = CMD_TITLE_2;
  195. cmd[2] = 0x03;
  196. cmd[3] = CMD_READ;
  197. cmd[4] = CMD_BACKLIGHT;
  198. cmd[5] = value;
  199. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  200. usleep(100000);
  201. }
  202. void GetCurrentPage()
  203. {
  204. byte cmd[6];
  205. memset(cmd, 0x00, sizeof(cmd));
  206. byte msg[8];
  207. memset(msg, 0x00, sizeof(msg));
  208. cmd[0] = CMD_TITLE_1;
  209. cmd[1] = CMD_TITLE_2;
  210. cmd[2] = 0x03; // 底下總長度
  211. cmd[3] = CMD_WRITE;
  212. cmd[4] = CMD_REGISTER;
  213. cmd[5] = 0x02;
  214. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  215. usleep(100000);
  216. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  217. }
  218. void DisplayValueToLcm(short address, byte *data, byte len)
  219. {
  220. byte cmd[256];
  221. memset(cmd, 0x00, sizeof(cmd));
  222. cmd[0] = CMD_TITLE_1;
  223. cmd[1] = CMD_TITLE_2;
  224. cmd[2] = 0x03 + len;
  225. cmd[3] = CMD_MULTI_WRITE;
  226. cmd[4] = address >> 8;
  227. cmd[5] = address & 0x00FF;
  228. for(byte count = 0; count < len; count++)
  229. {
  230. cmd[6 + count] = *(data + count);
  231. }
  232. WriteCmdToLcm(cmd, cmd[2] + 3);
  233. }
  234. void ChangeDisplay2Value(short address, short value)
  235. {
  236. byte data[2];
  237. data[0] = value >> 8;
  238. data[1] = value & 0x00FF;
  239. DisplayValueToLcm(address, data, sizeof(data));
  240. }
  241. void GetBtnStatus(short address, byte len)
  242. {
  243. byte cmd[8];
  244. memset(cmd, 0x00, sizeof(cmd));
  245. byte msg[8];
  246. memset(msg, 0x00, sizeof(msg));
  247. cmd[0] = CMD_TITLE_1;
  248. cmd[1] = CMD_TITLE_2;
  249. cmd[2] = 0x03 + len;
  250. cmd[3] = CMD_MULTI_READ;
  251. cmd[4] = address >> 8;
  252. cmd[5] = address & 0x00FF;
  253. cmd[6] = 0x00 + len;
  254. WriteCmdToLcm(cmd, cmd[2] + 3);
  255. usleep(100000);
  256. ReadMsgFromLcm(msg, (len * 2) + sizeof(msg));
  257. }
  258. //================================================
  259. // Warning process
  260. //================================================
  261. void string2ByteArray(unsigned char *input, byte *output)
  262. {
  263. int loop;
  264. int i;
  265. loop = 0;
  266. i = 0;
  267. while(input[loop] != '\0')
  268. {
  269. output[i++] = input[loop++];
  270. }
  271. output[loop] = '\0';
  272. }
  273. void ChangeWarningFunc()
  274. {
  275. byte cmd[7];
  276. byte i = 0;
  277. //PRINTF_FUNC("ChangeWarningFunc \n");
  278. // 最多一次五筆
  279. //PRINTF_FUNC("LCM PageIndex = %d \n", ShmSysConfigAndInfo->SysWarningInfo.PageIndex);
  280. //PRINTF_FUNC("WarningCount = %d \n", ShmSysConfigAndInfo->SysWarningInfo.WarningCount);
  281. for(i = 0; (i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5) < ShmSysConfigAndInfo->SysWarningInfo.WarningCount; i++)
  282. {
  283. memset(cmd, 0x00, sizeof(cmd));
  284. if(i >= 5)
  285. {
  286. break;
  287. }
  288. //error code
  289. string2ByteArray(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5][0], cmd);
  290. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  291. //警告標示
  292. memset(cmd, 0x00, sizeof(cmd));
  293. cmd[0] = 0x00;
  294. cmd[1] = 0x01;
  295. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  296. }
  297. memset(cmd, 0x00, sizeof(cmd));
  298. for(; i < 5; i++)
  299. {
  300. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  301. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  302. }
  303. }
  304. //================================================
  305. // QR Code process
  306. //================================================
  307. void ChangeQrCode_Idle(char *input)
  308. {
  309. int len = strlen(input);
  310. byte cmd[len];
  311. int loop = 0;
  312. int i = 0;
  313. while(input[loop] != '\0')
  314. {
  315. cmd[i++] = input[loop++];
  316. }
  317. DisplayValueToLcm(__qr_code, cmd, len);
  318. }
  319. void ChangeQrCode_Charge(char *input)
  320. {
  321. int len = strlen(input);
  322. byte cmd[len];
  323. int loop = 0;
  324. int i = 0;
  325. while(input[loop] != '\0')
  326. {
  327. cmd[i++] = input[loop++];
  328. }
  329. DisplayValueToLcm(__qr_code_pre, cmd, len);
  330. }
  331. //================================================
  332. // Change current page
  333. //================================================
  334. void ChangeCurPage()
  335. {
  336. //PRINTF_FUNC("cur = %d, new = %d \n", _currentPage, ShmSysConfigAndInfo->SysInfo.PageIndex);
  337. if (_currentPage != ShmSysConfigAndInfo->SysInfo.PageIndex)
  338. {
  339. _currentPage = ShmSysConfigAndInfo->SysInfo.PageIndex;
  340. ChangeToOtherPage(_currentPage);
  341. _everyPageRollChange = 0;
  342. }
  343. }
  344. //================================================
  345. // Main process
  346. //================================================
  347. byte demoCount = 0;
  348. void DemoFunction()
  349. {
  350. if (demoCount == 0)
  351. {
  352. ShmSysConfigAndInfo->SysWarningInfo.WarningCount = 6;
  353. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[0][0], "000001", 7);
  354. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[1][0], "000002", 7);
  355. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[2][0], "000003", 7);
  356. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[3][0], "000004", 7);
  357. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[4][0], "000005", 7);
  358. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[5][0], "000006", 7);
  359. }
  360. else
  361. {
  362. if (demoCount == 20) {
  363. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_IDLE;
  364. } else if (demoCount == 80) {
  365. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZING;
  366. } else if (demoCount == 100) {
  367. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_COMP;
  368. } else if (demoCount == 120) {
  369. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_FAIL;
  370. } else if (demoCount == 140) {
  371. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_PRE_CHARGE;
  372. } else if (demoCount == 180) {
  373. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_CHARGING;
  374. }
  375. }
  376. if (demoCount < 180)
  377. demoCount++;
  378. }
  379. //================================================
  380. // Main process
  381. //================================================
  382. bool FindChargingInfoData(byte target, struct ChargingInfoData **_chargingData)
  383. {
  384. for (byte index = 0; index < CHAdeMO_QUANTITY; index++)
  385. {
  386. if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target)
  387. {
  388. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index];
  389. return true;
  390. }
  391. }
  392. for (byte index = 0; index < CCS_QUANTITY; index++)
  393. {
  394. if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target)
  395. {
  396. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index];
  397. return true;
  398. }
  399. }
  400. for (byte index = 0; index < GB_QUANTITY; index++)
  401. {
  402. if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target)
  403. {
  404. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index];
  405. return true;
  406. }
  407. }
  408. return false;
  409. }
  410. void ChangeBattMapAndValue(short page, int soc)
  411. {
  412. // srand(time(NULL));
  413. // int min = 10;
  414. // int max = 90;
  415. // soc = rand() % (max - min + 1) + min;
  416. if (page == _LCM_CHARGING)
  417. {
  418. if (soc < 20)
  419. ChangeDisplay2Value(__batt_map, _battery_cap_20);
  420. else if (soc >= 20 && soc < 40)
  421. ChangeDisplay2Value(__batt_map, _battery_cap_40);
  422. else if (soc >= 40 && soc < 60)
  423. ChangeDisplay2Value(__batt_map, _battery_cap_60);
  424. else if (soc >= 60 && soc < 80)
  425. ChangeDisplay2Value(__batt_map, _battery_cap_80);
  426. else if (soc >= 80 && soc <= 100)
  427. ChangeDisplay2Value(__batt_map, _battery_cap_100);
  428. }
  429. else if (page == _LCM_COMPLETE)
  430. {
  431. if (soc < 20)
  432. ChangeDisplay2Value(__batt_map, _battery_soc_20);
  433. else if (soc >= 20 && soc < 40)
  434. ChangeDisplay2Value(__batt_map, _battery_soc_40);
  435. else if (soc >= 40 && soc < 60)
  436. ChangeDisplay2Value(__batt_map, _battery_soc_60);
  437. else if (soc >= 60 && soc < 80)
  438. ChangeDisplay2Value(__batt_map, _battery_soc_80);
  439. else if (soc >= 80 && soc <= 100)
  440. ChangeDisplay2Value(__batt_map, _battery_soc_100);
  441. }
  442. byte cmd[4];
  443. byte value[4];
  444. memset(cmd, 0x00, sizeof(cmd));
  445. sprintf((char *)value, "%d%%", soc);
  446. string2ByteArray(value, cmd);
  447. DisplayValueToLcm(__soc_value_charging, cmd, sizeof(cmd));
  448. }
  449. void ChangeRemainTime(int sec)
  450. {
  451. int h, m, s;
  452. byte cmd[10];
  453. byte value[10];
  454. memset(cmd, 0x00, sizeof(cmd));
  455. // srand(time(NULL));
  456. // int min = 0;
  457. // int max = 65536;
  458. // sec = rand() % (max - min + 1) + min;
  459. h = (sec / 3600);
  460. m = (sec - (3600 * h)) / 60;
  461. s = (sec - (3600 * h) - (m * 60));
  462. sprintf((char *)value, "%02d:%02d:%02d", h, m, s);
  463. string2ByteArray(value, cmd);
  464. DisplayValueToLcm(__remain_time_tx, cmd, sizeof(cmd));
  465. }
  466. void ChangeChargingEnergyValue(float energy)
  467. {
  468. byte cmd[10];
  469. byte value[10];
  470. memset(cmd, 0x00, sizeof(cmd));
  471. sprintf((char *) value, "%.1f kWh", energy);
  472. string2ByteArray(value, cmd);
  473. DisplayValueToLcm(__total_out_eng_tx, cmd, sizeof(cmd));
  474. }
  475. void ChangeChargingPowerValue(float pow)
  476. {
  477. byte cmd[10];
  478. byte value[10];
  479. memset(cmd, 0x00, sizeof(cmd));
  480. // float min = 0.0;
  481. // float max = 50;
  482. // pow = (max - min) * rand() / (RAND_MAX + 1.0) + min;
  483. sprintf((char *) value, "%.1f kW", pow);
  484. string2ByteArray(value, cmd);
  485. DisplayValueToLcm(__output_eng_tx, cmd, sizeof(cmd));
  486. }
  487. void ChangeStopMap(byte value)
  488. {
  489. }
  490. void RefreshPageAnimation(byte value)
  491. {
  492. switch(_currentPage)
  493. {
  494. case _LCM_IDLE:
  495. {
  496. if (value == 0)
  497. {
  498. ChangeToOtherPage(_currentPage);
  499. }
  500. else if (value == 15)
  501. {
  502. ChangeToOtherPage(_currentPage + 1);
  503. }
  504. else if (value == 30)
  505. {
  506. ChangeToOtherPage(_currentPage + 2);
  507. }
  508. _everyPageRollChange > 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  509. }
  510. break;
  511. case _LCM_WAIT_FOR_PLUG:
  512. {
  513. if(_everyPageRollChange == 0)
  514. ChangeDisplay2Value(__plug_in_arrow, _arrow_dark);
  515. else if(_everyPageRollChange == 15)
  516. ChangeDisplay2Value(__plug_in_arrow, _arrow_light);
  517. _everyPageRollChange > 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  518. }
  519. break;
  520. case _LCM_PRE_CHARGE:
  521. case _LCM_CHARGING:
  522. case _LCM_COMPLETE:
  523. {
  524. if (_currentPage == _LCM_PRE_CHARGE)
  525. {
  526. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  527. ChangeDisplay2Value(__conn_line, _conn_map1);
  528. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  529. ChangeDisplay2Value(__conn_line, _conn_map2);
  530. }
  531. else if (_currentPage == _LCM_CHARGING)
  532. {
  533. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  534. ChangeDisplay2Value(__conn_line_chag, _charging_map1);
  535. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  536. ChangeDisplay2Value(__conn_line_chag, _charging_map2);
  537. }
  538. else if (_currentPage == _LCM_COMPLETE)
  539. {
  540. if (_everyPageRollChange == 0)
  541. ChangeDisplay2Value(__conn_line_comp, _complete_map);
  542. }
  543. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  544. {
  545. byte index = 0;
  546. for (index = 0; index < _totalCount; index++) {
  547. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  548. {
  549. break;
  550. }
  551. }
  552. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  553. if (_chargingInfoData[index]->SystemStatus == S_IDLE ||
  554. _chargingInfoData[index]->SystemStatus == S_RESERVATION)
  555. {
  556. if(value == 0)
  557. {
  558. ChangeDisplay2Value(__side_top, _side_rfid_1);
  559. ChangeDisplay2Value(__side_down, _side_rfid_2);
  560. }
  561. else if (value == 15)
  562. {
  563. ChangeDisplay2Value(__side_top, _side_qr_1);
  564. ChangeDisplay2Value(__side_down, _side_qr_2);
  565. }
  566. else if (value == 30)
  567. {
  568. ChangeDisplay2Value(__side_top, _side_app_1);
  569. ChangeDisplay2Value(__side_down, _side_app_2);
  570. }
  571. }
  572. else
  573. {
  574. ChangeDisplay2Value(__side_top, _disappear);
  575. ChangeDisplay2Value(__side_down, _disappear);
  576. ChangeDisplay2Value(__qr_code_pre, _disappear);
  577. }
  578. }
  579. else
  580. {
  581. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  582. ChangeDisplay2Value(__side_top, _disappear);
  583. ChangeDisplay2Value(__side_down, _disappear);
  584. ChangeDisplay2Value(__qr_code_pre, _disappear);
  585. }
  586. _everyPageRollChange >= 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  587. }
  588. break;
  589. }
  590. }
  591. void RefreshConnStatus()
  592. {
  593. // Wifi priority is higher than Ethernet
  594. if (ShmSysConfigAndInfo->SysConfig.AthInterface.WifiNetworkConn == YES)
  595. {
  596. _wifi_conn_status = true;
  597. ChangeDisplay2Value(__wifi_status, _wifi_connect);
  598. ChangeDisplay2Value(__ethernet_status, _disappear);
  599. }
  600. else
  601. {
  602. _wifi_conn_status = false;
  603. ChangeDisplay2Value(__wifi_status, _disappear);
  604. }
  605. if (!_wifi_conn_status)
  606. {
  607. if (ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomNetworkConn == YES)
  608. {
  609. ChangeDisplay2Value(__ethernet_status, _ethernet_connect);
  610. }
  611. else
  612. {
  613. ChangeDisplay2Value(__ethernet_status, _ethernet_disconnect);
  614. }
  615. }
  616. // 連線到後台
  617. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES)
  618. ChangeDisplay2Value(__conn_status, _connect);
  619. else
  620. ChangeDisplay2Value(__conn_status, _disconnect);
  621. }
  622. void ProcessPageInfo()
  623. {
  624. switch(_currentPage)
  625. {
  626. case _LCM_IDLE:
  627. {
  628. // QR Code 處理
  629. ChangeQrCode_Idle("http://google.com.tw");
  630. }
  631. break;
  632. case _LCM_PRE_CHARGE:
  633. case _LCM_CHARGING:
  634. case _LCM_COMPLETE:
  635. {
  636. // gun type and charging info
  637. for(byte i = 0; i < _totalCount; i++)
  638. {
  639. switch(_chargingInfoData[i]->Type)
  640. {
  641. case _Type_Chademo:
  642. {
  643. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  644. {
  645. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_light);
  646. }
  647. else
  648. {
  649. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_dark);
  650. }
  651. }
  652. break;
  653. case _Type_CCS_2:
  654. {
  655. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  656. {
  657. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_light);
  658. }
  659. else
  660. {
  661. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_dark);
  662. }
  663. }
  664. break;
  665. }
  666. if (_currentPage == _LCM_CHARGING)
  667. {
  668. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  669. {
  670. ChangeBattMapAndValue(_LCM_CHARGING, _chargingInfoData[i]->EvBatterySoc);
  671. if (_chargingInfoData[i]->RemainChargingDuration >= 0)
  672. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  673. if (_chargingInfoData[i]->PresentChargingPower >= 0)
  674. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  675. if (_chargingInfoData[i]->PresentChargedEnergy >= 0)
  676. ChangeChargingEnergyValue(_chargingInfoData[i]->PresentChargedEnergy);
  677. if (strcmp((char *)_chargingInfoData[i]->StartUserId, "") == 0)
  678. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn);
  679. else
  680. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn_scan);
  681. }
  682. }
  683. else if (_currentPage == _LCM_COMPLETE)
  684. {
  685. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  686. {
  687. ChangeBattMapAndValue(_LCM_COMPLETE, _chargingInfoData[i]->EvBatterySoc);
  688. if (_chargingInfoData[i]->RemainChargingDuration >= 0)
  689. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  690. if (_chargingInfoData[i]->PresentChargingPower >= 0)
  691. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  692. if (_chargingInfoData[i]->PresentChargedEnergy >= 0)
  693. ChangeChargingEnergyValue(_chargingInfoData[i]->PresentChargedEnergy);
  694. }
  695. }
  696. }
  697. // gun btn and QR code
  698. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  699. {
  700. byte index = 0;
  701. for(index = 0; index < _totalCount; index++)
  702. {
  703. if(ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  704. {
  705. break;
  706. }
  707. }
  708. if (_chargingInfoData[index]->SystemStatus == S_IDLE ||
  709. _chargingInfoData[index]->SystemStatus == S_RESERVATION ||
  710. _chargingInfoData[index]->SystemStatus == S_BOOTING)
  711. {
  712. // QR Code 處理
  713. ChangeQrCode_Charge("http://google.com.tw");
  714. }
  715. }
  716. }
  717. break;
  718. }
  719. }
  720. void Initialization()
  721. {
  722. strcpy((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, moduleName);
  723. bool isPass = false;
  724. byte count = 5;
  725. while(!isPass && count > 0)
  726. {
  727. isPass = true;
  728. for (byte _index = 0; _index < _totalCount; _index++)
  729. {
  730. if (!FindChargingInfoData(_index, &_chargingInfoData[0]))
  731. {
  732. DEBUG_ERROR("EvComm (main) : FindChargingInfoData false \n");
  733. isPass = false;
  734. count--;
  735. break;
  736. }
  737. }
  738. }
  739. if (count == 0)
  740. PRINTF_FUNC("LCM Initialization Gun Fail.............\n");
  741. }
  742. int main(void)
  743. {
  744. if(InitShareMemory() == FAIL)
  745. {
  746. #ifdef SystemLogMessage
  747. DEBUG_ERROR("InitShareMemory NG\n");
  748. #endif
  749. if (ShmStatusCodeData != NULL)
  750. {
  751. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  752. }
  753. sleep(5);
  754. return 0;
  755. }
  756. _port = CreateCommunicationLcmPort();
  757. byte changeWarningPriority = 0;
  758. byte curWarningCount = 255;
  759. //ChangeBackLight(true);
  760. Initialization();
  761. // ChangeToOtherPage(_LCM_FIX);
  762. // return 0;
  763. while(_port != -1)
  764. {
  765. //DemoFunction();
  766. // Warning 處理
  767. if(curWarningCount != ShmSysConfigAndInfo->SysWarningInfo.WarningCount)
  768. {
  769. changeWarningPriority = 0;
  770. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  771. curWarningCount = ShmSysConfigAndInfo->SysWarningInfo.WarningCount;
  772. ChangeWarningFunc();
  773. }
  774. else if (ShmSysConfigAndInfo->SysWarningInfo.WarningCount > 5 && changeWarningPriority == 0)
  775. {
  776. // 當有兩頁 Warning 則每隔三秒改變一次
  777. if(ShmSysConfigAndInfo->SysWarningInfo.PageIndex == 0)
  778. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 1;
  779. else
  780. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  781. ChangeWarningFunc();
  782. }
  783. // 頁面資訊處理
  784. ProcessPageInfo();
  785. // 網路 - wifi - 連線訊號處理
  786. RefreshConnStatus();
  787. // 換頁處理
  788. ChangeCurPage();
  789. RefreshPageAnimation(_everyPageRollChange);
  790. changeWarningPriority >= 30 ? changeWarningPriority = 0 : changeWarningPriority++;
  791. usleep(100000);
  792. }
  793. CloseCommunicationLcmPort();
  794. return FAIL;
  795. }