Module_LcmControl.c 76 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730
  1. #include "Module_LcmContro.h"
  2. bool needReloadQr = true;
  3. bool needReloadQrCtep = true;
  4. bool _isInforShow = false;
  5. bool _isCtepInforShow = false;
  6. byte _showInformIndex = 0;
  7. byte _btn_pressed = 0xF0;
  8. byte _defaultPriceBuf[501];
  9. void PRINTF_FUNC(char *string, ...);
  10. int StoreLogMsg(const char *fmt, ...);
  11. #define DEBUG_INFO(format, args...) StoreLogMsg("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  12. #define DEBUG_WARN(format, args...) StoreLogMsg("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  13. #define DEBUG_ERROR(format, args...) StoreLogMsg("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  14. char* getTimeString(void);
  15. //=================================
  16. // Common routine
  17. //=================================
  18. int StoreLogMsg(const char *fmt, ...)
  19. {
  20. char Buf[4096+256];
  21. char buffer[4096];
  22. va_list args;
  23. struct timeb SeqEndTime;
  24. struct tm *tm;
  25. va_start(args, fmt);
  26. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  27. va_end(args);
  28. memset(Buf,0,sizeof(Buf));
  29. ftime(&SeqEndTime);
  30. SeqEndTime.time = time(NULL);
  31. tm=localtime(&SeqEndTime.time);
  32. if (ShmSysConfigAndInfo->SysConfig.SwitchDebugFlag == YES)
  33. {
  34. sprintf(Buf,"%02d:%02d:%02d:%03d - %s",
  35. tm->tm_hour,tm->tm_min,tm->tm_sec,SeqEndTime.millitm, buffer);
  36. printf("%s \n", Buf);
  37. }
  38. else
  39. {
  40. sprintf(Buf,"echo \"%04d-%02d-%02d %02d:%02d:%02d:%03d - %s\" >> /Storage/SystemLog/[%04d.%02d]SystemLog_%s_Log",
  41. tm->tm_year+1900,tm->tm_mon+1,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec,SeqEndTime.millitm,
  42. buffer,
  43. tm->tm_year+1900,tm->tm_mon+1,
  44. ShmSysConfigAndInfo->SysConfig.SerialNumber);
  45. system(Buf);
  46. }
  47. return rc;
  48. }
  49. char* getTimeString(void)
  50. {
  51. char *result=malloc(21);
  52. time_t timep;
  53. struct tm *p;
  54. time(&timep);
  55. p=gmtime(&timep);
  56. 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);
  57. return result;
  58. }
  59. void PRINTF_FUNC(char *string, ...)
  60. {
  61. va_list args;
  62. char buffer[4096];
  63. va_start(args, string);
  64. vsnprintf(buffer, sizeof(buffer), string, args);
  65. va_end(args);
  66. DEBUG_INFO("%s ", buffer);
  67. }
  68. //==========================================
  69. // Init all share memory
  70. //==========================================
  71. int InitShareMemory()
  72. {
  73. int result = PASS;
  74. int MeterSMId;
  75. //creat ShmSysConfigAndInfo
  76. if ((MeterSMId = shmget(ShmSysConfigAndInfoKey, sizeof(struct SysConfigAndInfo), 0777)) < 0)
  77. {
  78. #ifdef SystemLogMessage
  79. DEBUG_ERROR("shmget ShmSysConfigAndInfo NG\n");
  80. #endif
  81. result = FAIL;
  82. }
  83. else if ((ShmSysConfigAndInfo = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  84. {
  85. #ifdef SystemLogMessage
  86. DEBUG_ERROR("shmat ShmSysConfigAndInfo NG\n");
  87. #endif
  88. result = FAIL;
  89. }
  90. //creat ShmStatusCodeData
  91. if ((MeterSMId = shmget(ShmStatusCodeKey, sizeof(struct StatusCodeData), 0777)) < 0)
  92. {
  93. #ifdef SystemLogMessage
  94. DEBUG_ERROR("shmget ShmStatusCodeData NG\n");
  95. #endif
  96. result = FAIL;
  97. }
  98. else if ((ShmStatusCodeData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  99. {
  100. #ifdef SystemLogMessage
  101. DEBUG_ERROR("shmat ShmStatusCodeData NG\n");
  102. #endif
  103. result = FAIL;
  104. }
  105. if ((MeterSMId = shmget(ShmCommonKey, sizeof(struct DcCommonInformation), IPC_CREAT | 0777)) < 0)
  106. {
  107. #ifdef SystemLogMessage
  108. DEBUG_ERROR("shmget ShmCommonKey NG \n");
  109. #endif
  110. return 0;
  111. }
  112. else if ((ShmDcCommonData = shmat(MeterSMId, NULL, 0)) == (void *) -1)
  113. {
  114. #ifdef SystemLogMessage
  115. DEBUG_ERROR("shmat ShmCommonKey NG \n");
  116. #endif
  117. return 0;
  118. }
  119. return result;
  120. }
  121. //==========================================
  122. // Open and Close RS232 and R/W
  123. //==========================================
  124. int CreateCommunicationLcmPort()
  125. {
  126. int fd;
  127. struct termios tios;
  128. fd = open(pPortName, O_RDWR);
  129. if (fd <= 0) {
  130. #ifdef SystemLogMessage
  131. DEBUG_ERROR("open /dev/ttyS3 NG \n");
  132. #endif
  133. return -1;
  134. }
  135. ioctl(fd, TCGETS, &tios);
  136. tios.c_cflag = B115200 | CS8 | CLOCAL | CREAD;
  137. tios.c_lflag = 0;
  138. tios.c_iflag = 0;
  139. tios.c_oflag = 0;
  140. tios.c_cc[VMIN] = 0;
  141. tios.c_cc[VTIME] = (unsigned char) 5;
  142. tios.c_lflag = 0;
  143. tcflush(fd, TCIFLUSH);
  144. ioctl(fd, TCSETS, &tios);
  145. return fd;
  146. }
  147. void CloseCommunicationLcmPort()
  148. {
  149. close(Uart1Fd);
  150. }
  151. void WriteCmdToLcm(byte *cmd, byte cmdLen)
  152. {
  153. int len = write(Uart1Fd, cmd, cmdLen);
  154. if(len >= sizeof(cmd))
  155. {
  156. //PRINTF_FUNC("Write cmd to LCM successfully. \n");
  157. }
  158. }
  159. void ReadMsgFromLcm(byte *msg, byte readLen)
  160. {
  161. read(Uart1Fd, msg, readLen);
  162. // 5a : CMD_TITLE_1
  163. // a5 : CMD_TITLE_2
  164. // 5
  165. // 81 : CMD_WRITE
  166. // 3 : CMD_REGISTER
  167. // 2 : Data length
  168. // 0 : High byte
  169. // 1 : Low byte
  170. // printf("-------------------------------------------- \n");
  171. // printf("msg = %x \n", *msg); // A5
  172. // printf("msg = %x \n", *(msg + 1)); // 5A
  173. // printf("msg = %x \n", *(msg + 2)); // Len : [3] ~ [6] + Data Len
  174. // printf("msg = %x \n", *(msg + 3)); // cmd : 0x83
  175. // printf("msg = %x \n", *(msg + 4)); // addr : H
  176. // printf("msg = %x \n", *(msg + 5)); // addr : L
  177. // printf("msg = %x \n", *(msg + 6)); // Data Len
  178. //
  179. // printf("msg = %x \n", *(msg + 7));
  180. // printf("msg = %x \n", *(msg + 8));
  181. // printf("msg = %x \n", *(msg + 9));
  182. // printf("msg = %x \n", *(msg + 10));
  183. // printf("msg = %x \n", *(msg + 11));
  184. // printf("msg = %x \n", *(msg + 12));
  185. // printf("msg = %x \n", *(msg + 13));
  186. // printf("msg = %x \n", *(msg + 14));
  187. if(*msg == CMD_HEADER_1 && *(msg + 1) == CMD_HEADER_2)
  188. {
  189. if(*(msg + 3) == CMD_REG_READ)
  190. {
  191. switch (*(msg + 4))
  192. {
  193. case CMD_REGISTER:
  194. {
  195. // 頁面
  196. if(strcmp((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, "") != EQUAL)
  197. strcpy((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, moduleName);
  198. _currentPage = *(msg + 7);
  199. // if (_currentPage != 1 && _currentPage != 5 && _currentPage != 6 && _currentPage != 7 && _currentPage != 8)
  200. // printf("_currentPage = %d \n", _currentPage);
  201. }
  202. break;
  203. }
  204. }
  205. else if (*(msg + 3) == CMD_REG_READ_DATA)
  206. {
  207. short key = ((short)(*(msg + 4) << 8) + *(msg + 5));
  208. if (key == __lcm_version)
  209. {
  210. ShmDcCommonData->LcmFwVersion = atoi((char *)(msg + 7));
  211. //printf("msg = %d \n", atoi((char *)(msg + 7)));
  212. // printf("msg = %x \n", *(msg + 7));
  213. // printf("msg = %x \n", *(msg + 8));
  214. // printf("msg = %x \n", *(msg + 9));
  215. }
  216. }
  217. }
  218. }
  219. //================================================
  220. // Function
  221. //================================================
  222. void ChangeToOtherPage(short newPage)
  223. {
  224. byte cmd[7];
  225. memset(cmd, 0x00, sizeof(cmd));
  226. cmd[0] = CMD_HEADER_1;
  227. cmd[1] = CMD_HEADER_2;
  228. cmd[2] = 0x02 + sizeof(newPage);
  229. cmd[3] = CMD_REG_WRITE;
  230. cmd[4] = CMD_REGISTER;
  231. cmd[5] = newPage >> 8;
  232. cmd[6] = newPage & 0x00FF;
  233. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  234. usleep(100000);
  235. }
  236. void ChangeBackLight(bool islight)
  237. {
  238. byte value = 0x01;
  239. // 0x00 ~ 0x40
  240. if (islight)
  241. {
  242. value = 0x20;
  243. }
  244. byte cmd[7];
  245. memset(cmd, 0x00, sizeof(cmd));
  246. cmd[0] = CMD_HEADER_1;
  247. cmd[1] = CMD_HEADER_2;
  248. cmd[2] = 0x03;
  249. cmd[3] = CMD_REG_WRITE;
  250. cmd[4] = CMD_BACKLIGHT;
  251. cmd[5] = value;
  252. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  253. usleep(100000);
  254. }
  255. void GetCurrentPage()
  256. {
  257. byte cmd[6];
  258. memset(cmd, 0x00, sizeof(cmd));
  259. byte msg[8];
  260. memset(msg, 0x00, sizeof(msg));
  261. cmd[0] = CMD_HEADER_1;
  262. cmd[1] = CMD_HEADER_2;
  263. cmd[2] = 0x03; // 底下總長度
  264. cmd[3] = CMD_REG_READ;
  265. cmd[4] = CMD_REGISTER;
  266. cmd[5] = 0x02;
  267. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  268. usleep(10000);
  269. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  270. }
  271. void DisplayValueToLcm(short address, byte *data, byte len)
  272. {
  273. byte cmd[256];
  274. memset(cmd, 0x00, sizeof(cmd));
  275. cmd[0] = CMD_HEADER_1;
  276. cmd[1] = CMD_HEADER_2;
  277. cmd[2] = 0x03 + len;
  278. cmd[3] = CMD_REG_WRITE_DATA;
  279. cmd[4] = address >> 8;
  280. cmd[5] = address & 0x00FF;
  281. for(byte count = 0; count < len; count++)
  282. {
  283. cmd[6 + count] = *(data + count);
  284. }
  285. WriteCmdToLcm(cmd, cmd[2] + 3);
  286. }
  287. void DisplayFeeValueToLcm(short address, byte *data, byte len)
  288. {
  289. byte cmd[256];
  290. memset(cmd, 0x00, sizeof(cmd));
  291. cmd[0] = CMD_HEADER_1;
  292. cmd[1] = CMD_HEADER_2;
  293. cmd[2] = 0x03 + len;
  294. cmd[3] = CMD_REG_WRITE_DATA;
  295. cmd[4] = address >> 8;
  296. cmd[5] = address & 0x00FF;
  297. for(byte count = 0; count < len; count++)
  298. {
  299. cmd[12 + count] = *(data + count);
  300. }
  301. WriteCmdToLcm(cmd, cmd[2] + 3);
  302. }
  303. void ChangeDisplay2Value(short address, short value)
  304. {
  305. byte data[2];
  306. data[0] = value >> 8;
  307. data[1] = value & 0x00FF;
  308. DisplayValueToLcm(address, data, sizeof(data));
  309. }
  310. void GetDeviceInfoStatus(short address, byte len)
  311. {
  312. byte cmd[8];
  313. memset(cmd, 0x00, sizeof(cmd));
  314. byte msg[40];
  315. memset(msg, 0x00, sizeof(msg));
  316. cmd[0] = CMD_HEADER_1;
  317. cmd[1] = CMD_HEADER_2;
  318. cmd[2] = 0x04;
  319. cmd[3] = CMD_REG_READ_DATA;
  320. cmd[4] = (address >> 8) & 0xff;
  321. cmd[5] = (address >> 0) & 0xff;
  322. cmd[6] = len;
  323. WriteCmdToLcm(cmd, ARRAY_SIZE(cmd));
  324. usleep(10000);
  325. ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
  326. }
  327. //================================================
  328. // Warning process
  329. //================================================
  330. void string2ByteArray(unsigned char *input, byte *output)
  331. {
  332. int loop;
  333. int i;
  334. loop = 0;
  335. i = 0;
  336. while(input[loop] != '\0')
  337. {
  338. output[i++] = input[loop++];
  339. }
  340. output[loop] = '\0';
  341. }
  342. void ChangeWarningFunc()
  343. {
  344. byte cmd[7];
  345. byte i = 0;
  346. //PRINTF_FUNC("ChangeWarningFunc \n");
  347. // 最多一次五筆
  348. //PRINTF_FUNC("LCM PageIndex = %d \n", ShmSysConfigAndInfo->SysWarningInfo.PageIndex);
  349. //PRINTF_FUNC("WarningCount = %d \n", ShmSysConfigAndInfo->SysWarningInfo.WarningCount);
  350. for(i = 0; (i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5) < ShmSysConfigAndInfo->SysWarningInfo.WarningCount; i++)
  351. {
  352. memset(cmd, 0x00, sizeof(cmd));
  353. if(i >= 5)
  354. {
  355. break;
  356. }
  357. //error code
  358. string2ByteArray(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[i + ShmSysConfigAndInfo->SysWarningInfo.PageIndex * 5][0], cmd);
  359. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  360. //警告標示
  361. memset(cmd, 0x00, sizeof(cmd));
  362. cmd[0] = 0x00;
  363. cmd[1] = 0x01;
  364. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  365. }
  366. memset(cmd, 0x00, sizeof(cmd));
  367. for(; i < 5; i++)
  368. {
  369. DisplayValueToLcm(0x0010 + (i * 6), cmd, sizeof(cmd));
  370. DisplayValueToLcm(0x0002 + (i * 2), cmd, 2);
  371. }
  372. }
  373. //================================================
  374. // QR Code process
  375. //================================================
  376. void ChangeQrCode_Idle(char *input, byte len)
  377. {
  378. byte cmd[len];
  379. int loop = 0;
  380. input[len] = '\0';
  381. cmd[len] = '\0';
  382. while(input[loop] != '\0')
  383. {
  384. cmd[loop] = input[loop];
  385. loop++;
  386. }
  387. //printf("cmd = %s, len = %d \n", cmd, len + 1);
  388. DisplayValueToLcm(__qr_code, cmd, len + 1);
  389. }
  390. void ChangeQrCode_Charge(char *input, byte len)
  391. {
  392. byte cmd[len];
  393. int loop = 0;
  394. input[len] = '\0';
  395. cmd[len] = '\0';
  396. while(input[loop] != '\0')
  397. {
  398. cmd[loop] = input[loop];
  399. loop++;
  400. }
  401. //printf("2 - cmd = %s, len = %d \n", cmd, len + 1);
  402. DisplayValueToLcm(__qr_code_pre, cmd, len + 1);
  403. }
  404. void ChangeQrCode_Comp(char *input, byte len)
  405. {
  406. byte cmd [len];
  407. int loop = 0;
  408. input [len] = '\0';
  409. cmd [len] = '\0';
  410. while (input [loop] != '\0')
  411. {
  412. cmd [loop] = input [loop];
  413. loop ++;
  414. }
  415. DisplayValueToLcm ( __receipt_qrcode, cmd, len + 1 );
  416. }
  417. //================================================
  418. // Change current page
  419. //================================================
  420. void ChangeCurPage()
  421. {
  422. //PRINTF_FUNC("cur = %d, new = %d \n", _currentPage, ShmSysConfigAndInfo->SysInfo.PageIndex);
  423. if (_currentPage != ShmSysConfigAndInfo->SysInfo.PageIndex)
  424. {
  425. //_currentPage = ShmSysConfigAndInfo->SysInfo.PageIndex;
  426. ChangeToOtherPage(ShmSysConfigAndInfo->SysInfo.PageIndex);
  427. _everyPageRollChange = 0;
  428. }
  429. }
  430. //================================================
  431. // Demo
  432. //================================================
  433. byte demoCount = 0;
  434. void DemoFunction()
  435. {
  436. if (demoCount == 0)
  437. {
  438. ShmSysConfigAndInfo->SysWarningInfo.WarningCount = 6;
  439. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[0][0], "000001", 7);
  440. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[1][0], "000002", 7);
  441. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[2][0], "000003", 7);
  442. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[3][0], "000004", 7);
  443. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[4][0], "000005", 7);
  444. memcpy(&ShmSysConfigAndInfo->SysWarningInfo.WarningCode[5][0], "000006", 7);
  445. }
  446. else
  447. {
  448. if (demoCount == 20) {
  449. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_IDLE;
  450. } else if (demoCount == 80) {
  451. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZING;
  452. } else if (demoCount == 100) {
  453. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_COMP;
  454. } else if (demoCount == 120) {
  455. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_AUTHORIZ_FAIL;
  456. } else if (demoCount == 140) {
  457. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_PRE_CHARGE;
  458. } else if (demoCount == 180) {
  459. ShmSysConfigAndInfo->SysInfo.PageIndex = _LCM_CHARGING;
  460. }
  461. }
  462. if (demoCount < 180)
  463. demoCount++;
  464. }
  465. //=======================================
  466. // Download File
  467. //=======================================
  468. void ResetLCM()
  469. {
  470. uint8_t cmd_reset[] = {0x5a, 0xa5};
  471. lcdRegisterWrite(Uart1Fd, 0xee, cmd_reset, ARRAY_SIZE(cmd_reset));
  472. sleep(1);
  473. ChangeToOtherPage(_LCM_FIX);
  474. }
  475. int downloadBIN(uint8_t targetAddr, char *filename)
  476. {
  477. int result = PASS;
  478. int fd;
  479. struct stat fileSt;
  480. uint32_t blocklSize = 1024 * 256;
  481. uint32_t pageSize = 128;
  482. // Get image file size
  483. stat(filename, &fileSt);
  484. uint8_t buf[fileSt.st_size];
  485. PRINTF_FUNC("Target address: %d\n", targetAddr);
  486. PRINTF_FUNC("Bin filename: %s\n", filename);
  487. PRINTF_FUNC("Bin data size: %ld\n", fileSt.st_size);
  488. fd = open(filename, O_RDWR);
  489. if (fd < 0)
  490. {
  491. PRINTF_FUNC("Bin can not be open.\n");
  492. result = FAIL;
  493. }
  494. else
  495. {
  496. // Read data from bin file
  497. memset(buf, 0x00, ARRAY_SIZE(buf));
  498. read(fd, buf, ARRAY_SIZE(buf));
  499. close(fd);
  500. for(uint16_t idxBlock = 0;
  501. idxBlock < (fileSt.st_size % blocklSize == 0?fileSt.st_size / blocklSize : (fileSt.st_size / blocklSize) +1);
  502. idxBlock++)
  503. {
  504. // Download bin file command
  505. uint8_t cmd_download[] = {0x5a, targetAddr + idxBlock};
  506. while(lcdRegisterWrite(Uart1Fd, 0xf3, cmd_download, ARRAY_SIZE(cmd_download)) != PASS)
  507. {
  508. PRINTF_FUNC("Download start fail.\n");
  509. }
  510. // Transfer bin file data content
  511. for(uint16_t idxPage=0; idxPage < (((blocklSize % pageSize) == 0)?(blocklSize / pageSize) : (blocklSize / pageSize) + 1); idxPage++)
  512. {
  513. if((idxBlock * blocklSize) + (idxPage * pageSize) <= ARRAY_SIZE(buf))
  514. {
  515. if(write(Uart1Fd, &buf[(idxBlock * blocklSize)+(idxPage*pageSize)], pageSize) >= pageSize)
  516. {
  517. if (idxPage % 1000 == 0 || pageSize < 128)
  518. PRINTF_FUNC("idxBlock: %d, idxPage: %d, dataLength: %d\n", idxBlock, idxPage, pageSize);
  519. }
  520. }
  521. else
  522. {
  523. if(write(Uart1Fd, &buf[(idxBlock * blocklSize) + (idxPage * pageSize)], (ARRAY_SIZE(buf)-((idxBlock * blocklSize) + ((idxPage -1) * pageSize)))) >= (ARRAY_SIZE(buf)-((idxBlock * blocklSize) + ((idxPage -1) * pageSize))))
  524. {
  525. PRINTF_FUNC("idxBlock: %d, idxPage: %d, dataLength: %d\n", idxBlock, idxPage, (ARRAY_SIZE(buf) - ((idxBlock * blocklSize) + ((idxPage -1) * pageSize))));
  526. }
  527. break;
  528. }
  529. }
  530. sleep(1);
  531. PRINTF_FUNC("Save bin file on 0x%04X success.\n", (targetAddr + idxBlock));
  532. }
  533. }
  534. return result;
  535. }
  536. //=======================================
  537. // Download image
  538. //=======================================
  539. int downloadBMP(uint8_t picIdx, char *filename)
  540. {
  541. int result = PASS;
  542. BMP *bmp;
  543. struct stat fileSt;
  544. uint32_t blocklSize = 1024 * 256;
  545. uint32_t pageSize = 128;
  546. // Get image file size
  547. stat(filename, &fileSt);
  548. bmp = bopen(filename);
  549. uint8_t buf[fileSt.st_size];
  550. PRINTF_FUNC("Target address: %d \n", picIdx);
  551. PRINTF_FUNC("Image filename: %s \n", filename);
  552. PRINTF_FUNC("Image width: %d height: %d \n", bmp->width, bmp->height);
  553. PRINTF_FUNC("Image data size: %d \n", ARRAY_SIZE(buf));
  554. // Get bmp pixel data and convert to 16 bit color
  555. for(uint16_t idxY=0 ; idxY<bmp->height ; idxY++)
  556. {
  557. for(uint16_t idxX=0 ; idxX<bmp->width ; idxX++)
  558. {
  559. uint8_t r, g, b;
  560. get_pixel_rgb(bmp, idxX, (bmp->height-idxY-1), &r, &g, &b);
  561. buf[(2*((idxY*bmp->width) + idxX)) + 0] = ((((r>>3)<<11) | ((g>>2)<<5) | (b>>3)) >> 8) & 0xff;
  562. buf[(2*((idxY*bmp->width) + idxX)) + 1] = ((((r>>3)<<11) | ((g>>2)<<5) | (b>>3)) >> 0) & 0xff;
  563. }
  564. }
  565. bclose(bmp);
  566. uint8_t cmd_download[] = {0x5a, 0x00, (picIdx>>8)&0xff, picIdx&0xff};
  567. while (lcdRegisterWrite ( Uart1Fd, 0xf5, cmd_download, ARRAY_SIZE( cmd_download ) ) != PASS)
  568. {
  569. PRINTF_FUNC ( "Download start fail.\n" );
  570. }
  571. for(uint16_t idxBlock = 0;
  572. idxBlock < (fileSt.st_size % blocklSize == 0?fileSt.st_size / blocklSize : (fileSt.st_size / blocklSize) +1);
  573. idxBlock++)
  574. {
  575. // Transfer bin file data content
  576. for(uint16_t idxPage=0; idxPage < (((blocklSize % pageSize) == 0)?(blocklSize / pageSize) : (blocklSize / pageSize) + 1); idxPage++)
  577. {
  578. if((idxBlock * blocklSize) + (idxPage * pageSize) <= ARRAY_SIZE(buf))
  579. {
  580. if(write(Uart1Fd, &buf[(idxBlock * blocklSize)+(idxPage*pageSize)], pageSize) >= pageSize)
  581. {
  582. if (idxPage % 1000 == 0 || pageSize < 128)
  583. PRINTF_FUNC("idxBlock: %d, idxPage: %d, dataLength: %d\n", idxBlock, idxPage, pageSize);
  584. }
  585. }
  586. else
  587. {
  588. if(write(Uart1Fd, &buf[(idxBlock * blocklSize) + (idxPage * pageSize)], (ARRAY_SIZE(buf)-((idxBlock * blocklSize) + ((idxPage -1) * pageSize)))) >= (ARRAY_SIZE(buf)-((idxBlock * blocklSize) + ((idxPage -1) * pageSize))))
  589. {
  590. PRINTF_FUNC("idxBlock: %d, idxPage: %d, dataLength: %d\n", idxBlock, idxPage, (ARRAY_SIZE(buf) - ((idxBlock * blocklSize) + ((idxPage -1) * pageSize))));
  591. }
  592. break;
  593. }
  594. }
  595. }
  596. PRINTF_FUNC("Save bmp file on 0x%04X success.\n", picIdx);
  597. return result;
  598. }
  599. //================================================
  600. // Update Lcm process
  601. //================================================
  602. int UpdateBMP(char *forlder)
  603. {
  604. int result = PASS;
  605. DIR *dir;
  606. struct dirent *file;
  607. struct stat fileSt;
  608. if ((dir = opendir (forlder)) != NULL)
  609. {
  610. /* print all the files and directories within directory */
  611. while ((file = readdir (dir)) != NULL)
  612. {
  613. if((strlen(file->d_name) > 2))
  614. {
  615. int targetAddr;
  616. stat(file->d_name, &fileSt);
  617. if(sscanf(file->d_name, "%d", &targetAddr) == 1)
  618. {
  619. char targetFile[384];
  620. sprintf(targetFile, "/mnt/lcd/DWIN_SET/%s", file->d_name);
  621. PRINTF_FUNC("file->d_name = %s \n", file->d_name);
  622. if(strstr(file->d_name, ".bmp") != NULL)
  623. {
  624. PRINTF_FUNC("downloadBMP : targetAddr = %d,targetFile = %s \n", targetAddr, targetFile);
  625. downloadBMP(targetAddr, targetFile);
  626. }
  627. }
  628. else
  629. {
  630. PRINTF_FUNC("%s can not parse target address.\n", file->d_name);
  631. }
  632. }
  633. else
  634. {
  635. if(strlen(file->d_name) >= 3)
  636. {
  637. PRINTF_FUNC("File name error.\n");
  638. result = FAIL;
  639. }
  640. else
  641. {
  642. PRINTF_FUNC("Searching file.\n");
  643. }
  644. }
  645. sleep(1);
  646. }
  647. closedir (dir);
  648. }
  649. else
  650. {
  651. PRINTF_FUNC("%s does not valid (UpdateBMP).\n", forlder);
  652. result = FAIL;
  653. }
  654. return result;
  655. }
  656. int UpdateBin(char *forlder)
  657. {
  658. int result = PASS;
  659. DIR *dir;
  660. struct dirent *file;
  661. struct stat fileSt;
  662. if ((dir = opendir (forlder)) != NULL)
  663. {
  664. /* print all the files and directories within directory */
  665. while ((file = readdir (dir)) != NULL)
  666. {
  667. if((strlen(file->d_name) > 2))
  668. {
  669. int targetAddr;
  670. stat(file->d_name, &fileSt);
  671. if(sscanf(file->d_name, "%d", &targetAddr) == 1)
  672. {
  673. char targetFile[384];
  674. sprintf(targetFile, "/mnt/lcd/DWIN_SET/%s", file->d_name);
  675. PRINTF_FUNC("file->d_name = %s \n", file->d_name);
  676. if(strstr(file->d_name, ".bmp") == NULL)
  677. {
  678. PRINTF_FUNC("downloadBIN : targetAddr = %d,targetFile = %s \n", targetAddr, targetFile);
  679. downloadBIN(targetAddr, targetFile);
  680. }
  681. }
  682. else
  683. {
  684. PRINTF_FUNC("%s can not parse target address.\n", file->d_name);
  685. }
  686. }
  687. else
  688. {
  689. if(strlen(file->d_name) >= 3)
  690. {
  691. PRINTF_FUNC("File name error.\n");
  692. result = FAIL;
  693. }
  694. else
  695. {
  696. PRINTF_FUNC("Searching file.\n");
  697. }
  698. }
  699. sleep(1);
  700. }
  701. closedir (dir);
  702. }
  703. else
  704. {
  705. PRINTF_FUNC("%s does not valid (UpdateBin).\n", forlder);
  706. result = FAIL;
  707. }
  708. return result;
  709. }
  710. int lcdUpgrade(char *forlder)
  711. {
  712. int result = PASS;
  713. result = UpdateBMP(forlder);
  714. if (result)
  715. result = UpdateBin(forlder);
  716. return result;
  717. }
  718. void UpdateLcmFunction()
  719. {
  720. if(ShmDcCommonData->_upgrade_lcm_flag)
  721. {
  722. // 固定路徑 /mnt/lcd/DWIN_SET
  723. ChangeDisplay2Value(__qr_code, _disappear);
  724. ChangeDisplay2Value(__receipt_qrcode, _disappear);
  725. ShmDcCommonData->_upgrade_lcm_result = lcdUpgrade("/mnt/lcd/DWIN_SET");
  726. ResetLCM();
  727. ShmDcCommonData->_upgrade_lcm_flag = NO;
  728. }
  729. }
  730. //================================================
  731. // Main process
  732. //================================================
  733. bool FindChargingInfoData(byte target, struct ChargingInfoData **_chargingData)
  734. {
  735. for (byte index = 0; index < CHAdeMO_QUANTITY; index++)
  736. {
  737. if (ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index].Index == target)
  738. {
  739. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.ChademoChargingData[index];
  740. return true;
  741. }
  742. }
  743. for (byte index = 0; index < CCS_QUANTITY; index++)
  744. {
  745. if (ShmSysConfigAndInfo->SysInfo.CcsChargingData[index].Index == target)
  746. {
  747. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.CcsChargingData[index];
  748. return true;
  749. }
  750. }
  751. for (byte index = 0; index < GB_QUANTITY; index++)
  752. {
  753. if (ShmSysConfigAndInfo->SysInfo.GbChargingData[index].Index == target)
  754. {
  755. _chargingData[target] = &ShmSysConfigAndInfo->SysInfo.GbChargingData[index];
  756. return true;
  757. }
  758. }
  759. return false;
  760. }
  761. bool FindAcChargingInfoData(byte target, struct ChargingInfoData **acChargingData)
  762. {
  763. if (target < AC_QUANTITY)
  764. {
  765. acChargingData[target] = &ShmSysConfigAndInfo->SysInfo.AcChargingData[target];
  766. return true;
  767. }
  768. return false;
  769. }
  770. void ChangeAcBattMapAndValue(short page)
  771. {
  772. if (page == _LCM_CHARGING)
  773. {
  774. if (isDiffStatus != _battery_display_ani)
  775. {
  776. isChangeBattMap = false;
  777. isDiffStatus = _battery_display_ani;
  778. }
  779. if (ac_chargingInfo[0]->IsCharging && !isChangeBattMap)
  780. {
  781. isChangeBattMap = true;
  782. if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV5)
  783. {
  784. ChangeDisplay2Value(__batt_map, _battery_empty);
  785. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_EMP;
  786. }
  787. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_EMP)
  788. {
  789. ChangeDisplay2Value(__batt_map, _battery_cap_20);
  790. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_LV1;
  791. }
  792. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV1)
  793. {
  794. ChangeDisplay2Value(__batt_map, _battery_cap_40);
  795. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_LV2;
  796. }
  797. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV2)
  798. {
  799. ChangeDisplay2Value(__batt_map, _battery_cap_60);
  800. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_LV3;
  801. }
  802. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV3)
  803. {
  804. ChangeDisplay2Value(__batt_map, _battery_cap_80);
  805. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_LV4;
  806. }
  807. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV4)
  808. {
  809. ChangeDisplay2Value(__batt_map, _battery_cap_100);
  810. ac_ani_battery_level = _BATTERY_LEVEL_FOR_MAP_LV5;
  811. }
  812. }
  813. }
  814. else if (page == _LCM_COMPLETE)
  815. {
  816. if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV5)
  817. ChangeDisplay2Value(__batt_map, _battery_soc_20);
  818. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_EMP)
  819. ChangeDisplay2Value(__batt_map, _battery_soc_20);
  820. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV1)
  821. ChangeDisplay2Value(__batt_map, _battery_soc_40);
  822. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV2)
  823. ChangeDisplay2Value(__batt_map, _battery_soc_60);
  824. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV3)
  825. ChangeDisplay2Value(__batt_map, _battery_soc_80);
  826. else if (ac_ani_battery_level == _BATTERY_LEVEL_FOR_MAP_LV4)
  827. ChangeDisplay2Value(__batt_map, _battery_soc_100);
  828. }
  829. ChangeDisplay2Value(__soc_value_charging, _disappear);
  830. }
  831. void ChangeBattMapAndValue(short page, int soc)
  832. {
  833. // srand(time(NULL));
  834. // int min = 10;
  835. // int max = 90;
  836. // soc = rand() % (max - min + 1) + min;
  837. if (page == _LCM_PRE_CHARGE)
  838. {
  839. ChangeDisplay2Value(__batt_map_empty, _battery_empty);
  840. }
  841. else if (page == _LCM_CHARGING)
  842. {
  843. if (soc < 20)
  844. {
  845. if (_battery_display_ani)
  846. ChangeDisplay2Value(__batt_map, _battery_empty);
  847. else
  848. ChangeDisplay2Value(__batt_map, _battery_cap_20);
  849. }
  850. else if (soc >= 20 && soc < 40)
  851. {
  852. if (_battery_display_ani)
  853. ChangeDisplay2Value(__batt_map, _battery_cap_20);
  854. else
  855. ChangeDisplay2Value(__batt_map, _battery_cap_40);
  856. }
  857. else if (soc >= 40 && soc < 60)
  858. {
  859. if (_battery_display_ani)
  860. ChangeDisplay2Value(__batt_map, _battery_cap_40);
  861. else
  862. ChangeDisplay2Value(__batt_map, _battery_cap_60);
  863. }
  864. else if (soc >= 60 && soc < 80)
  865. {
  866. if (_battery_display_ani)
  867. ChangeDisplay2Value(__batt_map, _battery_cap_60);
  868. else
  869. ChangeDisplay2Value(__batt_map, _battery_cap_80);
  870. }
  871. else if (soc >= 80 && soc < 100)
  872. {
  873. if (_battery_display_ani)
  874. ChangeDisplay2Value(__batt_map, _battery_cap_80);
  875. else
  876. ChangeDisplay2Value(__batt_map, _battery_cap_100);
  877. }
  878. else if (soc == 100)
  879. ChangeDisplay2Value(__batt_map, _battery_cap_100);
  880. }
  881. else if (page == _LCM_COMPLETE)
  882. {
  883. if (soc < 20)
  884. ChangeDisplay2Value(__batt_map, _battery_soc_20);
  885. else if (soc >= 20 && soc < 40)
  886. ChangeDisplay2Value(__batt_map, _battery_soc_40);
  887. else if (soc >= 40 && soc < 60)
  888. ChangeDisplay2Value(__batt_map, _battery_soc_60);
  889. else if (soc >= 60 && soc < 80)
  890. ChangeDisplay2Value(__batt_map, _battery_soc_80);
  891. else if (soc >= 80 && soc <= 100)
  892. ChangeDisplay2Value(__batt_map, _battery_soc_100);
  893. }
  894. byte cmd[5];
  895. byte value[5];
  896. memset(cmd, 0x00, sizeof(cmd));
  897. memset(value, 0x00, sizeof(value));
  898. sprintf((char *)value, "%d%%", soc);
  899. string2ByteArray(value, cmd);
  900. DisplayValueToLcm(__soc_value_charging, cmd, sizeof(cmd));
  901. }
  902. void ChangeRemainTime(int sec)
  903. {
  904. int h, m, s;
  905. byte cmd[10];
  906. byte value[10];
  907. memset(cmd, 0x00, sizeof(cmd));
  908. // srand(time(NULL));
  909. // int min = 0;
  910. // int max = 65536;
  911. // sec = rand() % (max - min + 1) + min;
  912. h = (sec / 3600);
  913. m = (sec - (3600 * h)) / 60;
  914. s = (sec - (3600 * h) - (m * 60));
  915. sprintf((char *)value, "%02d:%02d:%02d", h, m, s);
  916. string2ByteArray(value, cmd);
  917. DisplayValueToLcm(__remain_time_tx, cmd, sizeof(cmd));
  918. }
  919. void ChangeChargingEnergyValue(float energy)
  920. {
  921. byte cmd[16];
  922. byte value[16];
  923. memset(cmd, 0x00, sizeof(cmd));
  924. if (energy >= 0.00005)
  925. energy -= 0.00005;
  926. sprintf((char *) value, "%.4f kWh", energy);
  927. string2ByteArray(value, cmd);
  928. DisplayValueToLcm(__total_out_eng_tx, cmd, sizeof(cmd));
  929. }
  930. void ChangeChargingPowerValue(float pow)
  931. {
  932. byte cmd[10];
  933. byte value[10];
  934. memset(cmd, 0x00, sizeof(cmd));
  935. // float min = 0.0;
  936. // float max = 50;
  937. // pow = (max - min) * rand() / (RAND_MAX + 1.0) + min;
  938. sprintf((char *) value, "%.1f kW", pow);
  939. string2ByteArray(value, cmd);
  940. DisplayValueToLcm(__output_eng_tx, cmd, sizeof(cmd));
  941. }
  942. void ChangeChargingFeeValue(float fee)
  943. {
  944. byte cmd[10];
  945. byte value[10];
  946. memset(cmd, 0x00, sizeof(cmd));
  947. sprintf((char *) value, "%.2f", fee);
  948. string2ByteArray(value, cmd);
  949. DisplayValueToLcm(__charging_fee_tx, cmd, sizeof(cmd));
  950. }
  951. void ChangeChargingInforForCTEP(short target, double cost)
  952. {
  953. byte cmd[10];
  954. byte value[10];
  955. memset(cmd, 0x00, sizeof(cmd));
  956. sprintf((char *) value, "$%.2f", cost);
  957. string2ByteArray(value, cmd);
  958. DisplayValueToLcm(target, cmd, sizeof(cmd));
  959. }
  960. void DisplayMoneyRate(float money)
  961. {
  962. byte cmd[8];
  963. byte value[8];
  964. memset(cmd, 0x00, sizeof(cmd));
  965. sprintf((char *) value, "%.2f", money);
  966. string2ByteArray(value, cmd);
  967. DisplayValueToLcm(__money_by_rate, cmd, sizeof(cmd));
  968. }
  969. void DisplayMoneyCur(byte *cur)
  970. {
  971. byte cmd[8];
  972. byte buf[8];
  973. memset(cmd, 0x00, sizeof(cmd));
  974. memcpy((char *) buf, cur, 3);
  975. memcpy((char *) buf + 3, "/kWh", 4);
  976. buf[7] = '\0';
  977. string2ByteArray(buf, cmd);
  978. DisplayValueToLcm(__money_rate, cmd, sizeof(cmd));
  979. }
  980. void RefreshPageAnimation(byte value)
  981. {
  982. switch(_currentPage)
  983. {
  984. case _LCM_IDLE:
  985. {
  986. }
  987. break;
  988. case _LCM_WAIT_FOR_PLUG:
  989. {
  990. if(_everyPageRollChange == 0)
  991. ChangeDisplay2Value(__plug_in_arrow, _arrow_dark);
  992. else if(_everyPageRollChange == 15)
  993. ChangeDisplay2Value(__plug_in_arrow, _arrow_light);
  994. _everyPageRollChange > 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  995. }
  996. break;
  997. case _LCM_PRE_CHARGE:
  998. case _LCM_CHARGING:
  999. case _LCM_COMPLETE:
  1000. {
  1001. if (_currentPage == _LCM_PRE_CHARGE)
  1002. {
  1003. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  1004. ChangeDisplay2Value(__conn_line, _conn_map1);
  1005. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  1006. ChangeDisplay2Value(__conn_line, _conn_map2);
  1007. }
  1008. else if (_currentPage == _LCM_CHARGING)
  1009. {
  1010. if (_everyPageRollChange == 0 || _everyPageRollChange == 22)
  1011. ChangeDisplay2Value(__conn_line_chag, _charging_map1);
  1012. else if (_everyPageRollChange == 11 || _everyPageRollChange == 33)
  1013. ChangeDisplay2Value(__conn_line_chag, _charging_map2);
  1014. }
  1015. else if (_currentPage == _LCM_COMPLETE)
  1016. {
  1017. if (_everyPageRollChange == 0)
  1018. ChangeDisplay2Value(__conn_line_comp, _complete_map);
  1019. }
  1020. _everyPageRollChange >= 45 ? _everyPageRollChange = 0 : _everyPageRollChange++;
  1021. }
  1022. break;
  1023. }
  1024. }
  1025. void RefreshConnStatus()
  1026. {
  1027. // eth
  1028. if (ShmSysConfigAndInfo->SysInfo.ethInternetConn == YES)
  1029. { ChangeDisplay2Value(__ethernet_status, _ethernet_connect); }
  1030. else
  1031. { ChangeDisplay2Value(__ethernet_status, _ethernet_disconnect); }
  1032. // Wifi
  1033. if((ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'W' || ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'D') &&
  1034. ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode != _SYS_WIFI_MODE_DISABLE)
  1035. {
  1036. if (ShmSysConfigAndInfo->SysConfig.AthInterface.WifiNetworkConn == YES ||
  1037. ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode == _SYS_WIFI_MODE_AP)
  1038. { ChangeDisplay2Value(__wifi_status, _wifi_connect); }
  1039. else
  1040. { ChangeDisplay2Value(__wifi_status, _wifi_disconnect); }
  1041. }
  1042. else
  1043. {
  1044. ShmSysConfigAndInfo->SysConfig.AthInterface.WifiRssi = 0;
  1045. ChangeDisplay2Value(__wifi_status, _disappear);
  1046. }
  1047. if((ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'T' || ShmSysConfigAndInfo->SysConfig.ModelName[10] == 'D') &&
  1048. ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomEnabled != _SYS_4G_MODE_DISABLE)
  1049. {
  1050. if (ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode == _SYS_WIFI_MODE_DISABLE)
  1051. {
  1052. ChangeDisplay2Value(__3G4G_status, _disappear);
  1053. // 3G/4G
  1054. if (ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomNetworkConn == YES)
  1055. { ChangeDisplay2Value(__3G4G_move_status, _3G4G_connect); }
  1056. else
  1057. { ChangeDisplay2Value(__3G4G_move_status, _3G4G_disconnect); }
  1058. }
  1059. else
  1060. {
  1061. ChangeDisplay2Value(__3G4G_move_status, _disappear);
  1062. // 3G/4G
  1063. if (ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomNetworkConn == YES)
  1064. { ChangeDisplay2Value(__3G4G_status, _3G4G_connect); }
  1065. else
  1066. { ChangeDisplay2Value(__3G4G_status, _3G4G_disconnect); }
  1067. }
  1068. }
  1069. else
  1070. {
  1071. ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomRssi = 0;
  1072. ChangeDisplay2Value(__3G4G_status, _disappear);
  1073. ChangeDisplay2Value(__3G4G_move_status, _disappear);
  1074. }
  1075. // 連線到後台
  1076. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES)
  1077. ChangeDisplay2Value(__conn_status, _connect);
  1078. else
  1079. ChangeDisplay2Value(__conn_status, _disconnect);
  1080. }
  1081. byte FirstPageChanged()
  1082. {
  1083. byte result = NO;
  1084. if (_currentPage != _oldPage)
  1085. {
  1086. result = YES;
  1087. _oldPage = _currentPage;
  1088. }
  1089. return result;
  1090. }
  1091. bool IsPageReloadChk()
  1092. {
  1093. bool result = false;
  1094. if (ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc == NO_DEFINE)
  1095. {
  1096. if (_curPage_index != ShmSysConfigAndInfo->SysInfo.CurGunSelected)
  1097. {
  1098. _curPage_index = ShmSysConfigAndInfo->SysInfo.CurGunSelected;
  1099. result = true;
  1100. }
  1101. }
  1102. else
  1103. {
  1104. if (_curPage_index != ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc)
  1105. {
  1106. _curPage_index = ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc;
  1107. result = true;
  1108. }
  1109. }
  1110. return result;
  1111. }
  1112. bool IsConfigReloadChk()
  1113. {
  1114. bool result = false;
  1115. if (ShmSysConfigAndInfo->SysConfig.QRCodeMadeMode == NO)
  1116. {
  1117. if (strcmp((char *)QRCodeBuf, (char *)ShmSysConfigAndInfo->SysConfig.SystemId) != EQUAL)
  1118. result = true;
  1119. }
  1120. else
  1121. {
  1122. if (strcmp((char *)QRCodeBuf, (char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent) != EQUAL)
  1123. result = true;
  1124. }
  1125. return result;
  1126. }
  1127. void SaveQrcodeToBuf(byte *qrcode)
  1128. {
  1129. strncpy((char *)QRCodeBuf, (char *)qrcode, sizeof(QRCodeBuf));
  1130. }
  1131. void ClearDisplayInfo()
  1132. {
  1133. ChangeDisplay2Value(__csu_ver_string, _disappear);
  1134. ChangeDisplay2Value(__csu_ver_value, _disappear);
  1135. ChangeDisplay2Value(__eth0_ip_string, _disappear);
  1136. ChangeDisplay2Value(__eth0_ip_value, _disappear);
  1137. ChangeDisplay2Value(__sn_string, _disappear);
  1138. ChangeDisplay2Value(__sn_value, _disappear);
  1139. ChangeDisplay2Value(__dc1_ver_string, _disappear);
  1140. ChangeDisplay2Value(__dc1_ver_value, _disappear);
  1141. ChangeDisplay2Value(__dc2_ver_string, _disappear);
  1142. ChangeDisplay2Value(__dc2_ver_value, _disappear);
  1143. ChangeDisplay2Value(__fan_speed_string, _disappear);
  1144. ChangeDisplay2Value(__fan_speed_value, _disappear);
  1145. }
  1146. void DisplayInfoCsuVer(bool isShow, unsigned char *modelName)
  1147. {
  1148. if (isShow)
  1149. {
  1150. byte value[10];
  1151. memset(value, 0x00, sizeof(value));
  1152. strcpy((char *)value, "CSU Ver >");
  1153. DisplayValueToLcm(__csu_ver_string, value, sizeof(value));
  1154. memset(value, 0x00, sizeof(value));
  1155. strncpy((char *)value, (char *)modelName, 5);
  1156. DisplayValueToLcm(__csu_ver_value, value, sizeof(value));
  1157. }
  1158. else
  1159. {
  1160. ChangeDisplay2Value(__csu_ver_string, _disappear);
  1161. ChangeDisplay2Value(__csu_ver_value, _disappear);
  1162. }
  1163. }
  1164. void ShowWifiMode(bool isShow, unsigned char mode)
  1165. {
  1166. if (isShow)
  1167. {
  1168. byte value[20];
  1169. memset(value, 0x00, sizeof(value));
  1170. strcpy((char *) value, "Wifi Mo. >");
  1171. DisplayValueToLcm(__csu_ver_string, value, sizeof(value));
  1172. memset(value, 0x00, sizeof(value));
  1173. if (mode == 0)
  1174. sprintf((char *)value, "disable");
  1175. else if (mode == 1)
  1176. sprintf((char *)value, "station");
  1177. else if (mode == 2)
  1178. sprintf((char *)value, "AP");
  1179. DisplayValueToLcm(__csu_ver_value, value, sizeof(value));
  1180. }
  1181. else
  1182. {
  1183. ChangeDisplay2Value(__csu_ver_string, _disappear);
  1184. ChangeDisplay2Value(__csu_ver_value, _disappear);
  1185. }
  1186. }
  1187. void DisplayInfoEthIp(bool isShow, unsigned char *ip)
  1188. {
  1189. if (isShow)
  1190. {
  1191. byte value[20];
  1192. memset(value, 0x00, sizeof(value));
  1193. strcpy((char *) value, "Eth IP >");
  1194. DisplayValueToLcm(__eth0_ip_string, value, sizeof(value));
  1195. memset(value, 0x00, sizeof(value));
  1196. strcpy((char *) value, (char *) ip);
  1197. DisplayValueToLcm(__eth0_ip_value, value, sizeof(value));
  1198. }
  1199. else
  1200. {
  1201. ChangeDisplay2Value(__eth0_ip_string, _disappear);
  1202. ChangeDisplay2Value(__eth0_ip_value, _disappear);
  1203. }
  1204. }
  1205. void Show4GRssi(bool isShow, int dbValue)
  1206. {
  1207. if (isShow)
  1208. {
  1209. byte value[20];
  1210. memset(value, 0x00, sizeof(value));
  1211. strcpy((char *) value, "RSSI >");
  1212. DisplayValueToLcm(__dc2_ver_string, value, sizeof(value));
  1213. memset(value, 0x00, sizeof(value));
  1214. sprintf((char *)value, "%d dBm", dbValue);
  1215. DisplayValueToLcm(__dc2_ver_value, value, sizeof(value));
  1216. }
  1217. else
  1218. {
  1219. ChangeDisplay2Value(__dc2_ver_string, _disappear);
  1220. ChangeDisplay2Value(__dc2_ver_value, _disappear);
  1221. }
  1222. }
  1223. void DisplayInfoSN(bool isShow, unsigned char *sn)
  1224. {
  1225. if (isShow)
  1226. {
  1227. byte value[30];
  1228. memset(value, 0x00, sizeof(value));
  1229. strcpy((char *) value, "SN >");
  1230. DisplayValueToLcm(__sn_string, value, sizeof(value));
  1231. memset(value, 0x00, sizeof(value));
  1232. strcpy((char *) value, (char *) sn);
  1233. DisplayValueToLcm(__sn_value, value, sizeof(value));
  1234. }
  1235. else
  1236. {
  1237. ChangeDisplay2Value(__sn_string, _disappear);
  1238. ChangeDisplay2Value(__sn_value, _disappear);
  1239. }
  1240. }
  1241. void ShowWifiRssi(bool isShow, int dbValue)
  1242. {
  1243. if (isShow)
  1244. {
  1245. byte value[20];
  1246. memset(value, 0x00, sizeof(value));
  1247. strcpy((char *) value, "RSSI >");
  1248. DisplayValueToLcm(__fan_speed_string, value, sizeof(value));
  1249. memset(value, 0x00, sizeof(value));
  1250. sprintf((char *)value, "%d dBm", dbValue);
  1251. DisplayValueToLcm(__fan_speed_value, value, sizeof(value));
  1252. }
  1253. else
  1254. {
  1255. ChangeDisplay2Value(__fan_speed_string, _disappear);
  1256. ChangeDisplay2Value(__fan_speed_value, _disappear);
  1257. }
  1258. }
  1259. void DisplayInfoGun1Ver(bool isShow, unsigned char *version)
  1260. {
  1261. if (isShow)
  1262. {
  1263. byte value[10];
  1264. memset(value, 0x00, sizeof(value));
  1265. strcpy((char *) value, "Ct1 Ver >");
  1266. DisplayValueToLcm(__dc1_ver_string, value, sizeof(value));
  1267. memset(value, 0x00, sizeof(value));
  1268. strcpy((char *) value, (char *) version);
  1269. DisplayValueToLcm(__dc1_ver_value, value, sizeof(value));
  1270. }
  1271. else
  1272. {
  1273. ChangeDisplay2Value(__dc1_ver_string, _disappear);
  1274. ChangeDisplay2Value(__dc1_ver_value, _disappear);
  1275. }
  1276. }
  1277. void Show4GMode(bool isShow, unsigned char mode)
  1278. {
  1279. if (isShow)
  1280. {
  1281. byte value[20];
  1282. memset(value, 0x00, sizeof(value));
  1283. strcpy((char *) value, "3/4G Mo. >");
  1284. DisplayValueToLcm(__dc1_ver_string, value, sizeof(value));
  1285. memset(value, 0x00, sizeof(value));
  1286. if (mode == 0)
  1287. sprintf((char *)value, "disable");
  1288. else if (mode == 1)
  1289. sprintf((char *)value, "enable");
  1290. DisplayValueToLcm(__dc1_ver_value, value, sizeof(value));
  1291. }
  1292. else
  1293. {
  1294. ChangeDisplay2Value(__dc1_ver_string, _disappear);
  1295. ChangeDisplay2Value(__dc1_ver_value, _disappear);
  1296. }
  1297. }
  1298. void DisplayInfoGun2Ver(bool isShow, unsigned char *version)
  1299. {
  1300. if (isShow)
  1301. {
  1302. byte value[10];
  1303. memset(value, 0x00, sizeof(value));
  1304. strcpy((char *) value, "Ct2 Ver >");
  1305. DisplayValueToLcm(__dc2_ver_string, value, sizeof(value));
  1306. memset(value, 0x00, sizeof(value));
  1307. strcpy((char *) value, (char *) version);
  1308. DisplayValueToLcm(__dc2_ver_value, value, sizeof(value));
  1309. }
  1310. else
  1311. {
  1312. ChangeDisplay2Value(__dc2_ver_string, _disappear);
  1313. ChangeDisplay2Value(__dc2_ver_value, _disappear);
  1314. }
  1315. }
  1316. void Show4GIP(bool isShow, unsigned char *ip)
  1317. {
  1318. if (isShow)
  1319. {
  1320. byte value[20];
  1321. memset(value, 0x00, sizeof(value));
  1322. strcpy((char *) value, "3/4G IP ");
  1323. DisplayValueToLcm(__eth0_ip_string, value, sizeof(value));
  1324. memset(value, 0x00, sizeof(value));
  1325. strcpy((char *) value, (char *) ip);
  1326. DisplayValueToLcm(__eth0_ip_value, value, sizeof(value));
  1327. }
  1328. else
  1329. {
  1330. ChangeDisplay2Value(__eth0_ip_string, _disappear);
  1331. ChangeDisplay2Value(__eth0_ip_value, _disappear);
  1332. }
  1333. }
  1334. void DisplayInfoSpeed(bool isShow, unsigned int fan)
  1335. {
  1336. if (isShow)
  1337. {
  1338. byte value[10];
  1339. memset(value, 0x00, sizeof(value));
  1340. strcpy((char *) value, "Fan Spd >");
  1341. DisplayValueToLcm(__fan_speed_string, value, sizeof(value));
  1342. memset(value, 0x00, sizeof(value));
  1343. sprintf((char *)value, "%d", fan);
  1344. DisplayValueToLcm(__fan_speed_value, value, sizeof(value));
  1345. }
  1346. else
  1347. {
  1348. ChangeDisplay2Value(__fan_speed_string, _disappear);
  1349. ChangeDisplay2Value(__fan_speed_value, _disappear);
  1350. }
  1351. }
  1352. void ShowWifiIP(bool isShow, unsigned char *ip)
  1353. {
  1354. if (isShow)
  1355. {
  1356. byte value[20];
  1357. memset(value, 0x00, sizeof(value));
  1358. strcpy((char *) value, "Wifi IP ");
  1359. DisplayValueToLcm(__sn_string, value, sizeof(value));
  1360. memset(value, 0x00, sizeof(value));
  1361. strcpy((char *) value, (char *) ip);
  1362. DisplayValueToLcm(__sn_value, value, sizeof(value));
  1363. }
  1364. else
  1365. {
  1366. ChangeDisplay2Value(__sn_string, _disappear);
  1367. ChangeDisplay2Value(__sn_value, _disappear);
  1368. }
  1369. }
  1370. void InformationShow()
  1371. {
  1372. if(ShmSysConfigAndInfo->SysConfig.ShowInformation == YES)
  1373. {
  1374. bool show = _isInforShow = true;
  1375. if (_showInformIndex == 0)
  1376. {
  1377. DisplayInfoCsuVer(show, ShmSysConfigAndInfo->SysInfo.CsuRootFsFwRev);
  1378. DisplayInfoSpeed(show, ShmSysConfigAndInfo->SysInfo.SystemFanRotaSpeed);
  1379. DisplayInfoSN(show, ShmSysConfigAndInfo->SysConfig.SerialNumber);
  1380. DisplayInfoEthIp(show, ShmSysConfigAndInfo->SysConfig.Eth0Interface.EthIpAddress);
  1381. DisplayInfoGun1Ver(show, ShmSysConfigAndInfo->SysInfo.Connector1FwRev);
  1382. if (_totalCount > 1)
  1383. DisplayInfoGun2Ver(show, ShmSysConfigAndInfo->SysInfo.Connector2FwRev);
  1384. else
  1385. {
  1386. DisplayInfoGun2Ver(false, ShmSysConfigAndInfo->SysInfo.Connector2FwRev);
  1387. }
  1388. }
  1389. else if (_showInformIndex == 1)
  1390. {
  1391. ShowWifiMode(show, ShmSysConfigAndInfo->SysConfig.AthInterface.WifiMode);
  1392. ShowWifiRssi(show, ShmSysConfigAndInfo->SysConfig.AthInterface.WifiRssi);
  1393. ShowWifiIP(show, ShmSysConfigAndInfo->SysConfig.AthInterface.WifiIpAddress);
  1394. Show4GMode(show, ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomEnabled);
  1395. Show4GRssi(show, ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomRssi);
  1396. Show4GIP(show, ShmSysConfigAndInfo->SysConfig.TelecomInterface.TelcomIpAddress);
  1397. }
  1398. }
  1399. else
  1400. {
  1401. ClearDisplayInfo();
  1402. if (_isInforShow)
  1403. {
  1404. _isInforShow = false;
  1405. _showInformIndex++;
  1406. if (_showInformIndex >= 2)
  1407. _showInformIndex = 0;
  1408. }
  1409. }
  1410. }
  1411. void ProcessPageInfo()
  1412. {
  1413. _page_reload = IsPageReloadChk();
  1414. if (!_page_reload)
  1415. _page_reload = IsConfigReloadChk();
  1416. bool isStatusChanged = (_lcmGunSelect != ShmSysConfigAndInfo->SysInfo.CurGunSelected) ? true : false;
  1417. if (isStatusChanged)
  1418. _lcmGunSelect = ShmSysConfigAndInfo->SysInfo.CurGunSelected;
  1419. else
  1420. isStatusChanged = (_lcmGunStatus != _chargingInfoData [ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus) ? true : false;
  1421. if (isStatusChanged)
  1422. _lcmGunStatus = _chargingInfoData [ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus;
  1423. // 隨插即充 - 可省略該按鈕
  1424. // if (ShmSysConfigAndInfo->SysConfig.AuthorisationMode == AUTH_MODE_ENABLE)
  1425. // {
  1426. // ChangeDisplay2Value(__ret_home_btn, _back_home_btn);
  1427. // if (_totalCount >= 2 && ShmSysConfigAndInfo->SysInfo.IsAlternatvieConf == NO)
  1428. // ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  1429. // else
  1430. // ChangeDisplay2Value(__sel_gun_btn, _disappear);
  1431. // }
  1432. switch(_currentPage)
  1433. {
  1434. case _LCM_IDLE:
  1435. {
  1436. if (ShmSysConfigAndInfo->SysConfig.isRFID)
  1437. ChangeDisplay2Value(__main_rfid, _main_rfid);
  1438. else
  1439. ChangeDisplay2Value(__main_rfid, _main_none_rfid);
  1440. if (ShmSysConfigAndInfo->SysConfig.isQRCode)
  1441. ChangeDisplay2Value(__main_qr, _main_qr);
  1442. else
  1443. {
  1444. ChangeDisplay2Value(__qr_code, _disappear);
  1445. ChangeDisplay2Value(__main_qr, _main_none_qr);
  1446. needReloadQr = true;
  1447. }
  1448. if (ShmSysConfigAndInfo->SysConfig.isAPP)
  1449. ChangeDisplay2Value(__main_app, _main_app);
  1450. else
  1451. ChangeDisplay2Value(__main_app, _main_none_app);
  1452. if (FirstPageChanged() == YES || needReloadQr || _page_reload)
  1453. {
  1454. if (ShmSysConfigAndInfo->SysConfig.isQRCode)
  1455. {
  1456. needReloadQr = false;
  1457. if (ShmSysConfigAndInfo->SysConfig.QRCodeMadeMode == NO)
  1458. {
  1459. byte len = strlen((char *)ShmSysConfigAndInfo->SysConfig.SystemId);
  1460. SaveQrcodeToBuf(ShmSysConfigAndInfo->SysConfig.SystemId);
  1461. ChangeQrCode_Idle((char *)ShmSysConfigAndInfo->SysConfig.SystemId, len);
  1462. }
  1463. else
  1464. {
  1465. byte len = strlen((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent);
  1466. SaveQrcodeToBuf(ShmSysConfigAndInfo->SysConfig.QRCodeContent);
  1467. ChangeQrCode_Idle((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent, len);
  1468. }
  1469. }
  1470. }
  1471. bool isCharging = false;
  1472. for(byte i = 0; i < _totalCount; i++)
  1473. {
  1474. if (_chargingInfoData[i]->SystemStatus == SYS_MODE_IDLE ||
  1475. _chargingInfoData[i]->SystemStatus == SYS_MODE_RESERVATION)
  1476. continue;
  1477. isCharging = true;
  1478. break;
  1479. }
  1480. if (isCharging && ShmSysConfigAndInfo->SysInfo.IsAlternatvieConf == NO)
  1481. {
  1482. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  1483. }
  1484. else
  1485. {
  1486. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  1487. }
  1488. //LW_tpc plug detect
  1489. if (ShmDcCommonData->TpcDetectFunction == YES)
  1490. {
  1491. if (ShmDcCommonData->_tpcPlugDetectState == _TPC_PLUG_DETECT_STATUS_NONE)
  1492. ChangeDisplay2Value ( __tpc_detect_map, _tpc_start_detect_btn );
  1493. else if (ShmDcCommonData->_tpcPlugDetectState == _TPC_PLUG_DETECT_STATUS_WAIT)
  1494. ChangeDisplay2Value ( __tpc_detect_map, _tpc_wait_plugin_btn );
  1495. }
  1496. else
  1497. ChangeDisplay2Value ( __tpc_detect_map, _disappear );
  1498. }
  1499. break;
  1500. case _LCM_AUTHORIZING:
  1501. case _LCM_AUTHORIZ_COMP:
  1502. case _LCM_AUTHORIZ_FAIL:
  1503. {
  1504. }
  1505. break;
  1506. case _LCM_WAIT_FOR_PLUG:
  1507. {
  1508. bool isCharging = false;
  1509. for (byte i = 0; i < _totalCount; i ++)
  1510. {
  1511. if (_chargingInfoData [i]->SystemStatus == SYS_MODE_IDLE ||
  1512. _chargingInfoData [i]->SystemStatus == SYS_MODE_RESERVATION)
  1513. continue;
  1514. isCharging = true;
  1515. break;
  1516. }
  1517. if (ShmSysConfigAndInfo->SysInfo.IsAlternatvieConf == YES)
  1518. {
  1519. ChangeDisplay2Value ( __sel_gun_btn, _disappear );
  1520. }
  1521. else
  1522. {
  1523. if (ShmSysConfigAndInfo->SysConfig.AuthorisationMode == AUTH_MODE_DISABLE ||
  1524. isCharging)
  1525. {
  1526. if (isCharging)
  1527. ChangeDisplay2Value ( __sel_gun_btn, _sel_gun_btn );
  1528. else
  1529. ChangeDisplay2Value ( __sel_gun_btn, _disappear );
  1530. }
  1531. }
  1532. if (ShmSysConfigAndInfo->SysConfig.AuthorisationMode == AUTH_MODE_DISABLE)
  1533. {
  1534. // 新增隨插即充功能預設在等待插槍頁面在開啟
  1535. ChangeDisplay2Value(__ret_home_btn, _disappear);
  1536. }
  1537. else
  1538. ChangeDisplay2Value(__ret_home_btn, _back_home_btn);
  1539. }
  1540. break;
  1541. case _LCM_PRE_CHARGE:
  1542. case _LCM_CHARGING:
  1543. case _LCM_COMPLETE:
  1544. {
  1545. bool isShowAc = false;
  1546. byte gunTargetIndex = 0;
  1547. ChangeDisplay2Value(__ret_home_btn, _back_home_btn);
  1548. if (acgunCount > 0)
  1549. {
  1550. gunTargetIndex = 2;
  1551. if (ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc != NO_DEFINE)
  1552. {
  1553. isShowAc = true;
  1554. if (_currentPage == _LCM_COMPLETE)
  1555. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _actype_light_cmp);
  1556. else
  1557. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _actype_light);
  1558. if (_currentPage == _LCM_CHARGING)
  1559. {
  1560. ChangeAcBattMapAndValue(_LCM_CHARGING);
  1561. if (ac_chargingInfo[0]->PresentChargedDuration >= 0 &&
  1562. ac_chargingInfo[0]->PresentChargedDuration <= TIME_MAX_SEC)
  1563. ChangeRemainTime(ac_chargingInfo[0]->PresentChargedDuration);
  1564. else
  1565. ChangeRemainTime(0);
  1566. if (ac_chargingInfo[0]->PresentChargingPower >= 0.1 &&
  1567. ac_chargingInfo[0]->PresentChargingPower <= POWER_MAX_KW)
  1568. ChangeChargingPowerValue(ac_chargingInfo[0]->PresentChargingPower);
  1569. else
  1570. ChangeChargingPowerValue(0);
  1571. if (ac_chargingInfo[0]->PresentChargedEnergy >= 0.1 &&
  1572. ac_chargingInfo[0]->PresentChargedEnergy <= ENERGY_MAX_KWH)
  1573. ChangeChargingEnergyValue(ac_chargingInfo[0]->PresentChargedEnergy);
  1574. else
  1575. ChangeChargingEnergyValue(0);
  1576. if (ShmSysConfigAndInfo->SysConfig.StopChargingByButton == YES)
  1577. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn);
  1578. else if (strcmp((char *)ac_chargingInfo[0]->StartUserId, "") != EQUAL)
  1579. ChangeDisplay2Value(__stop_method_btn, _stop_charging_btn_scan);
  1580. else
  1581. ChangeDisplay2Value(__stop_method_btn, _disappear);
  1582. }
  1583. else if (_currentPage == _LCM_COMPLETE)
  1584. {
  1585. ChangeAcBattMapAndValue(_LCM_COMPLETE);
  1586. if (ac_chargingInfo[0]->PresentChargedDuration >= 0 &&
  1587. ac_chargingInfo[0]->PresentChargedDuration <= TIME_MAX_SEC)
  1588. ChangeRemainTime(ac_chargingInfo[0]->PresentChargedDuration);
  1589. else
  1590. ChangeRemainTime(0);
  1591. if (ac_chargingInfo[0]->PresentChargingPower >= 0.1 &&
  1592. ac_chargingInfo[0]->PresentChargingPower <= POWER_MAX_KW)
  1593. ChangeChargingPowerValue(ac_chargingInfo[0]->PresentChargingPower);
  1594. else
  1595. ChangeChargingPowerValue(0);
  1596. if ((ac_chargingInfo[0]->PresentChargedEnergy >= 0.1 &&
  1597. ac_chargingInfo[0]->PresentChargedEnergy <= ENERGY_MAX_KWH) ||
  1598. (strcmp((char *)ShmSysConfigAndInfo->SysConfig.OcppServerURL, "") != EQUAL &&
  1599. strcmp((char *)ShmSysConfigAndInfo->SysConfig.ChargeBoxId, "") != EQUAL))
  1600. {
  1601. ChangeChargingEnergyValue(ac_chargingInfo[0]->PresentChargedEnergy);
  1602. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling &&
  1603. ac_chargingInfo[0]->ChargingFee >= 0)
  1604. {
  1605. ChangeChargingFeeValue(ac_chargingInfo[0]->ChargingFee);
  1606. }
  1607. }
  1608. else
  1609. {
  1610. ChangeChargingEnergyValue(0);
  1611. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1612. ChangeChargingFeeValue(0);
  1613. }
  1614. if(!ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1615. {
  1616. ChangeDisplay2Value(__charging_fee_map, _disappear);
  1617. ChangeDisplay2Value(__charging_fee_tx, _disappear);
  1618. }
  1619. else
  1620. {
  1621. ChangeDisplay2Value(__charging_fee_map, _money_map);
  1622. }
  1623. }
  1624. }
  1625. else
  1626. {
  1627. if (_currentPage == _LCM_COMPLETE)
  1628. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _actype_dark_cmp);
  1629. else
  1630. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _actype_dark);
  1631. }
  1632. }
  1633. else
  1634. {
  1635. // 超過一把槍, 把中間圖隱藏
  1636. if (_totalCount > 1)
  1637. {
  1638. gunTargetIndex = 2;
  1639. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _disappear);
  1640. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _disappear);
  1641. }
  1642. }
  1643. gunTargetIndex = 0;
  1644. for(byte i = 0; i < _totalCount; i++)
  1645. {
  1646. if (_totalCount == 1 && acgunCount <= 0)
  1647. {
  1648. if (ShmSysConfigAndInfo->SysInfo.ChargerType != _CHARGER_TYPE_JARI)
  1649. {
  1650. gunTargetIndex = 2;
  1651. }
  1652. //
  1653. // if (ShmSysConfigAndInfo->SysInfo.ChargerType == _CHARGER_TYPE_JARI)
  1654. // gunTargetIndex = 1;
  1655. // else
  1656. // gunTargetIndex = 2;
  1657. }
  1658. else
  1659. gunTargetIndex = i;
  1660. switch(_chargingInfoData[i]->Type)
  1661. {
  1662. case _Type_Chademo:
  1663. {
  1664. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i && !isShowAc)
  1665. {
  1666. if (_totalCount >= 2 && ShmSysConfigAndInfo->SysInfo.ChargerType == _CHARGER_TYPE_JARI)
  1667. {
  1668. if (_currentPage == _LCM_COMPLETE)
  1669. {
  1670. if (i == 0)
  1671. ChangeDisplay2Value(__cmp_gun_type_index_jp + (gunTargetIndex * 2), _n1_jp_cha_light_cmp);
  1672. else
  1673. ChangeDisplay2Value(__cmp_gun_type_index_jp + (gunTargetIndex * 2), _n2_jp_cha_light_cmp);
  1674. }
  1675. else
  1676. {
  1677. if (i == 0)
  1678. ChangeDisplay2Value(__gun_type_index_jp + (gunTargetIndex * 2), _n1_jp_cha_light);
  1679. else
  1680. ChangeDisplay2Value(__gun_type_index_jp + (gunTargetIndex * 2), _n2_jp_cha_light);
  1681. }
  1682. }
  1683. else
  1684. {
  1685. if (_currentPage == _LCM_COMPLETE)
  1686. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _chademo_light_cmp);
  1687. else
  1688. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _chademo_light);
  1689. }
  1690. }
  1691. else
  1692. {
  1693. if (_totalCount >= 2 && ShmSysConfigAndInfo->SysInfo.ChargerType == _CHARGER_TYPE_JARI)
  1694. {
  1695. if (_currentPage == _LCM_COMPLETE)
  1696. {
  1697. if (i == 0)
  1698. ChangeDisplay2Value(__cmp_gun_type_index_jp + (gunTargetIndex * 2), _n1_jp_cha_dark_cmp);
  1699. else
  1700. ChangeDisplay2Value(__cmp_gun_type_index_jp + (gunTargetIndex * 2), _n2_jp_cha_dark_cmp);
  1701. }
  1702. else
  1703. {
  1704. if (i == 0)
  1705. ChangeDisplay2Value(__gun_type_index_jp + (gunTargetIndex * 2), _n1_jp_cha_dark);
  1706. else
  1707. ChangeDisplay2Value(__gun_type_index_jp + (gunTargetIndex * 2), _n2_jp_cha_dark);
  1708. }
  1709. }
  1710. else
  1711. {
  1712. if (_currentPage == _LCM_COMPLETE)
  1713. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _chademo_dark_cmp);
  1714. else
  1715. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _chademo_dark);
  1716. }
  1717. }
  1718. }
  1719. break;
  1720. case _Type_GB:
  1721. {
  1722. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i && !isShowAc)
  1723. {
  1724. if (_currentPage == _LCM_COMPLETE)
  1725. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _gbt_light_cmp);
  1726. else
  1727. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _gbt_light);
  1728. }
  1729. else
  1730. {
  1731. if (_currentPage == _LCM_COMPLETE)
  1732. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _gbt_dark_cmp);
  1733. else
  1734. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _gbt_dark);
  1735. }
  1736. }
  1737. break;
  1738. case _Type_CCS:
  1739. {
  1740. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i && !isShowAc)
  1741. {
  1742. if (_currentPage == _LCM_COMPLETE)
  1743. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _ccs_light_cmp);
  1744. else
  1745. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _ccs_light);
  1746. }
  1747. else
  1748. {
  1749. if (_currentPage == _LCM_COMPLETE)
  1750. ChangeDisplay2Value(__cmp_gun_type_index + (gunTargetIndex * 2), _ccs_dark_cmp);
  1751. else
  1752. ChangeDisplay2Value(__gun_type_index + (gunTargetIndex * 2), _ccs_dark);
  1753. }
  1754. }
  1755. break;
  1756. }
  1757. if (_currentPage == _LCM_PRE_CHARGE && !isShowAc)
  1758. {
  1759. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  1760. {
  1761. ChangeBattMapAndValue(_currentPage, _chargingInfoData[i]->EvBatterySoc);
  1762. }
  1763. }
  1764. else if (_currentPage == _LCM_CHARGING && !isShowAc)
  1765. {
  1766. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  1767. {
  1768. ChangeBattMapAndValue(_currentPage, _chargingInfoData[i]->EvBatterySoc);
  1769. if (_chargingInfoData[i]->PresentChargedDuration >= 0 &&
  1770. _chargingInfoData[i]->PresentChargedDuration <= TIME_MAX_SEC)
  1771. ChangeRemainTime(_chargingInfoData[i]->PresentChargedDuration);
  1772. else
  1773. ChangeRemainTime(0);
  1774. if (_chargingInfoData[i]->PresentChargingPower >= 0 &&
  1775. _chargingInfoData[i]->PresentChargingPower <= POWER_MAX_KW)
  1776. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  1777. else
  1778. ChangeChargingPowerValue(0);
  1779. if (_chargingInfoData[i]->PresentChargedEnergy <= ENERGY_MAX_KWH)
  1780. ChangeChargingEnergyValue(_chargingInfoData[i]->PresentChargedEnergy);
  1781. else
  1782. ChangeChargingEnergyValue(0);
  1783. if (ShmSysConfigAndInfo->SysConfig.StopChargingByButton == YES)
  1784. ChangeDisplay2Value ( __stop_method_btn, _stop_charging_btn );
  1785. else if (strcmp((char *)_chargingInfoData[i]->StartUserId, "") != EQUAL)
  1786. ChangeDisplay2Value ( __stop_method_btn, _stop_charging_btn_scan );
  1787. else
  1788. ChangeDisplay2Value ( __stop_method_btn, _disappear );
  1789. // CTEP
  1790. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES &&
  1791. strlen ( (char *) ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL ) > 0 &&
  1792. ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1793. {
  1794. if (ShmDcCommonData->cdfaInfor[i]._ctepEnergyCost > 0)
  1795. ChangeChargingInforForCTEP (__Energy_Cost_charging, ShmDcCommonData->cdfaInfor[i]._ctepEnergyCost);
  1796. else
  1797. ChangeChargingInforForCTEP (__Energy_Cost_charging, 0 );
  1798. if (ShmDcCommonData->cdfaInfor[i]._ctepParkingFee > 0)
  1799. ChangeChargingInforForCTEP (__Parking_Fee_charging, ShmDcCommonData->cdfaInfor[i]._ctepParkingFee);
  1800. else
  1801. ChangeChargingInforForCTEP (__Parking_Fee_charging, 0 );
  1802. if (ShmDcCommonData->cdfaInfor[i]._ctepTotalCost > 0)
  1803. ChangeChargingInforForCTEP (__Total_Cost_charging, ShmDcCommonData->cdfaInfor[i]._ctepTotalCost);
  1804. else
  1805. ChangeChargingInforForCTEP (__Total_Cost_charging, 0 );
  1806. }
  1807. }
  1808. }
  1809. else if (_currentPage == _LCM_COMPLETE && !isShowAc)
  1810. {
  1811. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == i)
  1812. {
  1813. ChangeBattMapAndValue(_currentPage, _chargingInfoData[i]->EvBatterySoc);
  1814. if (_chargingInfoData[i]->PresentChargedDuration >= 0 &&
  1815. _chargingInfoData[i]->PresentChargedDuration <= TIME_MAX_SEC)
  1816. ChangeRemainTime(_chargingInfoData[i]->PresentChargedDuration);
  1817. else
  1818. ChangeRemainTime(0);
  1819. if (_chargingInfoData[i]->PresentChargingPower >= 0 &&
  1820. _chargingInfoData[i]->PresentChargingPower <= POWER_MAX_KW)
  1821. ChangeChargingPowerValue(_chargingInfoData[i]->PresentChargingPower);
  1822. else
  1823. ChangeChargingPowerValue(0);
  1824. if ((_chargingInfoData[i]->PresentChargedEnergy <= ENERGY_MAX_KWH) ||
  1825. (strcmp((char *)ShmSysConfigAndInfo->SysConfig.OcppServerURL, "") != EQUAL &&
  1826. strcmp((char *)ShmSysConfigAndInfo->SysConfig.ChargeBoxId, "") != EQUAL))
  1827. {
  1828. ChangeChargingEnergyValue(_chargingInfoData[i]->PresentChargedEnergy);
  1829. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling &&
  1830. _chargingInfoData[i]->ChargingFee >= 0)
  1831. {
  1832. ChangeChargingFeeValue(_chargingInfoData[i]->ChargingFee);
  1833. }
  1834. }
  1835. else
  1836. {
  1837. ChangeChargingEnergyValue(0);
  1838. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1839. ChangeChargingFeeValue(0);
  1840. }
  1841. if(!ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1842. {
  1843. ChangeDisplay2Value(__charging_fee_map, _disappear);
  1844. ChangeDisplay2Value(__charging_fee_tx, _disappear);
  1845. }
  1846. else
  1847. {
  1848. ChangeDisplay2Value(__charging_fee_map, _money_map);
  1849. }
  1850. // CTEP
  1851. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES &&
  1852. strlen ( (char *) ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL ) > 0 &&
  1853. ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  1854. {
  1855. if (ShmDcCommonData->cdfaInfor[i]._ctepEnergyCost > 0)
  1856. ChangeChargingInforForCTEP (__Energy_Cost_comp, ShmDcCommonData->cdfaInfor[i]._ctepEnergyCost);
  1857. else
  1858. ChangeChargingInforForCTEP (__Energy_Cost_comp, 0 );
  1859. if (ShmDcCommonData->cdfaInfor[i]._ctepParkingFee > 0)
  1860. ChangeChargingInforForCTEP (__Parking_Fee_comp, ShmDcCommonData->cdfaInfor[i]._ctepParkingFee);
  1861. else
  1862. ChangeChargingInforForCTEP (__Parking_Fee_comp, 0 );
  1863. if (ShmDcCommonData->cdfaInfor[i]._ctepTotalCost > 0)
  1864. ChangeChargingInforForCTEP (__Total_Cost_comp, ShmDcCommonData->cdfaInfor[i]._ctepTotalCost);
  1865. else
  1866. ChangeChargingInforForCTEP (__Total_Cost_comp, 0 );
  1867. }
  1868. }
  1869. }
  1870. }
  1871. if (_totalCount > 1 &&
  1872. ShmSysConfigAndInfo->SysInfo.IsAlternatvieConf == NO)
  1873. {
  1874. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  1875. }
  1876. else
  1877. {
  1878. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  1879. }
  1880. // gun btn and QR code
  1881. if (_totalCount + acgunCount >= 2 && _currentPage)
  1882. {
  1883. byte index = 0;
  1884. for(index = 0; index < _totalCount; index++)
  1885. {
  1886. if(ShmSysConfigAndInfo->SysInfo.CurGunSelected != index)
  1887. {
  1888. break;
  1889. }
  1890. }
  1891. if (_chargingInfoData[index]->SystemStatus == SYS_MODE_IDLE ||
  1892. _chargingInfoData[index]->SystemStatus == SYS_MODE_RESERVATION ||
  1893. _chargingInfoData[index]->SystemStatus == SYS_MODE_BOOTING)
  1894. {
  1895. if (FirstPageChanged() == YES || needReloadQr || _page_reload)
  1896. {
  1897. if (ShmSysConfigAndInfo->SysConfig.isQRCode)
  1898. {
  1899. needReloadQr = false;
  1900. if (ShmSysConfigAndInfo->SysConfig.QRCodeMadeMode == NO)
  1901. {
  1902. byte len = strlen((char *)ShmSysConfigAndInfo->SysConfig.SystemId);
  1903. ChangeQrCode_Charge((char *)ShmSysConfigAndInfo->SysConfig.SystemId, len);
  1904. }
  1905. else
  1906. {
  1907. byte len = strlen((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent);
  1908. ChangeQrCode_Charge((char *)ShmSysConfigAndInfo->SysConfig.QRCodeContent, len);
  1909. }
  1910. }
  1911. }
  1912. }
  1913. }
  1914. }
  1915. break;
  1916. }
  1917. if (_page_reload || isStatusChanged)
  1918. {
  1919. if (_chargingInfoData [ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus == SYS_MODE_COMPLETE ||
  1920. _chargingInfoData [ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus == SYS_MODE_ALARM)
  1921. {
  1922. if (isStatusChanged)
  1923. {
  1924. char showStr [525];
  1925. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES &&
  1926. ShmSysConfigAndInfo->SysConfig.BillingData.isBilling &&
  1927. ShmDcCommonData->startTransactionID[ShmSysConfigAndInfo->SysInfo.CurGunSelected] != 0)
  1928. {
  1929. if (ShmDcCommonData->_useVersion == _CDFA_VERSION_10 &&
  1930. strlen ((char *) ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL) > 0)
  1931. {
  1932. sprintf ( showStr, "%s%d",
  1933. ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL,
  1934. ShmDcCommonData->startTransactionID [ShmSysConfigAndInfo->SysInfo.CurGunSelected]);
  1935. byte len = strlen ( (char *) showStr );
  1936. ChangeQrCode_Comp ( (char *) showStr, len );
  1937. ChangeDisplay2Value ( __receipt_qrcode_bg, _ctep_qr_background );
  1938. }
  1939. else if (ShmDcCommonData->_useVersion == _CDFA_VERSION_20 &&
  1940. strcmp((char*)ShmDcCommonData->cdfaInfor[ShmSysConfigAndInfo->SysInfo.CurGunSelected]._preQrCodeText, "") != EQUAL)
  1941. {
  1942. byte len = strlen ( (char *) ShmDcCommonData->cdfaInfor[ShmSysConfigAndInfo->SysInfo.CurGunSelected]._preQrCodeText );
  1943. ChangeQrCode_Comp ( (char *) ShmDcCommonData->cdfaInfor[ShmSysConfigAndInfo->SysInfo.CurGunSelected]._preQrCodeText, len );
  1944. ChangeDisplay2Value ( __receipt_qrcode_bg, _ctep_qr_background );
  1945. }
  1946. else
  1947. {
  1948. ChangeDisplay2Value ( __receipt_qrcode, _disappear );
  1949. ChangeDisplay2Value ( __receipt_qrcode_bg, _disappear );
  1950. }
  1951. }
  1952. else
  1953. {
  1954. ChangeDisplay2Value ( __receipt_qrcode, _disappear );
  1955. ChangeDisplay2Value ( __receipt_qrcode_bg, _disappear );
  1956. }
  1957. }
  1958. }
  1959. }
  1960. }
  1961. void ChangeDisplayMoneyInfoWithoutBackend()
  1962. {
  1963. struct timeb csuTime;
  1964. struct tm *tmCSU;
  1965. ftime(&csuTime);
  1966. tmCSU = localtime(&csuTime.time);
  1967. if (tmCSU->tm_hour <= 23)
  1968. {
  1969. ShmDcCommonData->_hour_index = tmCSU->tm_hour;
  1970. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = ShmSysConfigAndInfo->SysConfig.BillingData.Fee[tmCSU->tm_hour];
  1971. DisplayMoneyRate(ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee);
  1972. }
  1973. }
  1974. void ChangeDisplayMoneyInfo()
  1975. {
  1976. struct timeb csuTime;
  1977. struct tm *tmCSU;
  1978. ftime(&csuTime);
  1979. tmCSU = localtime(&csuTime.time);
  1980. ChangeDisplay2Value(__money_rate_map, _charging_money);
  1981. ShmDcCommonData->_hour_index = tmCSU->tm_hour;
  1982. if (ShmSysConfigAndInfo->SysInfo.CurGunSelectedByAc == DEFAULT_AC_INDEX)
  1983. {
  1984. if (ac_chargingInfo[0]->SystemStatus == SYS_MODE_IDLE ||
  1985. ac_chargingInfo[0]->SystemStatus == SYS_MODE_MAINTAIN ||
  1986. ac_chargingInfo[0]->SystemStatus == SYS_MODE_RESERVATION)
  1987. {
  1988. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = (float)ShmDcCommonData->balanceInfo.defaultPrice_Noodoe / 100;
  1989. }
  1990. else
  1991. {
  1992. if (ShmSysConfigAndInfo->SysConfig.TotalConnectorCount > 0)
  1993. {
  1994. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[1].UserPrice == 0)
  1995. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = (float)ShmDcCommonData->balanceInfo.defaultPrice_Noodoe / 100;
  1996. else
  1997. {
  1998. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee =
  1999. (float)ShmDcCommonData->balanceInfo.connectorBalanceInfo[1].UserPrice / 100;
  2000. }
  2001. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[1].AccountBalance > 0)
  2002. ac_chargingInfo[0]->ChargingFee = (float)ShmDcCommonData->balanceInfo.connectorBalanceInfo[1].AccountBalance / 100;
  2003. else
  2004. ac_chargingInfo[0]->ChargingFee = 0;
  2005. }
  2006. else
  2007. {
  2008. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[0].UserPrice == 0)
  2009. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = (float)ShmDcCommonData->balanceInfo.defaultPrice_Noodoe / 100;
  2010. else
  2011. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = ShmDcCommonData->balanceInfo.connectorBalanceInfo[0].UserPrice;
  2012. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[0].AccountBalance > 0)
  2013. ac_chargingInfo[0]->ChargingFee = (float)ShmDcCommonData->balanceInfo.connectorBalanceInfo[0].AccountBalance / 100;
  2014. else
  2015. ac_chargingInfo[0]->ChargingFee = 0;
  2016. }
  2017. }
  2018. DisplayMoneyRate(ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee);
  2019. }
  2020. else
  2021. {
  2022. if (_chargingInfoData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus == SYS_MODE_IDLE ||
  2023. _chargingInfoData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus == SYS_MODE_MAINTAIN ||
  2024. _chargingInfoData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->SystemStatus == SYS_MODE_RESERVATION)
  2025. {
  2026. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = (float)ShmDcCommonData->balanceInfo.defaultPrice_Noodoe / 100;
  2027. }
  2028. else
  2029. {
  2030. byte acGunIndex = 0;
  2031. if (ShmSysConfigAndInfo->SysInfo.CurGunSelected == 1)
  2032. acGunIndex = ShmSysConfigAndInfo->SysConfig.AcConnectorCount;
  2033. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[ShmSysConfigAndInfo->SysInfo.CurGunSelected + acGunIndex].UserPrice == 0)
  2034. {
  2035. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee = (float)ShmDcCommonData->balanceInfo.defaultPrice_Noodoe / 100;
  2036. }
  2037. else
  2038. {
  2039. ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee =
  2040. (float)ShmDcCommonData->balanceInfo.connectorBalanceInfo[ShmSysConfigAndInfo->SysInfo.CurGunSelected + acGunIndex].UserPrice / 100;
  2041. }
  2042. if (ShmDcCommonData->balanceInfo.connectorBalanceInfo[ShmSysConfigAndInfo->SysInfo.CurGunSelected + acGunIndex].AccountBalance > 0)
  2043. {
  2044. _chargingInfoData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->ChargingFee =
  2045. (float)ShmDcCommonData->balanceInfo.connectorBalanceInfo[ShmSysConfigAndInfo->SysInfo.CurGunSelected + acGunIndex].AccountBalance / 100;
  2046. }
  2047. else
  2048. {
  2049. _chargingInfoData[ShmSysConfigAndInfo->SysInfo.CurGunSelected]->ChargingFee = 0;
  2050. }
  2051. }
  2052. DisplayMoneyRate(ShmSysConfigAndInfo->SysConfig.BillingData.Cur_fee);
  2053. }
  2054. }
  2055. void ChangeDisplayCtepMoneyInfo()
  2056. {
  2057. byte cmd [230];
  2058. memset(cmd, 0x00, sizeof(cmd));
  2059. string2ByteArray((byte *) _defaultPriceBuf, cmd);
  2060. DisplayFeeValueToLcm(__scroll_display_value, cmd, sizeof(cmd));
  2061. }
  2062. void Initialization()
  2063. {
  2064. bool isPass = false;
  2065. byte count = 5;
  2066. while(!isPass && count > 0)
  2067. {
  2068. isPass = true;
  2069. for (byte _index = 0; _index < _totalCount; _index++)
  2070. {
  2071. _lcmGunSelect = GUN_LEFT;
  2072. if (!FindChargingInfoData(_index, &_chargingInfoData[0]))
  2073. {
  2074. DEBUG_ERROR("LcmComm (main) : FindChargingInfoData false \n");
  2075. isPass = false;
  2076. count--;
  2077. break;
  2078. }
  2079. }
  2080. sleep(1);
  2081. }
  2082. isPass = false;
  2083. if (acgunCount > 0)
  2084. {
  2085. while(!isPass)
  2086. {
  2087. isPass = true;
  2088. for (byte _index = 0; _index < acgunCount; _index++)
  2089. {
  2090. if (!FindAcChargingInfoData(_index, &ac_chargingInfo[0]))
  2091. {
  2092. DEBUG_ERROR("LcmComm : FindAcChargingInfoData false \n");
  2093. isPass = false;
  2094. break;
  2095. }
  2096. }
  2097. sleep(1);
  2098. }
  2099. }
  2100. if (count == 0)
  2101. PRINTF_FUNC("LCM Initialization Gun Fail.............\n");
  2102. }
  2103. void DefaultIconStatus()
  2104. {
  2105. for(byte i = 0; i < 3; i++)
  2106. ChangeDisplay2Value(__gun_type_index + (i * 2), _disappear);
  2107. for(byte i = 0; i < 3; i++)
  2108. ChangeDisplay2Value(__cmp_gun_type_index + (i * 2), _disappear);
  2109. for(byte i = 0; i < 2; i++)
  2110. ChangeDisplay2Value(__gun_type_index_jp + (i * 2), _disappear);
  2111. for(byte i = 0; i < 2; i++)
  2112. ChangeDisplay2Value(__cmp_gun_type_index_jp + (i * 2), _disappear);
  2113. if (ShmSysConfigAndInfo->SysInfo.IsAlternatvieConf == YES || _totalCount == 1)
  2114. ChangeDisplay2Value(__sel_gun_btn, _disappear);
  2115. else
  2116. ChangeDisplay2Value(__sel_gun_btn, _sel_gun_btn);
  2117. if (ShmDcCommonData->ShowLogoFlag)
  2118. {
  2119. ChangeDisplay2Value(__logo, _logo);
  2120. ChangeDisplay2Value(__logo_cmp, _logo_cmp);
  2121. }
  2122. else
  2123. {
  2124. ChangeDisplay2Value(__logo, _disappear);
  2125. ChangeDisplay2Value(__logo_cmp, _disappear);
  2126. }
  2127. //LW_tpc plug detects
  2128. if (ShmDcCommonData->TpcDetectFunction == YES)
  2129. ChangeDisplay2Value(__tpc_detect_map, _tpc_start_detect_btn);
  2130. else
  2131. ChangeDisplay2Value(__tpc_detect_map, _disappear);
  2132. char _buf[3] = {0};
  2133. memcpy(_buf, &ShmSysConfigAndInfo->SysConfig.ModelName[12], 2);
  2134. // N0 : 拓連
  2135. // if (ShmDcCommonData->ShowLogoFlag &&
  2136. // strcmp(_buf, "N0") != EQUAL)
  2137. if (strcmp(_buf, "N0") != EQUAL)
  2138. {
  2139. ChangeDisplay2Value(__phihong_string, _phihong_string_map);
  2140. }
  2141. else
  2142. {
  2143. ChangeDisplay2Value(__phihong_string, _disappear);
  2144. }
  2145. }
  2146. void DisplaySystemDate()
  2147. {
  2148. byte cmd [16];
  2149. memset (cmd, 0x00, sizeof(cmd));
  2150. string2ByteArray(ShmDcCommonData->_sys_date, cmd);
  2151. DisplayValueToLcm(__sys_date_value, cmd, sizeof(cmd));
  2152. memset ( cmd, 0x00, sizeof(cmd) );
  2153. string2ByteArray ( ShmDcCommonData->_sys_time, cmd );
  2154. DisplayValueToLcm ( __sys_time_value, cmd, sizeof(cmd) );
  2155. memset ( cmd, 0x00, sizeof(cmd) );
  2156. string2ByteArray ( ShmDcCommonData->_sys_period, cmd );
  2157. DisplayValueToLcm ( __sys_period_value, cmd, sizeof(cmd) );
  2158. }
  2159. void SetCtepString(bool isShow)
  2160. {
  2161. if(isShow)
  2162. {
  2163. byte cmd [16];
  2164. memset ( cmd, 0x00, sizeof(cmd) );
  2165. sprintf ( (char *) cmd, "hrs:mins:secs");
  2166. DisplayValueToLcm ( __ctep_time_string, cmd, sizeof(cmd) );
  2167. memset ( cmd, 0x00, sizeof(cmd) );
  2168. sprintf ( (char *) cmd, "Energy" );
  2169. DisplayValueToLcm ( __ctep_energy_string, cmd, sizeof(cmd) );
  2170. memset ( cmd, 0x00, sizeof(cmd) );
  2171. sprintf ( (char *) cmd, "Energy Cost" );
  2172. DisplayValueToLcm ( __ctep_energy_mon_string, cmd, sizeof(cmd) );
  2173. memset ( cmd, 0x00, sizeof(cmd) );
  2174. sprintf ( (char *) cmd, "Packing Fee" );
  2175. DisplayValueToLcm ( __ctep_packing_mon_string, cmd, sizeof(cmd) );
  2176. memset ( cmd, 0x00, sizeof(cmd) );
  2177. sprintf ( (char *) cmd, "Total Cost" );
  2178. DisplayValueToLcm ( __ctep_total_mon_string, cmd, sizeof(cmd) );
  2179. ChangeDisplay2Value ( _ctep_energy_mon_comm, _ctep_energy_mon_comm_map );
  2180. ChangeDisplay2Value ( _ctep_packing_mon_comm, _ctep_packing_mon_comm_map );
  2181. ChangeDisplay2Value ( _ctep_total_mon_comm, _ctep_total_mon_comm_map );
  2182. ChangeDisplay2Value ( _ctep_energy_mon_chg, _ctep_energy_mon_chg_map );
  2183. ChangeDisplay2Value ( _ctep_packing_mon_chg, _ctep_packing_mon_chg_map );
  2184. ChangeDisplay2Value ( _ctep_total_mon_chg, _ctep_total_mon_chg_map );
  2185. ChangeDisplay2Value ( _ctep_energy_mon_comp, _ctep_energy_mon_comp_map );
  2186. ChangeDisplay2Value ( _ctep_packing_mon_comp, _ctep_packing_mon_comp_map );
  2187. ChangeDisplay2Value ( _ctep_total_mon_comp, _ctep_total_mon_comp_map );
  2188. memset ( cmd, 0x00, sizeof(cmd) );
  2189. sprintf ( (char *) cmd, "$0.00" );
  2190. DisplayValueToLcm ( __Energy_Cost_complete, cmd, sizeof(cmd) );
  2191. DisplayValueToLcm ( __Parking_Fee_complete, cmd, sizeof(cmd) );
  2192. DisplayValueToLcm ( __Total_Cost_complete, cmd, sizeof(cmd) );
  2193. DisplayValueToLcm ( __Energy_Cost_charging, cmd, sizeof(cmd) );
  2194. DisplayValueToLcm ( __Parking_Fee_charging, cmd, sizeof(cmd) );
  2195. DisplayValueToLcm ( __Total_Cost_charging, cmd, sizeof(cmd) );
  2196. DisplayValueToLcm ( __Energy_Cost_comp, cmd, sizeof(cmd) );
  2197. DisplayValueToLcm ( __Parking_Fee_comp, cmd, sizeof(cmd) );
  2198. DisplayValueToLcm ( __Total_Cost_comp, cmd, sizeof(cmd) );
  2199. }
  2200. else
  2201. {
  2202. ChangeDisplay2Value ( __ctep_time_string, _disappear);
  2203. ChangeDisplay2Value ( __ctep_energy_string, _disappear);
  2204. ChangeDisplay2Value ( __ctep_energy_mon_string, _disappear);
  2205. ChangeDisplay2Value ( __ctep_packing_mon_string, _disappear);
  2206. ChangeDisplay2Value ( __ctep_total_mon_string, _disappear);
  2207. ChangeDisplay2Value ( _ctep_energy_mon_comm, _disappear );
  2208. ChangeDisplay2Value ( _ctep_packing_mon_comm, _disappear );
  2209. ChangeDisplay2Value ( _ctep_total_mon_comm, _disappear );
  2210. ChangeDisplay2Value ( _ctep_energy_mon_chg, _disappear );
  2211. ChangeDisplay2Value ( _ctep_packing_mon_chg, _disappear );
  2212. ChangeDisplay2Value ( _ctep_total_mon_chg, _disappear );
  2213. ChangeDisplay2Value ( _ctep_energy_mon_comp, _disappear );
  2214. ChangeDisplay2Value ( _ctep_packing_mon_comp, _disappear );
  2215. ChangeDisplay2Value ( _ctep_total_mon_comp, _disappear );
  2216. ChangeDisplay2Value ( __Energy_Cost_complete, _disappear );
  2217. ChangeDisplay2Value ( __Parking_Fee_complete, _disappear );
  2218. ChangeDisplay2Value ( __Total_Cost_complete, _disappear );
  2219. ChangeDisplay2Value ( __Energy_Cost_charging, _disappear );
  2220. ChangeDisplay2Value ( __Parking_Fee_charging, _disappear );
  2221. ChangeDisplay2Value ( __Total_Cost_charging, _disappear );
  2222. ChangeDisplay2Value ( __Energy_Cost_comp, _disappear );
  2223. ChangeDisplay2Value ( __Parking_Fee_comp, _disappear );
  2224. ChangeDisplay2Value ( __Total_Cost_comp, _disappear );
  2225. }
  2226. }
  2227. int main(void)
  2228. {
  2229. if(InitShareMemory() == FAIL)
  2230. {
  2231. #ifdef SystemLogMessage
  2232. DEBUG_ERROR("InitShareMemory NG\n");
  2233. #endif
  2234. if (ShmStatusCodeData != NULL)
  2235. {
  2236. ShmStatusCodeData->AlarmCode.AlarmEvents.bits.FailToCreateShareMemory = 1;
  2237. }
  2238. sleep(5);
  2239. return 0;
  2240. }
  2241. Uart1Fd = CreateCommunicationLcmPort();
  2242. byte changeWarningPriority = 0;
  2243. byte curWarningCount = 255;
  2244. ChangeBackLight(true);
  2245. _totalCount = ShmSysConfigAndInfo->SysConfig.TotalConnectorCount;
  2246. acgunCount = ShmSysConfigAndInfo->SysConfig.AcConnectorCount;
  2247. Initialization();
  2248. //ChangeToOtherPage(_LCM_CHARGING);
  2249. // char SystemId[128] = "https://www.google.com.tw/";
  2250. // ChangeDisplay2Value(__qr_code, _disappear);
  2251. // sleep(1);
  2252. // byte len = strlen(SystemId);
  2253. // ChangeQrCode_Idle(SystemId, len);
  2254. //return -1;
  2255. // ChangeToOtherPage(_LCM_CHARGING);
  2256. //ChangeChargingPowerValue(1.1);
  2257. //ChangeChargingEnergyValue(3.225);
  2258. // ChangeDisplay2Value(__phihong_string, _disappear);
  2259. ///ChangeDisplayMoneyInfo();
  2260. // ChangeToOtherPage(_LCM_INIT);
  2261. DefaultIconStatus();
  2262. // int xxx = 3;
  2263. // while(xxx > 0 && Uart1Fd != -1)
  2264. // {
  2265. // if (xxx == 1)
  2266. // {
  2267. // printf("---------------------------- \n");
  2268. // downloadBMP(1, "/tmp/1_idle.bmp");
  2269. // printf("---------------------------- end \n");
  2270. // return -1;
  2271. // }
  2272. // sleep(1);
  2273. // xxx--;
  2274. // }
  2275. // return -1;
  2276. byte _verShowCount = 3;
  2277. while(Uart1Fd != -1)
  2278. {
  2279. UpdateLcmFunction();
  2280. if (strcmp((char *)ShmSysConfigAndInfo->SysInfo.LcmHwRev, moduleName) != EQUAL ||
  2281. _verShowCount > 0)
  2282. {
  2283. GetDeviceInfoStatus(__lcm_version, 3);
  2284. GetCurrentPage();
  2285. sleep(1);
  2286. if (_verShowCount > 0)
  2287. {
  2288. //PRINTF_FUNC("LCM Version = V.%03d \n", ShmDcCommonData->LcmFwVersion);
  2289. _verShowCount--;
  2290. }
  2291. if (ShmDcCommonData->LcmFwVersion >= 2)
  2292. {
  2293. ChangeDisplay2Value ( __logo, _logo );
  2294. ChangeDisplay2Value ( __logo_cmp, _logo_cmp );
  2295. }
  2296. if (ShmDcCommonData->LcmFwVersion >= 5)
  2297. {
  2298. if (_totalCount >= 2 || ShmSysConfigAndInfo->SysInfo.ChargerType != _CHARGER_TYPE_JARI)
  2299. {
  2300. ChangeDisplay2Value(__conn1_cabinet_charging, _conn1_cabinet_double_chg_map);
  2301. ChangeDisplay2Value(__conn1_cabinet_complete, _conn1_cabinet_double_cop_map);
  2302. }
  2303. else
  2304. {
  2305. ChangeDisplay2Value(__conn1_cabinet_charging, _conn2_cabinet_single_chg_map);
  2306. ChangeDisplay2Value(__conn1_cabinet_complete, _conn2_cabinet_single_cop_map);
  2307. }
  2308. }
  2309. }
  2310. else
  2311. {
  2312. //DemoFunction();
  2313. // Warning 處理
  2314. if(curWarningCount != ShmSysConfigAndInfo->SysWarningInfo.WarningCount)
  2315. {
  2316. changeWarningPriority = 0;
  2317. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  2318. curWarningCount = ShmSysConfigAndInfo->SysWarningInfo.WarningCount;
  2319. ChangeWarningFunc();
  2320. }
  2321. else if (ShmSysConfigAndInfo->SysWarningInfo.WarningCount > 5 && changeWarningPriority == 0)
  2322. {
  2323. // 當有兩頁 Warning 則每隔三秒改變一次
  2324. if(ShmSysConfigAndInfo->SysWarningInfo.PageIndex == 0)
  2325. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 1;
  2326. else
  2327. ShmSysConfigAndInfo->SysWarningInfo.PageIndex = 0;
  2328. ChangeWarningFunc();
  2329. }
  2330. // 頁面資訊處理
  2331. ProcessPageInfo();
  2332. // 網路 - wifi - 連線訊號處理
  2333. RefreshConnStatus();
  2334. // 換頁處理
  2335. GetCurrentPage();
  2336. ChangeCurPage();
  2337. RefreshPageAnimation(_everyPageRollChange);
  2338. if (changeWarningPriority == 0)
  2339. {
  2340. if (ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES &&
  2341. strlen ((char *) ShmSysConfigAndInfo->SysConfig.OcppReceiptrURL) > 0 &&
  2342. ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  2343. {
  2344. if (!_isCtepInforShow)
  2345. {
  2346. _isCtepInforShow = true;
  2347. SetCtepString(true);
  2348. }
  2349. }
  2350. else
  2351. {
  2352. _isCtepInforShow = false;
  2353. SetCtepString(false);
  2354. }
  2355. if (ShmSysConfigAndInfo->SysConfig.BillingData.isBilling)
  2356. {
  2357. ChangeDisplay2Value(__money_rate_map, _charging_money);
  2358. if(ShmDcCommonData->_useVersion != _CDFA_VERSION_NONE ||
  2359. (strcmp((char *)ShmSysConfigAndInfo->SysConfig.OcppServerURL, "") != EQUAL &&
  2360. strcmp((char *)ShmSysConfigAndInfo->SysConfig.ChargeBoxId, "") != EQUAL &&
  2361. ShmSysConfigAndInfo->SysInfo.OcppConnStatus == YES))
  2362. {
  2363. if (ShmDcCommonData->_useVersion == _CDFA_VERSION_NOODOE)
  2364. {
  2365. ChangeDisplayMoneyInfo();
  2366. memset(_defaultPriceBuf, 0, sizeof(_defaultPriceBuf));
  2367. ChangeDisplayCtepMoneyInfo();
  2368. }
  2369. else if (ShmDcCommonData->_useVersion == _CDFA_VERSION_10 ||
  2370. ShmDcCommonData->_useVersion == _CDFA_VERSION_20)
  2371. {
  2372. if (strcmp((char *)_defaultPriceBuf, ShmDcCommonData->balanceInfo.defaultPrice) != EQUAL)
  2373. {
  2374. memset(_defaultPriceBuf, 0, sizeof(_defaultPriceBuf));
  2375. strcpy((char *)_defaultPriceBuf, ShmDcCommonData->balanceInfo.defaultPrice);
  2376. ChangeDisplayCtepMoneyInfo();
  2377. }
  2378. ChangeDisplay2Value(__money_by_rate, _disappear);
  2379. }
  2380. }
  2381. else
  2382. {
  2383. ChangeDisplayMoneyInfoWithoutBackend();
  2384. memset(_defaultPriceBuf, 0, sizeof(_defaultPriceBuf));
  2385. ChangeDisplayCtepMoneyInfo();
  2386. }
  2387. if (ShmSysConfigAndInfo->SysConfig.BillingData.Currency <= 53)
  2388. {
  2389. DisplayMoneyCur((byte *)Currency[ShmSysConfigAndInfo->SysConfig.BillingData.Currency]);
  2390. }
  2391. }
  2392. else
  2393. {
  2394. ChangeDisplay2Value(__money_rate_map, _disappear);
  2395. ChangeDisplay2Value(__money_rate, _disappear);
  2396. ChangeDisplay2Value(__money_by_rate, _disappear);
  2397. memset(_defaultPriceBuf, 0, sizeof(_defaultPriceBuf));
  2398. ChangeDisplayCtepMoneyInfo();
  2399. }
  2400. InformationShow();
  2401. // CTEP Date
  2402. DisplaySystemDate();
  2403. }
  2404. changeWarningPriority >= 15 ? (_battery_display_ani = true) : (_battery_display_ani = false);
  2405. changeWarningPriority >= 30 ? changeWarningPriority = 0 : changeWarningPriority++;
  2406. usleep(100000);
  2407. }
  2408. }
  2409. CloseCommunicationLcmPort();
  2410. return FAIL;
  2411. }