|
@@ -2,7 +2,7 @@
|
|
|
* Module_LcmControl.c
|
|
|
*
|
|
|
* Created on : 2020-10-20
|
|
|
- * Update on : 2021-12-22
|
|
|
+ * Update on : 2021-12-24
|
|
|
* Author : Folus Wen, Eason Yang
|
|
|
* Version : V0.25
|
|
|
*
|
|
@@ -114,7 +114,7 @@ int Uart1Fd;
|
|
|
//=======================================
|
|
|
// Record version and date
|
|
|
//=======================================
|
|
|
-char *FIRMWARE_UPDATE_IMAGE[3] = {"V0.25", "2021-12-22", "REV.02.00"};
|
|
|
+char *FIRMWARE_UPDATE_IMAGE[3] = {"V0.25", "2021-12-24", "REV.02.00"};
|
|
|
|
|
|
//=======================================
|
|
|
// Common routine
|
|
@@ -444,6 +444,8 @@ void page_preparing(uint8_t gun_index, uint8_t system_mode)
|
|
|
|
|
|
void page_charging(uint8_t gun_index, uint8_t system_mode)
|
|
|
{
|
|
|
+ static char runningCost[256] = {0};
|
|
|
+
|
|
|
if((getCurrentPage() != SYSTEM_SCREEN_CHARGING) && (!ShmCharger->isAuthrizing && !ShmCharger->isGetAuthResult))
|
|
|
{
|
|
|
setCurrentPage(SYSTEM_SCREEN_CHARGING);
|
|
@@ -456,9 +458,10 @@ void page_charging(uint8_t gun_index, uint8_t system_mode)
|
|
|
setPresentChargedDuration(gun_index);
|
|
|
setPresentChargedgPower(gun_index);
|
|
|
|
|
|
- if(getDiffSecNow(startTime[gun_index][TMR_IDX_REFRESH_INFO]) >= (TIME_REFRESH_INFO))
|
|
|
+ if((getDiffSecNow(startTime[gun_index][TMR_IDX_REFRESH_INFO]) >= TIME_REFRESH_INFO) || (strcmp((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description, runningCost) != 0))
|
|
|
{
|
|
|
setPresentChargedEnergy(gun_index, system_mode);
|
|
|
+ memcpy((char*) runningCost,(char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description,ARRAY_SIZE(ShmOCPP16Data->Cost.RunningCost[gun_index].description));
|
|
|
|
|
|
if((ShmSysConfigAndInfo->SysInfo.OcppConnStatus == ON))
|
|
|
{
|
|
@@ -1444,28 +1447,33 @@ void setRunningCost(uint8_t gun_index, uint8_t type)
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
- if((strstr((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description, "Total Cost:") > 0))
|
|
|
+ if(strlen((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description) > 0)
|
|
|
{
|
|
|
- // APPEAR COST ICON
|
|
|
- setDisplayValue(ICON_CHARGING_COST, APPEAR);
|
|
|
+ if((strstr((char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description, "Total Cost:") > 0))
|
|
|
+ {
|
|
|
+ // APPEAR COST ICON
|
|
|
+ setDisplayValue(ICON_CHARGING_COST, APPEAR);
|
|
|
|
|
|
- // APPEAR COST TEXT
|
|
|
- strcpy((char*)tmp,(char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description);
|
|
|
- split((char**)splitString, tmp, Symbol);
|
|
|
- memcpy(input_data, splitString[3], strlen(splitString[3]));
|
|
|
- length = strlen(input_data);
|
|
|
- trim_string(input_data,length);
|
|
|
- memcpy(output_data ,input_data, strlen(input_data));
|
|
|
- lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_COST, output_data, ARRAY_SIZE(output_data));
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- setDisplayValue(ICON_CHARGING_COST, APPEAR);
|
|
|
+ // APPEAR COST TEXT
|
|
|
+ strcpy((char*)tmp,(char*)ShmOCPP16Data->Cost.RunningCost[gun_index].description);
|
|
|
+ split((char**)splitString, tmp, Symbol);
|
|
|
+ memcpy(input_data, splitString[3], strlen(splitString[3]));
|
|
|
+ length = strlen(input_data);
|
|
|
+ trim_string(input_data,length);
|
|
|
+ memcpy(output_data ,input_data, strlen(input_data));
|
|
|
+ lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_COST, output_data, ARRAY_SIZE(output_data));
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ setDisplayValue(ICON_CHARGING_COST, APPEAR);
|
|
|
|
|
|
- strcpy((char*)cost_empty, "-----");
|
|
|
- string2ByteArray(cost_empty, output_data);
|
|
|
- lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_COST, output_data, ARRAY_SIZE(output_data));
|
|
|
+ strcpy((char*)cost_empty, "-----");
|
|
|
+ string2ByteArray(cost_empty, output_data);
|
|
|
+ lcdRegisterWrite(Uart1Fd, REG_TYPE_RAM, TEXT_CHARGING_COST, output_data, ARRAY_SIZE(output_data));
|
|
|
+ }
|
|
|
}
|
|
|
+ else
|
|
|
+ {}
|
|
|
}
|
|
|
|
|
|
break;
|
|
@@ -1970,7 +1978,7 @@ void setPresentChargedEnergy(uint8_t gun_index, uint8_t system_mode)
|
|
|
|
|
|
memset(data, 0x00, ARRAY_SIZE(data));
|
|
|
memset(energy, 0x00, ARRAY_SIZE(energy));
|
|
|
-
|
|
|
+
|
|
|
switch(system_mode)
|
|
|
{
|
|
|
case SYS_MODE_PREPARING:
|