Module_LcmControl.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  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. h = (sec / 3600);
  447. m = (sec - (3600 * h)) / 60;
  448. s = (sec - (3600 * h) - (m * 60));
  449. sprintf((char *)value, "%02d:%02d:%02d", h, m, s);
  450. string2ByteArray(value, cmd);
  451. DisplayValueToLcm(__remain_time_tx, cmd, sizeof(cmd));
  452. }
  453. void ChangeChargingPowerValue(float pow)
  454. {
  455. byte cmd[10];
  456. byte value[10];
  457. memset(cmd, 0x00, sizeof(cmd));
  458. // float min = 0.0;
  459. // float max = 50;
  460. // pow = (max - min) * rand() / (RAND_MAX + 1.0) + min;
  461. sprintf((char *) value, "%.1f kW", pow);
  462. string2ByteArray(value, cmd);
  463. DisplayValueToLcm(__output_eng_tx, cmd, sizeof(cmd));
  464. }
  465. void RefreshPageAnimation(byte value)
  466. {
  467. switch(_currentPage)
  468. {
  469. case _LCM_IDLE:
  470. {
  471. if (value == 0)
  472. {
  473. ChangeToOtherPage(_currentPage);
  474. }
  475. else if (value == 15)
  476. {
  477. ChangeToOtherPage(_currentPage + 1);
  478. }
  479. else if (value == 30)
  480. {
  481. ChangeToOtherPage(_currentPage + 2);
  482. }
  483. _everyPageRollChange > 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  484. }
  485. break;
  486. case _LCM_WAIT_FOR_PLUG:
  487. {
  488. if(_everyPageRollChange == 0)
  489. ChangeDisplay2Value(__plug_in_arrow, _arrow_dark);
  490. else if(_everyPageRollChange == 15)
  491. ChangeDisplay2Value(__plug_in_arrow, _arrow_light);
  492. _everyPageRollChange > 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  493. }
  494. break;
  495. case _LCM_PRE_CHARGE:
  496. case _LCM_CHARGING:
  497. case _LCM_COMPLETE:
  498. {
  499. if (_currentPage == _LCM_PRE_CHARGE)
  500. {
  501. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  502. ChangeDisplay2Value(__conn_line, _conn_map1);
  503. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  504. ChangeDisplay2Value(__conn_line, _conn_map2);
  505. }
  506. else if (_currentPage == _LCM_CHARGING)
  507. {
  508. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  509. ChangeDisplay2Value(__conn_line_chag, _charging_map1);
  510. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  511. ChangeDisplay2Value(__conn_line_chag, _charging_map2);
  512. }
  513. else if (_currentPage == _LCM_COMPLETE)
  514. {
  515. if (_everyPageRollChange == 0)
  516. ChangeDisplay2Value(__conn_line_comp, _complete_map);
  517. }
  518. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  519. {
  520. byte index = 0;
  521. for (index = 0; index < _totalCount; index++) {
  522. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  523. {
  524. break;
  525. }
  526. }
  527. if (_chargingInfoData[index]->SystemStatus == S_IDLE)
  528. {
  529. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  530. if(value == 0)
  531. {
  532. ChangeDisplay2Value(__side_top, _side_rfid_1);
  533. ChangeDisplay2Value(__side_down, _side_rfid_2);
  534. }
  535. else if (value == 15)
  536. {
  537. ChangeDisplay2Value(__side_top, _side_qr_1);
  538. ChangeDisplay2Value(__side_down, _side_qr_2);
  539. }
  540. else if (value == 30)
  541. {
  542. ChangeDisplay2Value(__side_top, _side_app_1);
  543. ChangeDisplay2Value(__side_down, _side_app_2);
  544. }
  545. }
  546. else
  547. {
  548. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  549. ChangeDisplay2Value(__side_top, _disappear);
  550. ChangeDisplay2Value(__side_down, _disappear);
  551. ChangeDisplay2Value(__qr_code_pre, _disappear);
  552. }
  553. }
  554. else
  555. {
  556. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  557. ChangeDisplay2Value(__side_top, _disappear);
  558. ChangeDisplay2Value(__side_down, _disappear);
  559. ChangeDisplay2Value(__qr_code_pre, _disappear);
  560. }
  561. _everyPageRollChange >= 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  562. }
  563. break;
  564. }
  565. }
  566. void RefreshConnStatus()
  567. {
  568. // Wifi priority is higher than Ethernet
  569. if (ShmSysConfigAndInfo->SysConfig.AthInterface.WifiNetworkConn == 0x01)
  570. {
  571. if (!_wifi_conn_status)
  572. {
  573. _wifi_conn_status = true;
  574. ChangeDisplay2Value(__wifi_status, _wifi_connect);
  575. ChangeDisplay2Value(__ethernet_status, _disappear);
  576. }
  577. }
  578. else
  579. {
  580. if(_wifi_conn_status)
  581. {
  582. _wifi_conn_status = false;
  583. ChangeDisplay2Value(__wifi_status, _disappear);
  584. }
  585. }
  586. if (!_wifi_conn_status)
  587. {
  588. if (ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomNetworkConn == PASS)
  589. {
  590. if(!_net_conn_status)
  591. {
  592. _net_conn_status = true;
  593. ChangeDisplay2Value(__ethernet_status, _ethernet_connect);
  594. }
  595. }
  596. else
  597. {
  598. if(_net_conn_status)
  599. {
  600. _net_conn_status = false;
  601. ChangeDisplay2Value(__ethernet_status, _ethernet_disconnect);
  602. }
  603. }
  604. }
  605. // 連線到後台
  606. }
  607. void ProcessPageInfo()
  608. {
  609. switch(_currentPage)
  610. {
  611. case _LCM_IDLE:
  612. {
  613. // QR Code 處理
  614. ChangeQrCode_Idle("http://google.com.tw");
  615. }
  616. break;
  617. case _LCM_PRE_CHARGE:
  618. case _LCM_CHARGING:
  619. case _LCM_COMPLETE:
  620. {
  621. // gun type and charging info
  622. for(byte i = 0; i < _totalCount; i++)
  623. {
  624. switch(_chargingInfoData[i]->Type)
  625. {
  626. case _Type_Chademo:
  627. {
  628. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  629. {
  630. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_light);
  631. }
  632. else
  633. {
  634. ChangeDisplay2Value(__gun_type_index + (i * 2), _chademo_dark);
  635. }
  636. }
  637. break;
  638. case _Type_CCS:
  639. {
  640. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  641. {
  642. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_light);
  643. }
  644. else
  645. {
  646. ChangeDisplay2Value(__gun_type_index + (i * 2), _ccs_dark);
  647. }
  648. }
  649. break;
  650. }
  651. if (_currentPage == _LCM_CHARGING)
  652. {
  653. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  654. {
  655. ChangeBattMapAndValue(_LCM_CHARGING, _chargingInfoData[i]->EvBatterySoc);
  656. if (_chargingInfoData[i]->RemainChargingDuration < 0)
  657. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  658. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  659. }
  660. }
  661. else if (_currentPage == _LCM_COMPLETE)
  662. {
  663. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  664. {
  665. ChangeBattMapAndValue(_LCM_COMPLETE, _chargingInfoData[i]->EvBatterySoc);
  666. if (_chargingInfoData[i]->RemainChargingDuration < 0)
  667. ChangeRemainTime(_chargingInfoData[i]->RemainChargingDuration);
  668. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  669. }
  670. }
  671. }
  672. // gun btn and QR code
  673. if (_totalCount == 2 && _currentPage != _LCM_PRE_CHARGE)
  674. {
  675. byte index = 0;
  676. for(index = 0; index < _totalCount; index++)
  677. {
  678. if(ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  679. {
  680. break;
  681. }
  682. }
  683. if (_chargingInfoData[index]->SystemStatus == S_IDLE || _chargingInfoData[index]->SystemStatus == S_BOOTING)
  684. {
  685. // QR Code 處理
  686. ChangeQrCode_Charge("http://google.com.tw");
  687. }
  688. else
  689. {
  690. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  691. }
  692. }
  693. }
  694. break;
  695. }
  696. }
  697. void Initialization()
  698. {
  699. strcpy((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, moduleName);
  700. bool isPass = false;
  701. byte count = 5;
  702. while(!isPass && count > 0)
  703. {
  704. isPass = true;
  705. for (byte _index = 0; _index < _totalCount; _index++)
  706. {
  707. if (!FindChargingInfoData(_index, &_chargingInfoData[0]))
  708. {
  709. DEBUG_ERROR("EvComm (main) : FindChargingInfoData false \n");
  710. isPass = false;
  711. count--;
  712. break;
  713. }
  714. }
  715. }
  716. if (count == 0)
  717. printf("LCM Initialization Gun Fail.............\n");
  718. }
  719. int main(void)
  720. {
  721. if(InitShareMemory() == FAIL)
  722. {
  723. #ifdef SystemLogMessage
  724. DEBUG_ERROR("InitShareMemory NG\n");
  725. #endif
  726. if (ShmStatusCodeData != NULL)
  727. {
  728. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  729. }
  730. sleep(5);
  731. return 0;
  732. }
  733. _port = CreateCommunicationLcmPort();
  734. byte changeWarningPriority = 0;
  735. byte curWarningCount = 255;
  736. //ChangeBackLight(true);
  737. Initialization();
  738. while(_port != -1)
  739. {
  740. //DemoFunction();
  741. // Warning 處理
  742. if(curWarningCount != ShmSysConfigAndInfo->SysWarningInfo.WarningCount)
  743. {
  744. changeWarningPriority = 0;
  745. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  746. curWarningCount = ShmSysConfigAndInfo->SysWarningInfo.WarningCount;
  747. ChangeWarningFunc();
  748. }
  749. else if (ShmSysConfigAndInfo->SysWarningInfo.WarningCount > 5 && changeWarningPriority == 0)
  750. {
  751. // 當有兩頁 Warning 則每隔三秒改變一次
  752. if(ShmSysConfigAndInfo->SysWarningInfo.PageIndex == 0)
  753. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 1;
  754. else
  755. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  756. ChangeWarningFunc();
  757. }
  758. // 頁面資訊處理
  759. ProcessPageInfo();
  760. // 網路 - wifi - 連線訊號處理
  761. RefreshConnStatus();
  762. // 換頁處理
  763. ChangeCurPage();
  764. RefreshPageAnimation(_everyPageRollChange);
  765. changeWarningPriority >= 30 ? changeWarningPriority = 0 : changeWarningPriority++;
  766. usleep(100000);
  767. }
  768. CloseCommunicationLcmPort();
  769. return FAIL;
  770. }