Module_LcmControl.c 72 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056
  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. #include "../CSU/main.h"
  18. #include "../timeout.h"
  19. #define uSEC_VAL (1000000)
  20. //------------------------------------------------------------------------------
  21. //struct SysConfigAndInfo *ShmSysConfigAndInfo;
  22. //struct StatusCodeData *ShmStatusCodeData;
  23. static struct SysConfigData *pSysConfig = NULL;
  24. static struct SysInfoData *pSysInfo = NULL;
  25. static struct WARNING_CODE_INFO *pSysWarning = NULL;
  26. static struct OCPP16Data *ShmOCPP16Data = NULL;
  27. static struct FanModuleData *ShmFanModuleData;
  28. static struct PrimaryMcuData *ShmPrimaryMcuData;
  29. static SelectGunInfo *ShmSelectGunInfo = NULL;
  30. static struct ChargingInfoData *pDcChargingInfo = NULL;
  31. static DcCommonInfo *ShmDcCommonData = NULL;
  32. //int CardReadFd = -1;
  33. short _currentPage = _PAGE_NONE;
  34. uint8_t _totalCount;
  35. uint8_t _showInformIndex = 0;
  36. float ChargeMaxPower_0 = 0;
  37. float ChargeMaxPower_1 = 0;
  38. bool _battery_display_ani = false;
  39. int _port;
  40. //char* pPortName = "/dev/ttyO2";
  41. char *pPortName = "/dev/ttyS3";
  42. char *moduleName = "DMT80480T070_09WT";
  43. bool is_show = false;
  44. bool is_stop = false;
  45. uint8_t _everyPageRollChange;
  46. uint8_t _btn_press = 0;
  47. short _btn_press_id = 0;
  48. uint8_t _btn_press_count = 0;
  49. int _Text_Running_Count = 1;
  50. int Battery_Test = 0;
  51. extern void UpdateLcmFunction(DcCommonInfo *ShmDcCommonData,int _lcmport);
  52. //==========================================
  53. // Open and Close RS232 and R/W
  54. //==========================================
  55. void AuthorizingStart(void)
  56. {
  57. ShmOCPP16Data->SpMsg.bits.AuthorizeReq = YES;
  58. pSysInfo->AuthorizeFlag = YES;
  59. }
  60. void GetClockTime(struct timespec *_now_time, void *null)
  61. {
  62. clock_gettime(CLOCK_MONOTONIC, _now_time);
  63. }
  64. void StartSystemTimeoutDet(uint8_t flag)
  65. {
  66. if (pSysInfo->SystemTimeoutFlag != flag) {
  67. GetClockTime(&pSysInfo->SystemTimeoutTimer, NULL);
  68. }
  69. pSysInfo->SystemTimeoutFlag = flag;
  70. }
  71. void StopSystemTimeoutDet(void)
  72. {
  73. GetClockTime(&pSysInfo->SystemTimeoutTimer, NULL);
  74. pSysInfo->SystemTimeoutFlag = Timeout_None;
  75. }
  76. void StartGunInfoTimeoutDet(uint8_t gunIndex, uint8_t flag)
  77. {
  78. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
  79. if (gunIndex < pSysConfig->TotalConnectorCount) {
  80. if (pDcChargingInfo->TimeoutFlag != flag) {
  81. GetClockTime(&pDcChargingInfo->ConnectorTimeout, NULL);
  82. }
  83. pDcChargingInfo->TimeoutFlag = flag;
  84. }
  85. }
  86. void StopGunInfoTimeoutDet(uint8_t gunIndex)
  87. {
  88. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
  89. if (gunIndex < pSysConfig->TotalConnectorCount) {
  90. pDcChargingInfo->TimeoutFlag = Timeout_None;
  91. }
  92. }
  93. unsigned long GetClockTimeoutValue(struct timespec _start_time)
  94. {
  95. struct timespec ts_end;
  96. unsigned long ret = 0;
  97. clock_gettime(CLOCK_MONOTONIC, &ts_end);
  98. ret = ((unsigned long)(ts_end.tv_sec - _start_time.tv_sec) * 1000000) + ((unsigned long)((ts_end.tv_nsec / 1000) - (_start_time.tv_nsec/ 1000)));
  99. return ret;
  100. }
  101. int CreateCommunicationLcmPort()
  102. {
  103. int fd;
  104. struct termios tios;
  105. fd = open(pPortName, O_RDWR);
  106. if (fd <= 0) {
  107. log_error("open /dev/ttyS3 NG ");
  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] = (uint8_t) 5;
  117. tios.c_lflag = 0;
  118. tcflush(fd, TCIFLUSH);
  119. ioctl(fd, TCSETS, &tios);
  120. return fd;
  121. }
  122. bool isChargingEnd(gunIndex)
  123. {
  124. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
  125. if (pDcChargingInfo->SystemStatus == S_COMPLETE || pDcChargingInfo->SystemStatus == S_ALARM) {
  126. return TRUE;
  127. } else {
  128. return FALSE;
  129. }
  130. }
  131. void CloseCommunicationLcmPort()
  132. {
  133. close(_port);
  134. }
  135. void setSelGunWaitToAuthor(uint8_t curSel)
  136. {
  137. if (curSel == LEFT_GUN_NUM && ShmSelectGunInfo->SelGunInfo.LeftGun == SEL_GUN_CONFIRM) {
  138. ShmSelectGunInfo->SelGunInfo.LeftGun = SEL_GUN_ATHOR;
  139. log_info("setSelGunWaitToAuthor left");
  140. } else if (curSel == RIGHT_GUN_NUM && ShmSelectGunInfo->SelGunInfo.RightGun == SEL_GUN_CONFIRM) {
  141. ShmSelectGunInfo->SelGunInfo.RightGun = SEL_GUN_ATHOR;
  142. log_info("setSelGunWaitToAuthor right");
  143. }
  144. }
  145. void confirmSelGun(uint8_t selGun)
  146. {
  147. if (selGun == LEFT_GUN_NUM) {
  148. ShmSelectGunInfo->SelGunInfo.LeftGun = SEL_GUN_CONFIRM;
  149. //printf("confirmSelGun left");
  150. } else if (selGun == RIGHT_GUN_NUM) {
  151. ShmSelectGunInfo->SelGunInfo.RightGun = SEL_GUN_CONFIRM;
  152. //printf("confirmSelGun right");
  153. }
  154. //changeLcmPage(_PAGE_PLUGIN);
  155. //StartGunInfoTimeoutDet(selGun, Timeout_SelectGun);
  156. //StartSystemTimeoutDet(Timeout_ReturnViewPage);
  157. }
  158. void WriteCmdToLcm(uint8_t *cmd, uint8_t cmdLen)
  159. {
  160. int len = write(_port, cmd, cmdLen);
  161. if (len < sizeof(cmd)) {
  162. log_error("Write cmd to LCM Failure. ");
  163. }
  164. }
  165. void ReadMsgFromLcm(uint8_t* msg, uint8_t readLen)
  166. {
  167. read(_port, msg, readLen);
  168. // 5a : CMD_TITLE_1
  169. // a5 : CMD_TITLE_2
  170. // 5
  171. // 81 : CMD_WRITE
  172. // 3 : CMD_REGISTER
  173. // 2 : Data length
  174. // 0 : High byte
  175. // 1 : Low byte
  176. // printf("-------------------------------------------- \n");
  177. // printf("msg = %x \n", *msg); // A5
  178. // printf("msg = %x \n", *(msg + 1)); // 5A
  179. // printf("msg = %x \n", *(msg + 2)); // Len : [3] ~ [6] + Data Len
  180. // printf("msg = %x \n", *(msg + 3)); // cmd : 0x83
  181. // printf("msg = %x \n", *(msg + 4)); // addr : H
  182. // printf("msg = %x \n", *(msg + 5)); // addr : L
  183. // printf("msg = %x \n", *(msg + 6)); // Data Len
  184. //
  185. // printf("msg = %x \n", *(msg + 7));
  186. // printf("msg = %x \n", *(msg + 8));
  187. // printf("msg = %x \n", *(msg + 9));
  188. // printf("msg = %x \n", *(msg + 10));
  189. // printf("msg = %x \n", *(msg + 11));
  190. // printf("msg = %x \n", *(msg + 12));
  191. // printf("msg = %x \n", *(msg + 13));
  192. // printf("msg = %x \n", *(msg + 14));
  193. /*
  194. for(uint8_t i = 0 ; i<readLen+3; i++) {
  195. log_info("Read data[%d]:0x%x",i,msg[i]);
  196. }*/
  197. if (*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2)
  198. {
  199. if (*(msg + 3) == CMD_WRITE)
  200. {
  201. switch (*(msg + 4))
  202. {
  203. case CMD_REGISTER:
  204. {
  205. // 頁面
  206. if (strcmp((char*)pSysInfo->LcmHwRev, "") != EQUAL)
  207. strcpy((char*)pSysInfo->LcmHwRev, moduleName);
  208. _currentPage = *(msg + 7);
  209. log_info("Current Page:%d", _currentPage);
  210. // if (_currentPage != 1 && _currentPage != 5 && _currentPage != 6 && _currentPage != 7 && _currentPage != 8)
  211. // printf("_currentPage = %d \n", _currentPage);
  212. }
  213. break;
  214. }
  215. } else if (*(msg + 3) == CMD_MULTI_READ)
  216. {
  217. short key = ((short)(*(msg + 4) << 8) + *(msg + 5));
  218. if (strcmp((char*)pSysInfo->LcmHwRev, "") != EQUAL)
  219. strcpy((char*)pSysInfo->LcmHwRev, moduleName);
  220. if (key == 0x0014)
  221. _currentPage = *(msg + 8);
  222. if (key == 0x0031) {
  223. log_info("Get LCM Backlight change to 0x%x", *(msg + 8));
  224. }
  225. if (key >= _Touch_IDLE && key <= _Touch_Parking_Complete) {
  226. _btn_press_id = key;
  227. _btn_press = *(msg + 8);
  228. }
  229. // switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
  230. // {
  231. // case BUTTON_GUN_INDEX:
  232. // {
  233. // // 當前選的槍號
  234. // _curGunIndex = (*(msg + 8));
  235. // }
  236. // break;
  237. // }
  238. }
  239. }
  240. }
  241. void GetDeviceInfoStatus(short address, uint8_t len)
  242. {
  243. uint8_t cmd[8];
  244. memset(cmd, 0x00, sizeof(cmd));
  245. uint8_t msg[11];
  246. memset(msg, 0x00, sizeof(msg));
  247. cmd[0] = CMD_TITLE_1;
  248. cmd[1] = CMD_TITLE_2;
  249. cmd[2] = 0x04;
  250. cmd[3] = CMD_MULTI_READ;
  251. cmd[4] = (address >> 8) & 0xff;
  252. cmd[5] = (address >> 0) & 0xff;
  253. cmd[6] = len;
  254. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  255. usleep(1000);
  256. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  257. }
  258. void DisplayValueToLcm(short address, uint8_t* data, uint8_t len)
  259. {
  260. uint8_t cmd[256];
  261. memset(cmd, 0x00, sizeof(cmd));
  262. uint8_t msg[9];
  263. memset(msg, 0x00, sizeof(msg));
  264. cmd[0] = CMD_TITLE_1;
  265. cmd[1] = CMD_TITLE_2;
  266. cmd[2] = 0x03 + len;
  267. cmd[3] = CMD_MULTI_WRITE;
  268. cmd[4] = address >> 8;
  269. cmd[5] = address & 0x00FF;
  270. for (uint8_t count = 0; count < len; count++)
  271. {
  272. cmd[6 + count] = *(data + count);
  273. }
  274. WriteCmdToLcm(cmd, cmd[2] + 3);
  275. usleep(10000);
  276. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  277. }
  278. void ChangeDisplay2Value(short address, short value)
  279. {
  280. uint8_t data[2];
  281. data[0] = value >> 8;
  282. data[1] = value & 0x00FF;
  283. //log_info("Addr:0x%x, value:%d",address,value);
  284. DisplayValueToLcm(address, data, sizeof(data));
  285. }
  286. void TradeRunning(uint8_t _run)
  287. {
  288. if (_run == TRUE) {
  289. ChangeDisplay2Value(_Icon_PreAuth, 1);
  290. ChangeDisplay2Value(_Icon_Ani_Dot, 1);
  291. ChangeDisplay2Value(_Icon_CountDownBG, 0);
  292. ChangeDisplay2Value(_Icon_CancelCntDownTen, 0);
  293. ChangeDisplay2Value(_Icon_CancelCntDownDigits, 0);
  294. ChangeDisplay2Value(_Icon_PreAuthWord, _TCC_PreAuthWord);
  295. }
  296. else {
  297. ChangeDisplay2Value(_Icon_PreAuth, _TCC_TradeCancelString);
  298. ChangeDisplay2Value(_Icon_Ani_Dot, 0);
  299. ChangeDisplay2Value(_Icon_PreAuthWord, 0);
  300. ChangeDisplay2Value(_Icon_CountDownBG, _TCC_TradeCancelFrame);
  301. //log_info("SystemTimeoutFlag:%d", pSysInfo->SystemTimeoutFlag);
  302. if (pSysInfo->SystemTimeoutFlag == Timeout_TradeCancel) {
  303. unsigned long _time = TCC_TRADECANCEL_TIMEOUT-(GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL);
  304. ChangeDisplay2Value(_Icon_CancelCntDownTen, (short)(_TCC_CancelNum_0 + (_time / 10)));
  305. ChangeDisplay2Value(_Icon_CancelCntDownDigits, (short)(_TCC_CancelNum_0 + (_time % 10)));
  306. }
  307. }
  308. }
  309. static void systemPageRestoreInit(void)
  310. {
  311. int is_idle = TRUE;
  312. int gunIndex;
  313. for (gunIndex = 0; gunIndex < pSysConfig->TotalConnectorCount; gunIndex++) {
  314. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(gunIndex);
  315. // 檢查電樁狀態是否為idle狀態
  316. if ((pDcChargingInfo->SystemStatus >= S_AUTHORIZING &&
  317. pDcChargingInfo->SystemStatus <= S_RESERVATION) ||
  318. (pDcChargingInfo->SystemStatus >= S_CCS_PRECHARGE_ST0 &&
  319. pDcChargingInfo->SystemStatus <= S_CCS_PRECHARGE_ST0)) {
  320. is_idle = FALSE;
  321. }
  322. }
  323. if (is_idle)
  324. pSysInfo->SystemPage = _PAGE_IDLE;
  325. else
  326. pSysInfo->SystemPage = _PAGE_SELECT_GUN;
  327. }
  328. void CheckIdlePress()
  329. {
  330. systemPageRestoreInit();
  331. log_info("IDLE Enter Select Gun Page");
  332. }
  333. void CheckReturnPress()
  334. {
  335. int i;
  336. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  337. //pDcChargingInfo->SystemStatus = S_IDLE;
  338. if (pSysInfo->SystemPage >= _PAGE_BILL && pSysInfo->SystemPage <= _PAGE_PLUGIN ||
  339. pSysInfo->SystemPage == _PAGE_AUTHORIZE_FAIL || pSysInfo->SystemPage == _PAGE_DONATE_RIGHT) {
  340. if (pSysInfo->SystemPage == _PAGE_AUTHORIZE && ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].isParking) {
  341. log_info("Parking Status cann't press return button");
  342. return;
  343. }
  344. ShmDcCommonData->OperateIDLE[pSysInfo->CurGunSelected] = 1;
  345. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  346. ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].GetParkingBill = FALSE;
  347. ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].isParking = FALSE;
  348. log_info("Operate return to IDLE");
  349. }
  350. // Cancel Trade
  351. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  352. ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].GetParkingBill = FALSE;
  353. //if (pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
  354. log_info("Press Return button Cancel Sale");
  355. ShmDcCommonData->TradeCancel = TRUE;
  356. pSysInfo->SystemPage = _PAGE_SENSING;
  357. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  358. StartSystemTimeoutDet(Timeout_TradeCancel);
  359. for (i = 0; i <= 60; i++) {
  360. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus == _TCC_PARKING_OCCUPENCY_Ready)
  361. break;
  362. sleep(1);
  363. }
  364. //}
  365. ShmDcCommonData->TradeCancel = FALSE;
  366. StopSystemTimeoutDet();
  367. systemPageRestoreInit();
  368. return;
  369. } else if ( pDcChargingInfo->SystemStatus == S_AUTHORIZING ||
  370. ((pDcChargingInfo->SystemStatus == S_IDLE || pDcChargingInfo->SystemStatus == S_RESERVATION ) &&
  371. pSysInfo->SystemPage == _PAGE_AUTHORIZE)) {
  372. log_info("Press Return button cancel PreAuth");
  373. ShmDcCommonData->TradeCancel = TRUE;
  374. pSysInfo->SystemPage = _PAGE_SENSING;
  375. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  376. StartSystemTimeoutDet(Timeout_TradeCancel);
  377. for (i = 0; i <= 30; i++) {
  378. if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
  379. break;
  380. sleep(1);
  381. }
  382. ShmDcCommonData->PreAuth_Result = 0;
  383. ShmDcCommonData->AuthPass_flag[pSysInfo->CurGunSelected] = FALSE;
  384. if (strcmp(ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.VemData, "") != 0) {
  385. ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
  386. ShmDcCommonData->PreAuth_Result = 0;
  387. for (i = 0; i <= 30; i++) {
  388. if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
  389. break;
  390. sleep(1);
  391. }
  392. ShmDcCommonData->PreAuth_Result = 0;
  393. }
  394. StopSystemTimeoutDet();
  395. pDcChargingInfo->SystemStatus = S_IDLE;
  396. systemPageRestoreInit();
  397. strcpy((char *)pSysConfig->UserId, "");
  398. return;
  399. }
  400. if ( pSysInfo->SystemPage == _PAGE_EXIT ) {
  401. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  402. pDcChargingInfo->SystemStatus = S_IDLE;
  403. return;
  404. }
  405. if (pSysInfo->SystemPage == _PAGE_AUTHORIZE)
  406. pSysInfo->SystemPage = _PAGE_SELECT_PAY;
  407. else
  408. systemPageRestoreInit();
  409. }
  410. void CheckStopPress()
  411. {
  412. //ChangeDisplay2Value(_ConfirmStopIcon,is_stop);
  413. if (pSysInfo->CurGunSelected == LEFT_GUN_NUM)
  414. pSysInfo->SystemPage = _PAGE_STOP_CONFIRM_LEFT;
  415. else
  416. pSysInfo->SystemPage = _PAGE_STOP_CONFIRM_RIGHT;
  417. }
  418. void CheckStopConfirmPress()
  419. {
  420. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  421. pDcChargingInfo->SystemStatus = S_TERMINATING;
  422. pSysInfo->SystemPage = _PAGE_PAYING;
  423. is_stop = TRUE;
  424. /*
  425. //ShmDcCommonData->StopCharge[pSysInfo->CurGunSelected] = TRUE;
  426. if (ShmDcCommonData->is_AutoStart[pSysInfo->CurGunSelected] ||
  427. ShmDcCommonData->is_RemoteStart[pSysInfo->CurGunSelected]) {
  428. pSysInfo->SystemPage = _PAGE_COMPLETE;
  429. return;
  430. }
  431. */
  432. }
  433. void CheckStopCancelPress()
  434. {
  435. //ChangeDisplay2Value(_ConfirmStopIcon,is_stop);
  436. pSysInfo->SystemPage = _PAGE_CHARGING;
  437. is_stop = FALSE;
  438. }
  439. void CheckConfirmGun(uint8_t gunIndex)
  440. {
  441. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(gunIndex);
  442. if (pDcChargingInfo->SystemStatus == S_RESERVATION) {
  443. log_info("Reservation can't select");
  444. return;
  445. }
  446. //log_info("Confirm Gun%d",gunIndex);
  447. pSysInfo->CurGunSelected = gunIndex;
  448. if (ShmDcCommonData->pGunInfo[gunIndex].ParkingStatus) {
  449. if (pDcChargingInfo->SystemStatus == S_IDLE)
  450. ShmDcCommonData->pGunInfo[gunIndex].ReqParkingBill = TRUE;
  451. //else if (isChargingEnd(gunIndex)) {
  452. //}
  453. if (pDcChargingInfo->SystemStatus == S_COMPLETE || pDcChargingInfo->SystemStatus == S_ALARM) {
  454. if (ShmDcCommonData->PayPass_flag[gunIndex] == TRUE)
  455. pSysInfo->SystemPage = _PAGE_COMPLETE;
  456. else {
  457. if (pDcChargingInfo->Replug_flag)
  458. pSysInfo->SystemPage = _PAGE_PLUGOUT;
  459. else
  460. pSysInfo->SystemPage = _PAGE_PAYFAIL;
  461. }
  462. } else {
  463. pSysInfo->SystemPage = _PAGE_PAYING;
  464. }
  465. } else {
  466. pSysInfo->SystemPage = _PAGE_BILL;
  467. }
  468. }
  469. void CheckDonateBill(uint8_t gunIndex)
  470. {
  471. if (gunIndex == LEFT_GUN_NUM) {
  472. pSysInfo->SystemPage = _PAGE_DONATE_LEFT;
  473. } else
  474. pSysInfo->SystemPage = _PAGE_DONATE_RIGHT;
  475. }
  476. void CheckDonateYes()
  477. {
  478. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  479. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  480. StartGunInfoTimeoutDet(pSysInfo->CurGunSelected, Timeout_ParkingSelect);
  481. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].IsDonateInvoice = TRUE;
  482. } else {
  483. ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice = TRUE;
  484. }
  485. pSysInfo->SystemPage = _PAGE_SELECT_PAY;
  486. }
  487. void CheckDonateNo()
  488. {
  489. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  490. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  491. StartGunInfoTimeoutDet(pSysInfo->CurGunSelected, Timeout_ParkingSelect);
  492. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].IsDonateInvoice = FALSE;
  493. } else {
  494. StartSystemTimeoutDet(Timeout_AddLine);
  495. ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice = FALSE;
  496. }
  497. pSysInfo->SystemPage = _PAGE_BILL;
  498. }
  499. void CheckPayCreditCard()
  500. {
  501. //ShmDcCommonData->LineStatus[pSysInfo->CurGunSelected] = 0;
  502. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  503. // 使用者進入線上支付,禁止使用者使用刷卡機
  504. if (ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].LineStatus == _LINE_PAY_OPERATE ||
  505. pDcChargingInfo->SystemStatus == S_RESERVATION ) {
  506. pSysInfo->SystemPage = _PAGE_LINEPAYING;
  507. StartSystemTimeoutDet(Timeout_LINEPAYING);
  508. log_info("Some one online operate");
  509. return;
  510. }
  511. ShmDcCommonData->TradeCancel = FALSE;
  512. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  513. if ((pDcChargingInfo->SystemStatus == S_IDLE || isChargingEnd(pSysInfo->CurGunSelected)) &&
  514. ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE) {
  515. ShmDcCommonData->PreAuth_Config = _CREDITCARD_SALE;
  516. ShmDcCommonData->PreAuth_Result = 0;
  517. pSysInfo->SystemPage = _PAGE_AUTHORIZE;
  518. }
  519. } else {
  520. if ((pDcChargingInfo->SystemStatus == S_IDLE ) &&
  521. pSysInfo->SystemPage == _PAGE_SELECT_PAY &&
  522. ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE) {
  523. ShmDcCommonData->PreAuth_Config = _CREDITCARD_PREAUTH;
  524. ShmDcCommonData->PreAuth_Result = 0;
  525. pSysInfo->SystemPage = _PAGE_AUTHORIZE;
  526. //log_info("Press Credit card pay status:%d Page:%d Config:%d", pDcChargingInfo->SystemStatus,
  527. // pSysInfo->SystemPage, ShmDcCommonData->PreAuth_Config);
  528. }
  529. }
  530. }
  531. void CheckPayLinePay()
  532. {
  533. log_info("Change to Add Line Friend Page");
  534. StopSystemTimeoutDet();
  535. StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
  536. pSysInfo->SystemPage = _PAGE_ADD_FRIEND;
  537. }
  538. void CheckTouchPress(short id)
  539. {
  540. GetDeviceInfoStatus(id,1);
  541. if (_btn_press >= 1 && _btn_press_id == id ) {
  542. _btn_press_count++;
  543. }
  544. if (_btn_press >= 1 && _btn_press_id == id && _btn_press_count >= 2) {
  545. ChangeDisplay2Value(id, 0);
  546. //log_info("Press id : 0x%04x",id);
  547. _btn_press_count = 0;
  548. switch (id) {
  549. case _Touch_Show_Left:
  550. if (pSysInfo->SystemPage >= _PAGE_BILL && pSysInfo->SystemPage <= _PAGE_PLUGIN) {
  551. log_info("Authorize Process can't select gun");
  552. return;
  553. }
  554. // Show log
  555. if(pSysInfo->CurGunSelected != LEFT_GUN_NUM) {
  556. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  557. pSysInfo->CurGunSelected = LEFT_GUN_NUM;
  558. if(pDcChargingInfo->SystemStatus == S_IDLE || pDcChargingInfo->SystemStatus == S_RESERVATION) {
  559. systemPageRestoreInit();
  560. }
  561. log_info("LCM left Gun down...............................%x %x %x",
  562. pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
  563. }
  564. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  565. if (ShmDcCommonData->pGunInfo[LEFT_GUN_NUM].ParkingStatus) {
  566. if (pDcChargingInfo->SystemStatus == S_COMPLETE || pDcChargingInfo->SystemStatus == S_ALARM) {
  567. if (ShmDcCommonData->PayPass_flag[LEFT_GUN_NUM] == TRUE)
  568. pSysInfo->SystemPage = _PAGE_COMPLETE;
  569. else {
  570. if (pDcChargingInfo->Replug_flag)
  571. pSysInfo->SystemPage = _PAGE_PLUGOUT;
  572. else
  573. pSysInfo->SystemPage = _PAGE_PAYFAIL;
  574. }
  575. }
  576. }
  577. if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE ||
  578. pSysInfo->SystemPage == _PAGE_PAYFAIL) {
  579. StopSystemTimeoutDet();
  580. }
  581. break;
  582. case _Touch_Show_Right:
  583. if (pSysInfo->SystemPage >= _PAGE_BILL && pSysInfo->SystemPage <= _PAGE_PLUGIN) {
  584. log_info("Authorize Process can't select gun");
  585. return;
  586. }
  587. // Show log
  588. if(pSysInfo->CurGunSelected != RIGHT_GUN_NUM) {
  589. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  590. pSysInfo->CurGunSelected = RIGHT_GUN_NUM;
  591. if (pDcChargingInfo->SystemStatus == S_IDLE || pDcChargingInfo->SystemStatus == S_RESERVATION) {
  592. systemPageRestoreInit();
  593. }
  594. log_info("LCM Right Gun down...............................%x %x %x",
  595. pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
  596. }
  597. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  598. if (ShmDcCommonData->pGunInfo[RIGHT_GUN_NUM].ParkingStatus) {
  599. if (pDcChargingInfo->SystemStatus == S_COMPLETE || pDcChargingInfo->SystemStatus == S_ALARM) {
  600. if (ShmDcCommonData->PayPass_flag[RIGHT_GUN_NUM] == TRUE)
  601. pSysInfo->SystemPage = _PAGE_COMPLETE;
  602. else
  603. if (pDcChargingInfo->Replug_flag)
  604. pSysInfo->SystemPage = _PAGE_PLUGOUT;
  605. else
  606. pSysInfo->SystemPage = _PAGE_PAYFAIL;
  607. }
  608. }
  609. if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE ||
  610. pSysInfo->SystemPage == _PAGE_PAYFAIL) {
  611. StopSystemTimeoutDet();
  612. }
  613. break;
  614. case _Touch_Return:
  615. CheckReturnPress();
  616. break;
  617. case _Touch_IDLE:
  618. CheckIdlePress();
  619. break;
  620. case _Touch_StopCharge:
  621. CheckStopPress();
  622. break;
  623. case _Touch_Stop_Confirm:
  624. CheckStopConfirmPress();
  625. break;
  626. case _Touch_Stop_Cancel:
  627. CheckStopCancelPress();
  628. break;
  629. case _Touch_Select_Left:
  630. CheckConfirmGun(LEFT_GUN_NUM);
  631. break;
  632. case _Touch_Select_Right:
  633. CheckConfirmGun(RIGHT_GUN_NUM);
  634. break;
  635. case _Touch_DonateBill:
  636. StopSystemTimeoutDet();
  637. CheckDonateBill(pSysInfo->CurGunSelected);
  638. break;
  639. case _Touch_DonateYes:
  640. CheckDonateYes();
  641. break;
  642. case _Touch_DonateNo:
  643. CheckDonateNo();
  644. break;
  645. case _Touch_Pay_CreditCard:
  646. CheckPayCreditCard();
  647. break;
  648. case _Touch_Pay_LinePay:
  649. CheckPayLinePay();
  650. break;
  651. case _Touch_Parking_Complete:
  652. ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ReqParkingBill = TRUE;
  653. pSysInfo->SystemPage = _PAGE_PAYING;
  654. //log_info("Set Page to %d",pSysInfo->SystemPage);
  655. break;
  656. } // switch
  657. } //if (_btn_press >= 3)
  658. }
  659. void CheckLCMPressed()
  660. {
  661. pid_t Pid = fork();
  662. if ( Pid == 0 ) {
  663. while (1) {
  664. if (pSysInfo->SystemPage != _PAGE_SELECT_GUN && pSysInfo->SystemPage != _PAGE_IDLE) {
  665. CheckTouchPress(_Touch_Show_Left);
  666. CheckTouchPress(_Touch_Show_Right);
  667. }
  668. switch (pSysInfo->SystemPage) {
  669. case _PAGE_IDLE:
  670. //CheckTouchPress(_Touch_IDLE);
  671. CheckTouchPress(_Touch_Select_Left);
  672. CheckTouchPress(_Touch_Select_Right);
  673. break;
  674. case _PAGE_SELECT_GUN:
  675. CheckTouchPress(_Touch_Select_Left);
  676. CheckTouchPress(_Touch_Select_Right);
  677. break;
  678. case _PAGE_BILL:
  679. CheckTouchPress(_Touch_Return);
  680. CheckTouchPress(_Touch_DonateBill);
  681. CheckTouchPress(_Touch_Pay_LinePay);
  682. break;
  683. case _PAGE_ADD_FRIEND:
  684. CheckTouchPress(_Touch_Return);
  685. //CheckTouchPress(_Touch_DonateBill);
  686. break;
  687. case _PAGE_DONATE_LEFT:
  688. case _PAGE_DONATE_RIGHT:
  689. CheckTouchPress(_Touch_Return);
  690. CheckTouchPress(_Touch_DonateYes);
  691. CheckTouchPress(_Touch_DonateNo);
  692. break;
  693. case _PAGE_SELECT_PAY:
  694. CheckTouchPress(_Touch_Pay_CreditCard);
  695. CheckTouchPress(_Touch_Return);
  696. break;
  697. case _PAGE_PLUGIN:
  698. CheckTouchPress(_Touch_Return);
  699. break;
  700. ///*
  701. case _PAGE_CHARGING:
  702. CheckTouchPress(_Touch_StopCharge);
  703. break;
  704. case _PAGE_AUTHORIZE:
  705. CheckTouchPress(_Touch_Return);
  706. break;
  707. case _PAGE_STOP_CONFIRM_LEFT:
  708. case _PAGE_STOP_CONFIRM_RIGHT:
  709. StopSystemTimeoutDet();
  710. CheckTouchPress(_Touch_Stop_Confirm);
  711. CheckTouchPress(_Touch_Stop_Cancel);
  712. break;
  713. case _PAGE_EXIT:
  714. CheckTouchPress(_Touch_Return);
  715. break;
  716. case _PAGE_AUTHORIZE_FAIL:
  717. CheckTouchPress(_Touch_Return);
  718. break;
  719. case _PAGE_COMPLETE:
  720. case _PAGE_PAYFAIL:
  721. case _PAGE_PLUGOUT:
  722. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus >= _TCC_PARKING_OCCUPENCY)
  723. CheckTouchPress(_Touch_Parking_Complete);
  724. break;
  725. } // switch
  726. usleep(5000);
  727. } //while
  728. } // if pid
  729. log_info("Create LCM fork:%d\n\n",Pid);
  730. }
  731. void GetHrFormTimeString(char* time,char* hr)
  732. {
  733. //char tm[] = "2021-12-06 17:29:08:084";
  734. for(int i = 0 ; i < 2 ; i++) {
  735. hr[i] = time[i+11];
  736. }
  737. if( atoi(hr) < 0 || atoi(hr) > 24) {
  738. strcmp(hr,"");
  739. }
  740. }
  741. void GetMinFormTimeString(char* time,char* min)
  742. {
  743. //char tm[] = "2021-12-06 17:29:08:084";
  744. for(int i = 0 ; i < 2 ; i++) {
  745. min[i] = time[i+14];
  746. }
  747. if( atoi(min) < 0 || atoi(min) > 60) {
  748. strcmp(min,"");
  749. }
  750. }
  751. //================================================
  752. // Function
  753. //================================================
  754. void ChangeToOtherPage(short newPage)
  755. {
  756. uint8_t cmd[10];
  757. memset(cmd, 0x00, sizeof(cmd));
  758. uint8_t msg[9];
  759. memset(msg, 0x00, sizeof(msg));
  760. cmd[0] = CMD_TITLE_1;
  761. cmd[1] = CMD_TITLE_2;
  762. cmd[2] = 0x07;
  763. cmd[3] = 0x82;
  764. cmd[4] = 0x00;
  765. cmd[5] = 0x84;
  766. cmd[6] = 0x5A;
  767. cmd[7] = 0x01;
  768. cmd[8] = newPage >> 8;
  769. cmd[9] = newPage & 0x00FF;
  770. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  771. usleep(5000);
  772. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  773. }
  774. void ChangeBackLight(uint8_t value)
  775. {
  776. //uint8_t value = 0x01;
  777. uint8_t msg[9];
  778. memset(msg, 0x00, sizeof(msg));
  779. uint8_t cmd[7];
  780. memset(cmd, 0x00, sizeof(cmd));
  781. cmd[0] = CMD_TITLE_1;
  782. cmd[1] = CMD_TITLE_2;
  783. cmd[2] = 0x05;
  784. cmd[3] = CMD_MULTI_WRITE;
  785. cmd[4] = 0x00;
  786. cmd[5] = 0x82;
  787. cmd[6] = value;
  788. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  789. usleep(10000);
  790. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  791. }
  792. void GetCurrentPage()
  793. {
  794. uint8_t cmd[7];
  795. memset(cmd, 0x00, sizeof(cmd));
  796. uint8_t msg[9];
  797. memset(msg, 0x00, sizeof(msg));
  798. cmd[0] = CMD_TITLE_1;
  799. cmd[1] = CMD_TITLE_2;
  800. cmd[2] = 0x04; // 底下總長度
  801. cmd[3] = 0x83;
  802. cmd[4] = 0x00;
  803. cmd[5] = 0x14;
  804. cmd[6] = 0x01;
  805. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  806. usleep(5000);
  807. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  808. }
  809. //================================================
  810. // Warning process
  811. //================================================
  812. void string2ByteArray(uint8_t *input, uint8_t *output)
  813. {
  814. int loop;
  815. int i;
  816. loop = 0;
  817. i = 0;
  818. while (input[loop] != '\0') {
  819. output[i++] = input[loop++];
  820. }
  821. output[loop] = '\0';
  822. }
  823. void RefreshProgressAnimation()
  824. {
  825. _everyPageRollChange >= 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  826. }
  827. //================================================
  828. // Change current page
  829. //================================================
  830. void ChangeCurPage()
  831. {
  832. //log_info("cur = %d ,system = %d, lcm = %d ",_currentPage, pSysInfo->SystemPage, pSysInfo->PageIndex);
  833. if (pSysInfo->PageIndex != pSysInfo->SystemPage)
  834. log_info("Gun[%d] Chagne LCM Page:%d",pSysInfo->CurGunSelected, pSysInfo->SystemPage);
  835. pSysInfo->PageIndex = pSysInfo->SystemPage;
  836. if (_currentPage != pSysInfo->PageIndex) {
  837. switch (pSysInfo->SystemPage) {
  838. case _PAGE_AUTHORIZE:
  839. break;
  840. case _PAGE_PLUGIN:
  841. break;
  842. case _PAGE_PRECHARGE:
  843. break;
  844. case _PAGE_CHARGING:
  845. break;
  846. case _PAGE_COMPLETE:
  847. is_stop = FALSE;
  848. break;
  849. case _PAGE_PAYFAIL:
  850. is_stop = FALSE;
  851. break;
  852. case _PAGE_MAINTAIN:
  853. break;
  854. }
  855. _currentPage = pSysInfo->PageIndex;
  856. //if (pSysInfo->PageIndex != _PAGE_IDLE)
  857. ChangeToOtherPage(pSysInfo->PageIndex);
  858. }
  859. }
  860. /*
  861. * View Page
  862. *
  863. */
  864. unsigned long GetTimeoutValue(struct timeval _sour_time)
  865. {
  866. struct timeval _end_time;
  867. gettimeofday(&_end_time, NULL);
  868. return 1000000 * (_end_time.tv_sec - _sour_time.tv_sec) + _end_time.tv_usec - _sour_time.tv_usec;
  869. }
  870. void showGunWorkingType()
  871. {
  872. if (pSysInfo->CurGunSelected == LEFT_GUN_NUM) {
  873. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  874. if (ShmDcCommonData->pGunInfo[LEFT_GUN_NUM].ParkingStatus) {
  875. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_LeftParkingSel);
  876. } else {
  877. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  878. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  879. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS1_On);
  880. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  881. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  882. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS2_On);
  883. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  884. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CHAdeMo_On);
  885. }
  886. }
  887. // Set Right Gun
  888. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  889. if (ShmDcCommonData->pGunInfo[RIGHT_GUN_NUM].ParkingStatus) {
  890. ChangeDisplay2Value(_Icon_ShowRight,_TCC_RightParkingSel);
  891. } else {
  892. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  893. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  894. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS1_Off);
  895. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  896. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  897. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS2_Off);
  898. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  899. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CHAdeMo_Off);
  900. }
  901. }
  902. } else if (pSysInfo->CurGunSelected == RIGHT_GUN_NUM){
  903. // Left Gun
  904. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  905. if (ShmDcCommonData->pGunInfo[LEFT_GUN_NUM].ParkingStatus) {
  906. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_LeftParkingSel);
  907. } else {
  908. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  909. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  910. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS1_Off);
  911. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  912. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  913. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS2_Off);
  914. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  915. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CHAdeMo_Off);
  916. }
  917. }
  918. // Right Gun
  919. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  920. if (ShmDcCommonData->pGunInfo[RIGHT_GUN_NUM].ParkingStatus) {
  921. ChangeDisplay2Value(_Icon_ShowRight,_TCC_RightParkingSel);
  922. } else {
  923. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  924. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  925. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS1_On);
  926. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  927. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  928. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS2_On);
  929. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  930. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CHAdeMo_On);
  931. }
  932. }
  933. }
  934. }
  935. void ClearQrCode_Idle()
  936. {
  937. char cmd[200];
  938. memset(cmd,0,200);
  939. DisplayValueToLcm(_QRCode_AddLine, cmd, 200);
  940. }
  941. void ChangeQrCode_Idle(char *input)
  942. {
  943. char cmd[256];
  944. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  945. int len = 0;
  946. memset(cmd,0,256);
  947. time_t timep;
  948. struct tm* tm;
  949. time(&timep);
  950. char SN[37];
  951. memset(SN,'\0',sizeof(SN));
  952. memcpy(SN,ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].OccupancySN,36);
  953. tm = localtime(&timep);
  954. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus && !ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingCntDownFlag) {
  955. tm->tm_year -= 50;
  956. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingStopTime = mktime(tm) + 120 +(ShmDcCommonData->TZOffset * 60);
  957. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingCntDownFlag = TRUE;
  958. tm = gmtime(&ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingStopTime);
  959. log_info("QR Code Show Time:(%d)%s",ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingStopTime,asctime(tm));
  960. }
  961. if (!ShmDcCommonData->tccdev) {
  962. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  963. len = sprintf(cmd, "https://nhoatcc.lineapid.tw/web/placeholder?sn=%s&ts=%d",SN,
  964. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingStopTime);
  965. } else
  966. len = sprintf(cmd, "https://nhoatcc.lineapid.tw/web/tologin?sn=%s&cid=%d", input, ShmDcCommonData->ConnectorID[pSysInfo->CurGunSelected]);
  967. } else {
  968. if (ShmDcCommonData->pGunInfo[pSysInfo->CurGunSelected].ParkingStatus) {
  969. len = sprintf(cmd, "https://nhoatcctest.lineapid.tw/web/placeholder?sn=%s&ts=%d",SN,
  970. ShmDcCommonData->ParkingInfo[pSysInfo->CurGunSelected].ParkingStopTime);
  971. } else {
  972. len = sprintf(cmd, "https://nhoatcctest.lineapid.tw/web/tologin?sn=%s&cid=%d", input, ShmDcCommonData->ConnectorID[pSysInfo->CurGunSelected]);
  973. }
  974. }
  975. //log_info("QR Code:URL:%s",cmd);
  976. if (pSysInfo->SystemPage == _PAGE_ADD_FRIEND)
  977. DisplayValueToLcm(_QRCode_AddLine, cmd, len+1);
  978. }
  979. void ClearQrCode_Error()
  980. {
  981. char cmd[200];
  982. memset(cmd, 0, 200);
  983. DisplayValueToLcm(_QRCode_Service, cmd, 200);
  984. }
  985. void ChangeQrCode_Error()
  986. {
  987. char cmd[200];
  988. memset(cmd, 0, 200);
  989. sprintf(cmd, "https://line.me/R/ti/p/@217tcevc");
  990. //log_info("QR Code:URL:%s",cmd);
  991. DisplayValueToLcm(_QRCode_Service, cmd, 200);
  992. }
  993. /*
  994. void ChangeRemainTime(int sec)
  995. {
  996. int h, m, s;
  997. uint8_t cmd[10];
  998. uint8_t value[10];
  999. memset(cmd, 0x00, sizeof(cmd));
  1000. // srand(time(NULL));
  1001. // int min = 0;
  1002. // int max = 65536;
  1003. // sec = rand() % (max - min + 1) + min;
  1004. h = (sec / 3600);
  1005. m = (sec - (3600 * h)) / 60;
  1006. s = (sec - (3600 * h) - (m * 60));
  1007. sprintf((char *)value, "%02d:%02d:%02d", h, m, s);
  1008. string2ByteArray(value, cmd);
  1009. DisplayValueToLcm(_Text_Time, cmd, sizeof(cmd));
  1010. }
  1011. */
  1012. void ShowSelectGun()
  1013. {
  1014. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  1015. if (ShmDcCommonData->pGunInfo[LEFT_GUN_NUM].ParkingStatus){
  1016. ChangeDisplay2Value(_Icon_Select_Left,_TCC_LeftParkingIdle);
  1017. } else if ((pDcChargingInfo->SystemStatus >= S_AUTHORIZING &&
  1018. pDcChargingInfo->SystemStatus <= S_ALARM) ||
  1019. pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST0 ||
  1020. pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST1) {
  1021. // 使用中
  1022. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1023. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1024. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunCharging_CCS1);
  1025. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1026. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1027. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunCharging_CCS2);
  1028. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1029. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunCharging_CHAdeMo);
  1030. }
  1031. } else if (pDcChargingInfo->SystemStatus == S_RESERVATION) {
  1032. // 預約中
  1033. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1034. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1035. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunReservation_CCS1);
  1036. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1037. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1038. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunReservation_CCS2);
  1039. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1040. ChangeDisplay2Value(_Icon_Select_Left, _TCC_ShowLeftGunReservation_CHAdeMo);
  1041. }
  1042. } else {
  1043. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1044. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1045. ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS1);
  1046. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1047. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1048. ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS2);
  1049. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1050. ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CHAdeMo);
  1051. }
  1052. }
  1053. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  1054. if (ShmDcCommonData->pGunInfo[RIGHT_GUN_NUM].ParkingStatus) {
  1055. ChangeDisplay2Value(_Icon_Select_Right,_TCC_RightParkingIdle);
  1056. } else if ((pDcChargingInfo->SystemStatus >= S_AUTHORIZING &&
  1057. pDcChargingInfo->SystemStatus <= S_ALARM) ||
  1058. pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST0 ||
  1059. pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST1) {
  1060. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1061. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1062. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunCharging_CCS1);
  1063. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1064. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1065. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunCharging_CCS2);
  1066. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1067. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunCharging_CHAdeMo);
  1068. }
  1069. } else if (pDcChargingInfo->SystemStatus == S_RESERVATION) {
  1070. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1071. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1072. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunReservation_CCS1);
  1073. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1074. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1075. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunReservation_CCS2);
  1076. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1077. ChangeDisplay2Value(_Icon_Select_Right, _TCC_ShowRightGunReservation_CHAdeMo);
  1078. }
  1079. } else {
  1080. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1081. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1082. ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS1);
  1083. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1084. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1085. ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS2);
  1086. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1087. ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CHAdeMo);
  1088. }
  1089. }
  1090. }
  1091. void ChangeChargingPowerValue(float pow)
  1092. {
  1093. uint8_t cmd[10];
  1094. uint8_t value[10];
  1095. memset(cmd, 0x00, sizeof(cmd));
  1096. sprintf((char *) value, "%d",(int)pow);
  1097. string2ByteArray(value, cmd);
  1098. DisplayValueToLcm(_String_ChargePower, cmd, sizeof(cmd));
  1099. }
  1100. void ChangeChargingRateValue(float rate,int show)
  1101. {
  1102. uint8_t cmd[10];
  1103. uint8_t value[10];
  1104. memset(cmd, 0x00, sizeof(cmd));
  1105. if (show)
  1106. sprintf((char *) value, "%.1f",rate);
  1107. else
  1108. sprintf((char *) value, "");
  1109. string2ByteArray(value, cmd);
  1110. DisplayValueToLcm(_String_ChargeRate, cmd, sizeof(cmd));
  1111. }
  1112. void ChangeChargingFeeValue(float fee)
  1113. {
  1114. uint8_t cmd[10];
  1115. uint8_t value[10];
  1116. memset(cmd, 0x00, sizeof(cmd));
  1117. sprintf((char *) value, "%d", (int)fee);
  1118. string2ByteArray(value, cmd);
  1119. DisplayValueToLcm(_String_Money, cmd, sizeof(cmd));
  1120. }
  1121. void ChangeCarBonValue(float data)
  1122. {
  1123. uint8_t cmd[10];
  1124. uint8_t value[10];
  1125. float _carbon = 0;
  1126. memset(cmd, 0x00, sizeof(cmd));
  1127. _carbon = data * 0.577;
  1128. //log_info("Carbon:%d",(int)_carbon);
  1129. sprintf((char *) value, "%.1f", _carbon);
  1130. string2ByteArray(value, cmd);
  1131. DisplayValueToLcm(_String_Carbon, cmd, sizeof(cmd));
  1132. }
  1133. void ChangeChargingEnergyValue(float energy)
  1134. {
  1135. uint8_t cmd[10];
  1136. uint8_t value[10];
  1137. memset(cmd, 0x00, sizeof(cmd));
  1138. if (energy >= 0.05) {
  1139. energy -= 0.05;
  1140. }
  1141. if (energy < 0 )
  1142. ChangeDisplay2Value(_Icon_ChargeBar,_TCC_Charging_Bar0);
  1143. else if (energy > 100)
  1144. ChangeDisplay2Value(_Icon_ChargeBar,_TCC_Charging_Bar0+100);
  1145. else
  1146. ChangeDisplay2Value(_Icon_ChargeBar,(int)energy+_TCC_Charging_Bar0);
  1147. if (energy < 10)
  1148. sprintf((char *) value, "%.1f", energy);
  1149. else
  1150. sprintf((char *) value, "%d", (int)energy);
  1151. string2ByteArray(value, cmd);
  1152. DisplayValueToLcm(_Strting_Energy, cmd, sizeof(cmd));
  1153. }
  1154. void ChangeParkingRateValue(float fee,int show)
  1155. {
  1156. uint8_t cmd[10];
  1157. uint8_t value[10];
  1158. memset(cmd, 0x00, sizeof(cmd));
  1159. if (show)
  1160. sprintf((char *) value, "%d", (int)fee);
  1161. else
  1162. sprintf((char *) value, "");
  1163. string2ByteArray(value, cmd);
  1164. DisplayValueToLcm(_String_ParkRate, cmd, sizeof(cmd));
  1165. }
  1166. void ChangeParkingLeaveTime(int min,int show)
  1167. {
  1168. uint8_t cmd[10];
  1169. uint8_t value[10];
  1170. memset(cmd, 0x00, sizeof(cmd));
  1171. if (show)
  1172. sprintf((char *) value, "%d", (int)min);
  1173. else
  1174. sprintf((char *) value, "");
  1175. string2ByteArray(value, cmd);
  1176. DisplayValueToLcm(_String_ParkingLeaveTime, cmd, sizeof(cmd));
  1177. }
  1178. void ChangeSaleLeaveTime(int min,int show)
  1179. {
  1180. uint8_t cmd[10];
  1181. uint8_t value[10];
  1182. memset(cmd, 0x00, sizeof(cmd));
  1183. if (show)
  1184. sprintf((char *) value, "%d", (int)min);
  1185. else
  1186. sprintf((char *) value, "");
  1187. string2ByteArray(value, cmd);
  1188. DisplayValueToLcm(_String_SaleLeaveTime, cmd, sizeof(cmd));
  1189. }
  1190. uint8_t _battery_display_count = 0;
  1191. void ChangeBattMapAndValue(int soc)
  1192. {
  1193. int i = (soc*36)/100;
  1194. uint8_t cmd[5];
  1195. uint8_t value[5];
  1196. _battery_display_count++;
  1197. if (_battery_display_count == 3 ) {
  1198. if (_battery_display_ani == 0)
  1199. _battery_display_ani= TRUE;
  1200. else
  1201. _battery_display_ani= FALSE ;
  1202. _battery_display_count = 0;
  1203. }
  1204. if (pSysInfo->SystemPage == _PAGE_CHARGING) {
  1205. if (i>=36)
  1206. ChangeDisplay2Value(_Icon_ChargeCircle,_TCC_Charging_Circle0+36);
  1207. else {
  1208. if (_battery_display_ani) {
  1209. ChangeDisplay2Value(_Icon_ChargeCircle, _TCC_Charging_Circle0+i);
  1210. } else {
  1211. ChangeDisplay2Value(_Icon_ChargeCircle, _TCC_Charging_Circle0+i+1);
  1212. }
  1213. }
  1214. } else if (pSysInfo->SystemPage == _PAGE_COMPLETE)
  1215. ChangeDisplay2Value(_Icon_CompleteCircle, _TCC_CompleteCircle0+i);
  1216. else
  1217. ChangeDisplay2Value(_Icon_CompleteCircle, _TCC_FAILCircle0 +i);
  1218. memset(cmd, 0x00, sizeof(cmd));
  1219. memset(value, 0x00, sizeof(value));
  1220. sprintf((char *)value, "%d", soc);
  1221. string2ByteArray(value, cmd);
  1222. DisplayValueToLcm(_String_Battery, cmd, sizeof(cmd));
  1223. }
  1224. unsigned long GetPreChargeTimeoutValue(struct timeval _sour_time)
  1225. {
  1226. struct timeval _end_time;
  1227. gettimeofday(&_end_time, NULL);
  1228. return 1000000 * (_end_time.tv_sec - _sour_time.tv_sec) + _end_time.tv_usec - _sour_time.tv_usec;
  1229. }
  1230. void ChangeTimeValue(int time)
  1231. {
  1232. uint8_t cmd[6];
  1233. uint8_t value[6];
  1234. memset(cmd, 0x00, sizeof(cmd));
  1235. sprintf((char *) value, "%d", time);
  1236. string2ByteArray(value, cmd);
  1237. DisplayValueToLcm(_String_ChargeTime, cmd, sizeof(cmd));
  1238. }
  1239. void changeWeatherValue(int _weather)
  1240. {
  1241. switch (_weather) {
  1242. case _WEATHER_TYPE_SUN:
  1243. ChangeDisplay2Value(_Icon_Weather,_TCC_Sun);
  1244. break;
  1245. case _WEATHER_TYPE_CLOUDY:
  1246. ChangeDisplay2Value(_Icon_Weather,_TCC_Cloudy);
  1247. break;
  1248. case _WEATHER_TYPE_RAIN:
  1249. ChangeDisplay2Value(_Icon_Weather,_TCC_Rain);
  1250. break;
  1251. case _WEATHER_TYPE_THUNDER:
  1252. ChangeDisplay2Value(_Icon_Weather,_TCC_Thunder);
  1253. break;
  1254. case _WEATHER_TYPE_SNOW:
  1255. ChangeDisplay2Value(_Icon_Weather,_TCC_Snow);
  1256. break;
  1257. case _WEATHER_TYPE_FOG:
  1258. ChangeDisplay2Value(_Icon_Weather,_TCC_Fog);
  1259. break;
  1260. }
  1261. }
  1262. void changeWeekValue(int _week)
  1263. {
  1264. time_t timep;
  1265. struct tm* tm;
  1266. time(&timep);
  1267. timep += (ShmDcCommonData->TZOffset * 60);
  1268. tm = localtime(&timep);
  1269. _week = tm->tm_wday;
  1270. if (_week == 0 )
  1271. _week = 7;
  1272. ChangeDisplay2Value(_Icon_Week,_week);
  1273. }
  1274. void changeDegreeValue(int _degree)
  1275. {
  1276. char value[16];
  1277. memset(value, 0x00, sizeof(value));
  1278. sprintf((char *)value,"%d",_degree);
  1279. DisplayValueToLcm(_String_Tempture, (uint8_t *)value, sizeof(value));
  1280. }
  1281. void changeDateValue(char* _date)
  1282. {
  1283. time_t timep;
  1284. struct tm* tm;
  1285. time(&timep);
  1286. timep += (ShmDcCommonData->TZOffset * 60);
  1287. tm = localtime(&timep);
  1288. sprintf(_date, "%04d/%02d/%02d",
  1289. tm->tm_year + 1900,
  1290. tm->tm_mon + 1,
  1291. tm->tm_mday);
  1292. char value[16];
  1293. memset(value, 0x00, sizeof(value));
  1294. sprintf((char *)value,"%s",_date);
  1295. DisplayValueToLcm(_String_Date, (uint8_t *)value, sizeof(value));
  1296. }
  1297. void changeLocationValue(int _location)
  1298. {
  1299. //_location+=1000;
  1300. //log_info("location:%d",_location);
  1301. ChangeDisplay2Value(_Icon_Location,(short)_location);
  1302. }
  1303. void ShowLineRegisterCountDown(int _show)
  1304. {
  1305. if(!_show) {
  1306. ChangeDisplay2Value(_Icon_ScanCntDw_BG,_ICON_Empty);
  1307. ChangeDisplay2Value(_Icon_ScanCntDownTen, _ICON_Empty);
  1308. ChangeDisplay2Value(_Icon_ScanCntDownDigits, _ICON_Empty);
  1309. return;
  1310. }
  1311. int _ten, _digits;
  1312. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  1313. if (pDcChargingInfo->TimeoutFlag == Timeout_LineReigster) {
  1314. _ten = (TCC_LINEREGISTER_TIMEOUT - (GetClockTimeoutValue(pDcChargingInfo->ConnectorTimeout) / uSEC_VAL)) / 10;
  1315. _digits = (TCC_LINEREGISTER_TIMEOUT - (GetClockTimeoutValue(pDcChargingInfo->ConnectorTimeout) / uSEC_VAL)) % 10;
  1316. ChangeDisplay2Value(_Icon_ScanCntDw_BG,_TCC_Scan_CntDw_BG);
  1317. ChangeDisplay2Value(_Icon_ScanCntDownTen, (short)_TCC_CntDownNumber0+_ten);
  1318. ChangeDisplay2Value(_Icon_ScanCntDownDigits, (short)_TCC_CntDownNumber0+ _digits);
  1319. } else {
  1320. //log_info("Not get Line Register Count Down");
  1321. }
  1322. }
  1323. void ShowAuthorizeCountDown()
  1324. {
  1325. int _ten, _digits;
  1326. if (pSysInfo->SystemTimeoutFlag == Timeout_ScanCard) {
  1327. ChangeDisplay2Value(_Icon_ScanCntDw_BG,_TCC_Scan_CntDw_BG);
  1328. _ten = (TCC_SCANCARD_TIMEOUT - (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL)) / 10;
  1329. _digits = (TCC_SCANCARD_TIMEOUT - (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL)) % 10;
  1330. ChangeDisplay2Value(_Icon_AuthCntDownTen, (short)_TCC_CntDownNumber0 + _ten);
  1331. ChangeDisplay2Value(_Icon_AuthCntDownDigits, (short)_TCC_CntDownNumber0 + _digits);
  1332. }
  1333. else {
  1334. log_info("Not get Line Register Count Down");
  1335. }
  1336. }
  1337. void ShowParkingCountDown(int is_parking)
  1338. {
  1339. int _ten, _digits , _hun;
  1340. unsigned char time_flag;
  1341. int TimeoutTime;
  1342. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(pSysInfo->CurGunSelected);
  1343. if (is_parking) {
  1344. if (pSysInfo->SystemPage == _PAGE_ADD_FRIEND) {
  1345. time_flag = Timeout_ParkingBill;
  1346. TimeoutTime = TCC_PARKINGBILL_TIMEOUT;
  1347. } else {
  1348. time_flag = Timeout_ParkingSelect;
  1349. TimeoutTime = TCC_PARK_SELECTPAY_TIMEOUT;
  1350. }
  1351. if (pDcChargingInfo->TimeoutFlag == time_flag ) {
  1352. _hun = (TimeoutTime - (GetClockTimeoutValue(pDcChargingInfo->ConnectorTimeout) / uSEC_VAL)) / 100;
  1353. _ten = ((TimeoutTime - (GetClockTimeoutValue(pDcChargingInfo->ConnectorTimeout) / uSEC_VAL)) / 10)%10;
  1354. _digits = (TimeoutTime - (GetClockTimeoutValue(pDcChargingInfo->ConnectorTimeout) / uSEC_VAL)) % 10;
  1355. if (pSysInfo->SystemPage == _PAGE_ADD_FRIEND) {
  1356. ChangeDisplay2Value(_Icon_ParkingCntDw_BG, (short)_TCC_ParkingCntDown_BG3);
  1357. ChangeDisplay2Value(_Icon_ParkingCntDw_Hun, (short)_TCC_ParkingCD_0 + _hun);
  1358. ChangeDisplay2Value(_Icon_ParkingCntDw_Tens, (short)_TCC_ParkingCD_0 + _ten);
  1359. ChangeDisplay2Value(_Icon_ParkingCntDw_Digits, (short)_TCC_ParkingCD_0 + _digits);
  1360. } else {
  1361. ChangeDisplay2Value(_Icon_ParkingCntDw_BG, (short)_TCC_ParkingCntDown_BG);
  1362. ChangeDisplay2Value(_Icon_ParkingCntDw_Tens, (short)_TCC_ParkingCD_0 + _ten);
  1363. ChangeDisplay2Value(_Icon_ParkingCntDw_Digits, (short)_TCC_ParkingCD_0 + _digits);
  1364. }
  1365. }
  1366. else {
  1367. log_info("Not get Parking Count Down(%d)",pDcChargingInfo->TimeoutFlag);
  1368. }
  1369. } else {
  1370. ChangeDisplay2Value(_Icon_ParkingCntDw_BG, NULL);
  1371. ChangeDisplay2Value(_Icon_ParkingCntDw_Hun, NULL);
  1372. ChangeDisplay2Value(_Icon_ParkingCntDw_Tens, NULL);
  1373. ChangeDisplay2Value(_Icon_ParkingCntDw_Digits, NULL);
  1374. }
  1375. }
  1376. void changeGunType()
  1377. {
  1378. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(LEFT_GUN_NUM);
  1379. if (ShmDcCommonData->pGunInfo[LEFT_GUN_NUM].ParkingStatus) {
  1380. ChangeDisplay2Value(_Icon_Select_Left,_TCC_LeftParkingIdle);
  1381. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1382. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1383. ChangeDisplay2Value(_Icon_Select_Left, _TCC_IDLE_LEFT_CCS1);
  1384. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1385. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1386. ChangeDisplay2Value(_Icon_Select_Left, _TCC_IDLE_LEFT_CCS2);
  1387. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1388. ChangeDisplay2Value(_Icon_Select_Left, _TCC_IDLE_LEFT_CHAdeMo);
  1389. }
  1390. // Set Right Gun
  1391. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(RIGHT_GUN_NUM);
  1392. if (ShmDcCommonData->pGunInfo[RIGHT_GUN_NUM].ParkingStatus) {
  1393. ChangeDisplay2Value(_Icon_Select_Right,_TCC_RightParkingIdle);
  1394. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1395. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1396. ChangeDisplay2Value(_Icon_Select_Right, _TCC_IDLE_RIGHT_CCS1);
  1397. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1398. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1399. ChangeDisplay2Value(_Icon_Select_Right, _TCC_IDLE_RIGHT_CCS2);
  1400. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1401. ChangeDisplay2Value(_Icon_Select_Right, _TCC_IDLE_RIGHT_CHAdeMo);
  1402. }
  1403. }
  1404. void ShowParkingInfo(bool is_show,uint8_t gunIndex)
  1405. {
  1406. char cmd[32];
  1407. if (is_show) {
  1408. ChangeDisplay2Value(_Icon_ParkingInfo,_TCC_ParkingInfo);
  1409. memset(cmd, 0x00, sizeof(cmd));
  1410. sprintf((char *)cmd,"%s",ShmDcCommonData->ParkingInfo[gunIndex].ParkingStartTime);
  1411. DisplayValueToLcm(_String_ParkingStartTime, (uint8_t *)cmd, sizeof(cmd));
  1412. memset(cmd, 0x00, sizeof(cmd));
  1413. sprintf((char *)cmd,"%d",ShmDcCommonData->ParkingInfo[gunIndex].ParkingDuration);
  1414. DisplayValueToLcm(_String_ParkingDuration, (uint8_t *)cmd, sizeof(cmd));
  1415. memset(cmd, 0x00, sizeof(cmd));
  1416. sprintf((char *)cmd,"%d",(int)ShmDcCommonData->ParkingInfo[gunIndex].Amount);
  1417. DisplayValueToLcm(_String_ParkingFee, (uint8_t *)cmd, sizeof(cmd));
  1418. } else {
  1419. if (pSysInfo->SystemPage == _PAGE_BILL) {
  1420. ChangeDisplay2Value(_Icon_ParkingInfo,_TCC_ICON_SelectChargeMode);
  1421. } else if (pSysInfo->SystemPage >= _PAGE_ADD_FRIEND && pSysInfo->SystemPage <= _PAGE_AUTHORIZE) {
  1422. ChangeDisplay2Value(_Icon_ParkingInfo,_TCC_ICON_SelectPayMode);
  1423. } else {
  1424. ChangeDisplay2Value(_Icon_ParkingInfo,NULL);
  1425. }
  1426. memset(cmd, 0x00, sizeof(cmd));
  1427. DisplayValueToLcm(_String_ParkingStartTime, (uint8_t *)cmd, sizeof(cmd));
  1428. DisplayValueToLcm(_String_ParkingDuration, (uint8_t *)cmd, sizeof(cmd));
  1429. DisplayValueToLcm(_String_ParkingFee, (uint8_t *)cmd, sizeof(cmd));
  1430. }
  1431. if (pSysInfo->SystemPage >= _PAGE_BILL && pSysInfo->SystemPage <= _PAGE_SELECT_PAY)
  1432. ShowParkingCountDown(is_show);
  1433. }
  1434. int old_money = 0;
  1435. int ClearQR_flag[2];
  1436. void ProcessPageInfo()
  1437. {
  1438. if (ShmDcCommonData->CreditCardUpload) {
  1439. pSysInfo->SystemPage = _PAGE_PAYING;
  1440. }
  1441. // Show Gun Working and Type
  1442. if (pSysInfo->SystemPage == _PAGE_IDLE) {
  1443. changeWeatherValue(ShmDcCommonData->WeatherID);
  1444. changeWeekValue(0);
  1445. changeDegreeValue((int)ShmDcCommonData->Temperature);
  1446. changeDateValue(&ShmDcCommonData->PresentTime[0]);
  1447. changeLocationValue(1000);
  1448. changeGunType();
  1449. ClearQR_flag[pSysInfo->CurGunSelected] = FALSE;
  1450. return;
  1451. }
  1452. if (pSysInfo->SystemPage == _PAGE_MAINTAIN) {
  1453. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
  1454. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1455. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1456. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS1_Off);
  1457. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1458. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1459. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CCS2_Off);
  1460. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1461. ChangeDisplay2Value(_Icon_ShowLeft,_TCC_ShowLeft_CHAdeMo_Off);
  1462. }
  1463. // Set Right Gun
  1464. pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
  1465. if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
  1466. pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
  1467. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS1_Off);
  1468. } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
  1469. pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
  1470. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CCS2_Off);
  1471. } else if (pDcChargingInfo->Type == _Type_Chademo) {
  1472. ChangeDisplay2Value(_Icon_ShowRight,_TCC_ShowRight_CHAdeMo_Off);
  1473. }
  1474. ChangeQrCode_Error();
  1475. return;
  1476. }
  1477. showGunWorkingType();
  1478. for (uint8_t i = 0; i < pSysConfig->TotalConnectorCount; i++) {
  1479. if (pSysInfo->CurGunSelected == i) {
  1480. pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(i);
  1481. if (pDcChargingInfo->SystemStatus == S_IDLE) {
  1482. _everyPageRollChange = 0;
  1483. _Text_Running_Count = 1;
  1484. }
  1485. if (pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
  1486. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1487. ChangeDisplay2Value(_Icon_Return,NULL);
  1488. } else {
  1489. ChangeDisplay2Value(_Icon_Return,_TCC_Return);
  1490. }
  1491. ShowParkingCountDown(FALSE);
  1492. } else {
  1493. ChangeDisplay2Value(_Icon_Return,_TCC_Return);
  1494. }
  1495. switch (pSysInfo->SystemPage) {
  1496. case _PAGE_IDLE:
  1497. ShowSelectGun();
  1498. ClearQR_flag[i] = FALSE;
  1499. break;
  1500. case _PAGE_SELECT_PAY:
  1501. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1502. ShowParkingInfo(true,i);
  1503. } else {
  1504. ShowParkingInfo(false,i);
  1505. }
  1506. break;
  1507. case _PAGE_SELECT_GUN:
  1508. ShowSelectGun();
  1509. ClearQR_flag[i] = FALSE;
  1510. break;
  1511. case _PAGE_BILL:
  1512. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1513. ChangeDisplay2Value(_Icon_Add_Line,_TCC_ParkingLine);
  1514. ChangeDisplay2Value(_Icon_Donate,_TCC_ParkingDonate);
  1515. ShowParkingInfo(true,i);
  1516. } else {
  1517. ChangeDisplay2Value(_Icon_Add_Line,_TCC_GetBill);
  1518. ChangeDisplay2Value(_Icon_Donate,_TCC_DonateBill);
  1519. ShowParkingInfo(false,i);
  1520. }
  1521. break;
  1522. case _PAGE_AUTHORIZE:
  1523. StartSystemTimeoutDet(Timeout_ScanCard);
  1524. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1525. ShowParkingInfo(true,i);
  1526. ChangeDisplay2Value(_Icon_CreditCardFrame,_TCC_ParkingFee);
  1527. ChangeChargingRateValue(ShmDcCommonData->ChargingRate,FALSE);
  1528. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,FALSE);
  1529. ChangeParkingLeaveTime(ShmDcCommonData->ParkingLeaveTime,FALSE);
  1530. } else {
  1531. ShowParkingInfo(false,i);
  1532. ChangeDisplay2Value(_Icon_CreditCardFrame,_TCC_CardSensing_Frame);
  1533. ChangeChargingRateValue(ShmDcCommonData->ChargingRate,TRUE);
  1534. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,TRUE);
  1535. ChangeParkingLeaveTime(ShmDcCommonData->ParkingLeaveTime,TRUE);
  1536. }
  1537. ShowAuthorizeCountDown();
  1538. break;
  1539. case _PAGE_SENSING:
  1540. if (ShmDcCommonData->TradeCancel == TRUE) {
  1541. TradeRunning(FALSE);
  1542. }
  1543. else
  1544. TradeRunning(TRUE);
  1545. break;
  1546. case _PAGE_PLUGIN:
  1547. _everyPageRollChange = 0;
  1548. if (ShmDcCommonData->pGunInfo[i].isParking) {
  1549. ChangeDisplay2Value(_Icon_PreAuth_Complete,_TCC_ParkingLeave);
  1550. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,FALSE);
  1551. ChangeParkingLeaveTime(ShmDcCommonData->ParkingLeaveTime,FALSE);
  1552. ChangeSaleLeaveTime(ShmDcCommonData->SaleLeaveTime,TRUE);
  1553. } else {
  1554. ChangeDisplay2Value(_Icon_PreAuth_Complete,_TCC_PaySuccess);
  1555. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,TRUE);
  1556. ChangeParkingLeaveTime(ShmDcCommonData->ParkingLeaveTime,TRUE);
  1557. ChangeSaleLeaveTime(ShmDcCommonData->SaleLeaveTime,FALSE);
  1558. }
  1559. break;
  1560. case _PAGE_ADD_FRIEND:
  1561. if(ClearQR_flag[i] == FALSE) {
  1562. ClearQrCode_Idle();
  1563. ClearQR_flag[i] = TRUE;
  1564. }
  1565. ChangeQrCode_Idle((char *)pSysConfig->SystemId);
  1566. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1567. ShowParkingInfo(true,i);
  1568. ShowLineRegisterCountDown(FALSE);
  1569. } else {
  1570. ShowLineRegisterCountDown(TRUE);
  1571. ShowParkingInfo(false,i);
  1572. }
  1573. break;
  1574. case _PAGE_PRECHARGE:
  1575. RefreshProgressAnimation();
  1576. if (_everyPageRollChange == 0) {
  1577. ChangeDisplay2Value(_Icon_Precharge,_Text_Running_Count);
  1578. _Text_Running_Count >= 24 ? _Text_Running_Count = 24 : _Text_Running_Count++;
  1579. }
  1580. break;
  1581. case _PAGE_CHARGING:
  1582. if (pDcChargingInfo->PresentChargingPower >= 0 &&
  1583. pDcChargingInfo->PresentChargingPower <= POWER_MAX_KW) {
  1584. ChangeChargingPowerValue(pDcChargingInfo->PresentChargingPower);
  1585. } else {
  1586. ChangeChargingPowerValue(0);
  1587. }
  1588. if (pDcChargingInfo->PresentChargedEnergy >= 0.1 &&
  1589. pDcChargingInfo->PresentChargedEnergy <= ENERGY_MAX_KWH) {
  1590. ChangeChargingEnergyValue(pDcChargingInfo->PresentChargedEnergy);
  1591. } else {
  1592. ChangeChargingEnergyValue(0);
  1593. }
  1594. if ( pDcChargingInfo->ChargingFee >= 0) {
  1595. ChangeChargingFeeValue(pDcChargingInfo->ChargingFee);
  1596. }
  1597. if (pDcChargingInfo->RemainChargingDuration >= 0 &&
  1598. pDcChargingInfo->RemainChargingDuration <= TIME_MAX_SEC) {
  1599. ChangeTimeValue(pDcChargingInfo->RemainChargingDuration/60);
  1600. } else {
  1601. ChangeTimeValue(0);
  1602. }
  1603. ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
  1604. StartSystemTimeoutDet(Timeout_ReturnViewPage);
  1605. break;
  1606. case _PAGE_COMPLETE:
  1607. case _PAGE_PAYFAIL:
  1608. if (pDcChargingInfo->PresentChargedEnergy >= 0.1 &&
  1609. pDcChargingInfo->PresentChargedEnergy <= ENERGY_MAX_KWH) {
  1610. ChangeChargingEnergyValue(pDcChargingInfo->PresentChargedEnergy);
  1611. } else {
  1612. ChangeChargingEnergyValue(0);
  1613. }
  1614. ChangeChargingFeeValue(ShmDcCommonData->TransactionInfo[i].Amount);
  1615. ChangeCarBonValue(pDcChargingInfo->PresentChargedEnergy);
  1616. ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
  1617. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1618. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,FALSE);
  1619. ChangeDisplay2Value(_Icon_CompleteBtn,_TCC_ParkingComplete);
  1620. } else {
  1621. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,TRUE);
  1622. ChangeDisplay2Value(_Icon_CompleteBtn,_TCC_NoParkingComplete);
  1623. }
  1624. //StartSystemTimeoutDet(Timeout_ReturnViewPage);
  1625. break;
  1626. case _PAGE_PLUGOUT:
  1627. if (ShmDcCommonData->pGunInfo[i].ParkingStatus) {
  1628. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,FALSE);
  1629. ChangeDisplay2Value(_Icon_CompleteBtn,_TCC_ParkingComplete);
  1630. } else {
  1631. ChangeParkingRateValue(ShmDcCommonData->ParkingRate,TRUE);
  1632. ChangeDisplay2Value(_Icon_CompleteBtn,NULL);
  1633. }
  1634. break;
  1635. case _PAGE_PAYING:
  1636. ChangeDisplay2Value(_Icon_Ani_Dot, 1);
  1637. if (ShmDcCommonData->CreditCardUpload) {
  1638. ChangeDisplay2Value(_Icon_Uploading, _TCC_Uploading);
  1639. ChangeDisplay2Value(_Icon_Paying, _ICON_Empty);
  1640. } else {
  1641. if (ShmDcCommonData->StopCharge[i]) {
  1642. ChangeDisplay2Value(_Icon_Uploading, _ICON_Empty);
  1643. ChangeDisplay2Value(_Icon_Paying, _TCC_Paying);
  1644. } else if (ShmDcCommonData->pGunInfo[i].isParking){
  1645. ChangeDisplay2Value(_Icon_Uploading, _TCC_WaitParkInfo);
  1646. ChangeDisplay2Value(_Icon_Paying, _ICON_Empty);
  1647. }
  1648. }
  1649. break;
  1650. case _PAGE_EXIT:
  1651. break;
  1652. case _PAGE_LINEPAYING:
  1653. StartSystemTimeoutDet(Timeout_LINEPAYING);
  1654. break;
  1655. case _PAGE_MAINTAIN:
  1656. ChangeQrCode_Error();
  1657. break;
  1658. }
  1659. }
  1660. }
  1661. }
  1662. /*
  1663. void InformationShow()
  1664. {
  1665. is_show = true;
  1666. if (_showInformIndex == 0 ) {
  1667. pSysInfo->PageIndex = __SHOW_CABIENT_VERSION;
  1668. } else {
  1669. pSysInfo->PageIndex = __SHOW_DISPENSER_VERASION;
  1670. ShowDispenserVersion();
  1671. }
  1672. }
  1673. */
  1674. void DefautLayOut()
  1675. {
  1676. int i;
  1677. for (i = 0 ; i <= 0x5C ; i+=2 ) {
  1678. ChangeDisplay2Value(0x1000+i,1);
  1679. if (i==0x28 || i ==0x2A)
  1680. continue;
  1681. }
  1682. ChangeDisplay2Value(_Icon_MobilePay,0);
  1683. ChangeDisplay2Value(_Icon_CardPay,0);
  1684. ChangeDisplay2Value(0x5000,1);
  1685. //ChangeDisplay2Value(_QRCode_Service, 1);
  1686. ShowSelectGun();
  1687. }
  1688. /*
  1689. static int InitialRfidPort(void)
  1690. {
  1691. int fd = open(rfidPortName, O_RDWR);
  1692. struct termios tios;
  1693. struct AlarmCodeData *pAlarmCode = (struct AlarmCodeData *)GetShmAlarmCodeData();
  1694. if (fd != FAIL) {
  1695. ioctl (fd, TCGETS, &tios);
  1696. tios.c_cflag = B115200 | CS8 | CLOCAL | CREAD;
  1697. tios.c_lflag = 0;
  1698. tios.c_iflag = 0;
  1699. tios.c_oflag = 0;
  1700. tios.c_cc[VMIN] = 0;
  1701. tios.c_cc[VTIME] = (uint8_t) 1;
  1702. tios.c_lflag = 0;
  1703. tcflush(fd, TCIFLUSH);
  1704. ioctl(fd, TCSETS, &tios);
  1705. }
  1706. if (fd < 0) {
  1707. pAlarmCode->AlarmEvents.bits.RfidModuleCommFail = 1;
  1708. }
  1709. return fd;
  1710. }
  1711. */
  1712. void DemoFunction(int index)
  1713. {
  1714. int i;
  1715. showGunWorkingType();
  1716. switch (index) {
  1717. case 1: // _PAGE_IDLE
  1718. /*
  1719. for (i = 0; i <= 100; i++) {
  1720. changeWeatherValue(i / 20);
  1721. ChangeDisplay2Value(_Icon_Week, i / 15);
  1722. changeDegreeValue(i);
  1723. sprintf(text, "20%02d/%02d/%02d %02d:%02d:%02d", i, i, i, i, i, i);
  1724. DisplayValueToLcm(_String_Date, (uint8_t*)text, 30);
  1725. usleep(100000);
  1726. }
  1727. */
  1728. break;
  1729. case 3:
  1730. ChangeQrCode_Idle((char*)pSysConfig->SystemId);
  1731. sleep(3);
  1732. break;
  1733. case 4: //_PAGE_ADD_FRIEND
  1734. for (i = 0; i <= 10; i++) {
  1735. ChangeDisplay2Value(_Icon_ScanCntDownTen, (short)_TCC_CntDownNumber0 + i);
  1736. ChangeDisplay2Value(_Icon_ScanCntDownDigits, (short)_TCC_CntDownNumber0 + i);
  1737. usleep(100000);
  1738. }
  1739. break;
  1740. case 7: //_PAGE_AUTHORIZE
  1741. for (i = 0; i < 10; i++) {
  1742. ChangeChargingRateValue(i+i*10,TRUE);
  1743. ChangeDisplay2Value(_Icon_AuthCntDownTen, (short)_TCC_CntDownNumber0 + i);
  1744. ChangeDisplay2Value(_Icon_AuthCntDownDigits, (short)_TCC_CntDownNumber0 + i);
  1745. usleep(100000);
  1746. }
  1747. break;
  1748. case 8: //_PAGE_SENSING
  1749. for (i = 0; i < 10; i++) {
  1750. ChangeDisplay2Value(_Icon_CancelCntDownTen, (short)(_TCC_CancelNum_0 + i));
  1751. ChangeDisplay2Value(_Icon_CancelCntDownDigits, (short)(_TCC_CancelNum_0 + i));
  1752. usleep(100000);
  1753. }
  1754. break;
  1755. case 10: //_PAGE_PRECHARGE
  1756. for (i = 1; i <= 24; i++) {
  1757. ChangeDisplay2Value(_Icon_Precharge, i);
  1758. usleep(100000);
  1759. }
  1760. break;
  1761. case 11: //_PAGE_CHARGING
  1762. for (i = 0; i <= 100; i++) {
  1763. ChangeChargingPowerValue(i);
  1764. ChangeChargingEnergyValue(i);
  1765. ChangeChargingFeeValue(i);
  1766. ChangeTimeValue(i);
  1767. ChangeBattMapAndValue(i);
  1768. usleep(100000);
  1769. }
  1770. break;
  1771. case 13: //_PAGE_PAYING
  1772. break;
  1773. case 14: //_PAGE_COMPLETE
  1774. case 20: //_PAGE_PAYFAIL
  1775. for (i = 0; i <= 100; i++) {
  1776. ChangeChargingEnergyValue(i);
  1777. ChangeChargingFeeValue(i);
  1778. ChangeCarBonValue(i*2);
  1779. ChangeBattMapAndValue(i);
  1780. usleep(100000);
  1781. }
  1782. break;
  1783. }
  1784. sleep(1);
  1785. }
  1786. int main(void)
  1787. {
  1788. bool defaulttext = false;
  1789. if (CreateAllCsuShareMemory() == FAIL) {
  1790. log_error("create share memory error");
  1791. return FAIL;
  1792. }
  1793. MappingGunChargingInfo("LCM Control Task");
  1794. pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
  1795. pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
  1796. pSysWarning = (struct WARNING_CODE_INFO *)GetShmSysWarningInfo();
  1797. ShmFanModuleData = (struct FanModuleData *)GetShmFanModuleData();;
  1798. ShmPrimaryMcuData = (struct PrimaryMcuData *)GetShmPrimaryMcuData();
  1799. ShmSelectGunInfo = (SelectGunInfo *)GetShmSelectGunInfo();
  1800. ShmDcCommonData = (DcCommonInfo *)GetShmDcCommonData();
  1801. ShmOCPP16Data = (struct OCPP16Data *)GetShmOCPP16Data();
  1802. struct StatusCodeData *ShmStatusCodeData = (struct StatusCodeData *)GetShmStatusCodeData();;
  1803. _port = CreateCommunicationLcmPort();
  1804. uint8_t changeWarningPriority = 0;
  1805. uint8_t curWarningCount = 255;
  1806. uint8_t light = 0x64;
  1807. ShmDcCommonData->BackLight = light;
  1808. ChangeBackLight(light);
  1809. _totalCount = pSysConfig->TotalConnectorCount;
  1810. _everyPageRollChange = 0;
  1811. //Initialization();
  1812. //printf("_LCM_COMPLETE ");
  1813. //ChangeToOtherPage(_LCM_COMPLETE);
  1814. DefautLayOut();
  1815. //return 0;
  1816. uint8_t index = 1;
  1817. ShmDcCommonData->PSU_Number = 12;
  1818. /*
  1819. CardReadFd = InitialRfidPort();
  1820. if (CardReadFd <0) {
  1821. log_info("Card Read Port open fail!");
  1822. }*/
  1823. CheckLCMPressed();
  1824. while (_port != -1) {
  1825. if (strcmp((char *)pSysInfo->LcmHwRev, moduleName) != 0x00) {
  1826. GetCurrentPage();
  1827. sleep(1);
  1828. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = true;
  1829. } else {
  1830. UpdateLcmFunction(ShmDcCommonData,_port);
  1831. if (ShmDcCommonData->BackLight != light) {
  1832. ChangeBackLight(ShmDcCommonData->BackLight);
  1833. light = ShmDcCommonData->BackLight;
  1834. log_info("Set Backlight:%d",light);
  1835. }
  1836. ///*
  1837. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = false;
  1838. // 頁面資訊處理
  1839. if (!ShmDcCommonData->lcmtest)
  1840. ProcessPageInfo();
  1841. else
  1842. pSysInfo->SystemPage = index;
  1843. // 換頁處理
  1844. //GetCurrentPage(); //DS60-120 add
  1845. /*
  1846. if (pSysConfig->ShowInformation == YES && pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
  1847. InformationShow();
  1848. ChangeToOtherPage(pSysInfo->PageIndex);
  1849. usleep(100000);
  1850. continue;
  1851. } else {
  1852. if (is_show)
  1853. _showInformIndex >= 1 ? _showInformIndex = 0 : _showInformIndex++;
  1854. is_show = false;
  1855. }*/
  1856. GetCurrentPage(); //DS60-120 add
  1857. ChangeCurPage();
  1858. changeWarningPriority >= 30 ? changeWarningPriority = 0 : changeWarningPriority++;
  1859. if (ShmDcCommonData->lcmtest) {
  1860. DemoFunction(index);
  1861. index >= 20 ? index = 1 : index++;
  1862. }
  1863. usleep(10000); //*/
  1864. /*
  1865. GetCurrentPage();
  1866. ChangeCurPage();
  1867. usleep(10000);
  1868. //*/
  1869. }
  1870. } //while
  1871. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.LcmModuleCommFail = true;
  1872. log_info("Close LCM Uart Port");
  1873. CloseCommunicationLcmPort();
  1874. return FAIL;
  1875. }