|
@@ -20,6 +20,7 @@
|
|
#include "../timeout.h"
|
|
#include "../timeout.h"
|
|
|
|
|
|
#define uSEC_VAL (1000000)
|
|
#define uSEC_VAL (1000000)
|
|
|
|
+
|
|
//------------------------------------------------------------------------------
|
|
//------------------------------------------------------------------------------
|
|
//struct SysConfigAndInfo *ShmSysConfigAndInfo;
|
|
//struct SysConfigAndInfo *ShmSysConfigAndInfo;
|
|
//struct StatusCodeData *ShmStatusCodeData;
|
|
//struct StatusCodeData *ShmStatusCodeData;
|
|
@@ -204,6 +205,9 @@ void CheckReturnPress()
|
|
//pDcChargingInfo->SystemStatus = S_IDLE;
|
|
//pDcChargingInfo->SystemStatus = S_IDLE;
|
|
StopSystemTimeoutDet();
|
|
StopSystemTimeoutDet();
|
|
if ( pDcChargingInfo->SystemStatus == S_AUTHORIZING ) {
|
|
if ( pDcChargingInfo->SystemStatus == S_AUTHORIZING ) {
|
|
|
|
+ if (pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
|
|
|
|
+ pSysInfo->SystemPage = _PAGE_SELECT_PAY;
|
|
|
|
+ }
|
|
ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
|
|
ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
|
|
ShmDcCommonData->PreAuth_Result = 0;
|
|
ShmDcCommonData->PreAuth_Result = 0;
|
|
for(i=0;i<=30;i++) {
|
|
for(i=0;i<=30;i++) {
|
|
@@ -239,6 +243,7 @@ void CheckStopConfirmPress()
|
|
pDcChargingInfo->SystemStatus = S_TERMINATING;
|
|
pDcChargingInfo->SystemStatus = S_TERMINATING;
|
|
pSysInfo->SystemPage = _PAGE_PAYING;
|
|
pSysInfo->SystemPage = _PAGE_PAYING;
|
|
is_stop = FALSE;
|
|
is_stop = FALSE;
|
|
|
|
+ ShmDcCommonData->StopCharge[pSysInfo->CurGunSelected] = TRUE;
|
|
StartGunInfoTimeoutDet(pSysInfo->CurGunSelected,Timeout_FinalCost);
|
|
StartGunInfoTimeoutDet(pSysInfo->CurGunSelected,Timeout_FinalCost);
|
|
/*
|
|
/*
|
|
ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
|
|
ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
|
|
@@ -322,18 +327,18 @@ void CheckTouchPress(short id)
|
|
log_info("LCM left Gun down...............................%x %x %x",
|
|
log_info("LCM left Gun down...............................%x %x %x",
|
|
pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
|
|
pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
|
|
}
|
|
}
|
|
- /*
|
|
|
|
- if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE) {
|
|
|
|
|
|
+
|
|
|
|
+ if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE ||
|
|
|
|
+ pSysInfo->SystemPage == _PAGE_PAYFAIL) {
|
|
StopSystemTimeoutDet();
|
|
StopSystemTimeoutDet();
|
|
StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
- }*/
|
|
|
|
|
|
+ }
|
|
break;
|
|
break;
|
|
case _Touch_Show_Right:
|
|
case _Touch_Show_Right:
|
|
- if (pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
|
|
|
|
- log_info("Authorize Page can't select gun");
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
|
|
+ if (pSysInfo->SystemPage >= _PAGE_ADD_FRIEND && pSysInfo->SystemPage <= _PAGE_PLUGIN) {
|
|
|
|
+ log_info("Authorize Process can't select gun");
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
// Show log
|
|
// Show log
|
|
if(pSysInfo->CurGunSelected != RIGHT_GUN_NUM) {
|
|
if(pSysInfo->CurGunSelected != RIGHT_GUN_NUM) {
|
|
pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
|
|
pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
|
|
@@ -344,14 +349,17 @@ void CheckTouchPress(short id)
|
|
log_info("LCM Right Gun down...............................%x %x %x",
|
|
log_info("LCM Right Gun down...............................%x %x %x",
|
|
pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
|
|
pSysInfo->CurGunSelected,pDcChargingInfo->SystemStatus,pSysInfo->SystemPage);
|
|
}
|
|
}
|
|
- /*
|
|
|
|
- if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE) {
|
|
|
|
|
|
+
|
|
|
|
+ if (pSysInfo->SystemPage == _PAGE_CHARGING || pSysInfo->SystemPage == _PAGE_COMPLETE ||
|
|
|
|
+ pSysInfo->SystemPage == _PAGE_PAYFAIL) {
|
|
StopSystemTimeoutDet();
|
|
StopSystemTimeoutDet();
|
|
StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
}
|
|
}
|
|
- */
|
|
|
|
|
|
+
|
|
break;
|
|
break;
|
|
case _Touch_Return:
|
|
case _Touch_Return:
|
|
|
|
+ if (pSysInfo->SystemPage == _PAGE_AUTHORIZE)
|
|
|
|
+ pSysInfo->SystemPage = _PAGE_SELECT_PAY;
|
|
CheckReturnPress();
|
|
CheckReturnPress();
|
|
break;
|
|
break;
|
|
case _Touch_IDLE:
|
|
case _Touch_IDLE:
|
|
@@ -465,6 +473,7 @@ void CheckLCMPressed()
|
|
} // if pid
|
|
} // if pid
|
|
log_info("Create LCM fork:%d",Pid);
|
|
log_info("Create LCM fork:%d",Pid);
|
|
}
|
|
}
|
|
|
|
+
|
|
void ReadMsgFromLcm(uint8_t *msg, uint8_t readLen)
|
|
void ReadMsgFromLcm(uint8_t *msg, uint8_t readLen)
|
|
{
|
|
{
|
|
read(_port, msg, readLen);
|
|
read(_port, msg, readLen);
|
|
@@ -691,7 +700,7 @@ void string2ByteArray(uint8_t *input, uint8_t *output)
|
|
|
|
|
|
void RefreshProgressAnimation()
|
|
void RefreshProgressAnimation()
|
|
{
|
|
{
|
|
- _everyPageRollChange >= 20 ? _everyPageRollChange = 0 : _everyPageRollChange++;
|
|
|
|
|
|
+ _everyPageRollChange >= 30 ? _everyPageRollChange = 0 : _everyPageRollChange++;
|
|
}
|
|
}
|
|
|
|
|
|
//================================================
|
|
//================================================
|
|
@@ -830,6 +839,35 @@ void ChangeRemainTime(int sec)
|
|
DisplayValueToLcm(_Text_Time, cmd, sizeof(cmd));
|
|
DisplayValueToLcm(_Text_Time, cmd, sizeof(cmd));
|
|
}
|
|
}
|
|
*/
|
|
*/
|
|
|
|
+void ShowSelectGun()
|
|
|
|
+{
|
|
|
|
+ pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
|
|
|
|
+ if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
|
|
|
|
+ pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS1);
|
|
|
|
+
|
|
|
|
+ } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
|
|
|
|
+ pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS2);
|
|
|
|
+
|
|
|
|
+ } else if (pDcChargingInfo->Type == _Type_Chademo) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CHAdeMo);
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+ pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
|
|
|
|
+ if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
|
|
|
|
+ pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS1);
|
|
|
|
+
|
|
|
|
+ } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
|
|
|
|
+ pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS2);
|
|
|
|
+
|
|
|
|
+ } else if (pDcChargingInfo->Type == _Type_Chademo) {
|
|
|
|
+ ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CHAdeMo);
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+}
|
|
void ChangeChargingPowerValue(float pow)
|
|
void ChangeChargingPowerValue(float pow)
|
|
{
|
|
{
|
|
uint8_t cmd[10];
|
|
uint8_t cmd[10];
|
|
@@ -861,7 +899,11 @@ void ChangeCarBonValue(float data)
|
|
float _carbon = 0;
|
|
float _carbon = 0;
|
|
memset(cmd, 0x00, sizeof(cmd));
|
|
memset(cmd, 0x00, sizeof(cmd));
|
|
_carbon = (data*9)/10*2.36 - data*0.637;
|
|
_carbon = (data*9)/10*2.36 - data*0.637;
|
|
- sprintf((char *) value, "%d", (int)_carbon);
|
|
|
|
|
|
+ //log_info("Carbon:%d",(int)_carbon);
|
|
|
|
+ if (_carbon < 10)
|
|
|
|
+ sprintf((char *) value, "%.1f", _carbon);
|
|
|
|
+ else
|
|
|
|
+ sprintf((char *) value, "%d", (int)_carbon);
|
|
string2ByteArray(value, cmd);
|
|
string2ByteArray(value, cmd);
|
|
DisplayValueToLcm(_String_Carbon, cmd, sizeof(cmd));
|
|
DisplayValueToLcm(_String_Carbon, cmd, sizeof(cmd));
|
|
}
|
|
}
|
|
@@ -1047,13 +1089,14 @@ void ProcessPageInfo()
|
|
|
|
|
|
break;
|
|
break;
|
|
case _PAGE_SELECT_PAY:
|
|
case _PAGE_SELECT_PAY:
|
|
- if (ShmDcCommonData->donate_flag == TRUE) {
|
|
|
|
|
|
+ if (ShmDcCommonData->donate_flag[i] == TRUE) {
|
|
ChangeDisplay2Value(_Icon_WordAddFriend,_ICON_Empty);
|
|
ChangeDisplay2Value(_Icon_WordAddFriend,_ICON_Empty);
|
|
} else
|
|
} else
|
|
ChangeDisplay2Value(_Icon_WordAddFriend,_TCC_SelectPayMode);
|
|
ChangeDisplay2Value(_Icon_WordAddFriend,_TCC_SelectPayMode);
|
|
StartSystemTimeoutDet(Timeout_SelectPayMode);
|
|
StartSystemTimeoutDet(Timeout_SelectPayMode);
|
|
break;
|
|
break;
|
|
case _PAGE_SELECT_GUN:
|
|
case _PAGE_SELECT_GUN:
|
|
|
|
+ ShowSelectGun();
|
|
ClearQR_flag[i] = FALSE;
|
|
ClearQR_flag[i] = FALSE;
|
|
break;
|
|
break;
|
|
case _PAGE_BILL:
|
|
case _PAGE_BILL:
|
|
@@ -1115,7 +1158,7 @@ void ProcessPageInfo()
|
|
ChangeTimeValue(0);
|
|
ChangeTimeValue(0);
|
|
}
|
|
}
|
|
ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
|
|
ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
|
|
- //StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
|
|
|
|
+ StartSystemTimeoutDet(Timeout_ReturnViewPage);
|
|
break;
|
|
break;
|
|
case _PAGE_COMPLETE:
|
|
case _PAGE_COMPLETE:
|
|
case _PAGE_PAYFAIL:
|
|
case _PAGE_PAYFAIL:
|
|
@@ -1129,7 +1172,7 @@ void ProcessPageInfo()
|
|
if ( ShmDcCommonData->finalcost[i] >= 0 && ShmDcCommonData->finalcost_flag[i] == TRUE) {
|
|
if ( ShmDcCommonData->finalcost[i] >= 0 && ShmDcCommonData->finalcost_flag[i] == TRUE) {
|
|
StopGunInfoTimeoutDet(i);
|
|
StopGunInfoTimeoutDet(i);
|
|
ChangeChargingFeeValue(ShmDcCommonData->finalcost[i]);
|
|
ChangeChargingFeeValue(ShmDcCommonData->finalcost[i]);
|
|
- ShmDcCommonData->finalcost_flag[i] = FALSE;
|
|
|
|
|
|
+ //ShmDcCommonData->finalcost_flag[i] = FALSE;
|
|
}
|
|
}
|
|
ChangeCarBonValue(pDcChargingInfo->PresentChargedEnergy);
|
|
ChangeCarBonValue(pDcChargingInfo->PresentChargedEnergy);
|
|
ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
|
|
ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
|
|
@@ -1332,6 +1375,7 @@ void InformationShow()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
*/
|
|
*/
|
|
|
|
+
|
|
void DefautLayOut()
|
|
void DefautLayOut()
|
|
{
|
|
{
|
|
int i;
|
|
int i;
|
|
@@ -1344,32 +1388,7 @@ void DefautLayOut()
|
|
ChangeDisplay2Value(_Icon_CardPay,0);
|
|
ChangeDisplay2Value(_Icon_CardPay,0);
|
|
ChangeDisplay2Value(0x5000,1);
|
|
ChangeDisplay2Value(0x5000,1);
|
|
|
|
|
|
- pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
|
|
|
|
- if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
|
|
|
|
- pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS1);
|
|
|
|
-
|
|
|
|
- } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
|
|
|
|
- pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CCS2);
|
|
|
|
-
|
|
|
|
- } else if (pDcChargingInfo->Type == _Type_Chademo) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Left,_TCC_SelectLeft_CHAdeMo);
|
|
|
|
-
|
|
|
|
- }
|
|
|
|
- pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
|
|
|
|
- if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
|
|
|
|
- pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS1);
|
|
|
|
-
|
|
|
|
- } else if (pDcChargingInfo->CCSGunType == _TYPE_CCS2_Liquid ||
|
|
|
|
- pDcChargingInfo->CCSGunType == _TYPE_CCS2_Natural) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CCS2);
|
|
|
|
-
|
|
|
|
- } else if (pDcChargingInfo->Type == _Type_Chademo) {
|
|
|
|
- ChangeDisplay2Value(_Icon_Select_Right,_TCC_SelectRight_CHAdeMo);
|
|
|
|
-
|
|
|
|
- }
|
|
|
|
|
|
+ ShowSelectGun();
|
|
}
|
|
}
|
|
/*
|
|
/*
|
|
static int InitialRfidPort(void)
|
|
static int InitialRfidPort(void)
|