Module_LcmControl.c 20 KB

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