Commit e13f36f0 authored by 李俭双's avatar 李俭双

🐞 fix:更改水温数显格显同步问题

parent 6b2142f8
...@@ -50,28 +50,29 @@ typedef struct ...@@ -50,28 +50,29 @@ typedef struct
} HYS_Seg_Table_st_t; } HYS_Seg_Table_st_t;
const HYS_Seg_Table_st_t stHYSSegTableTemp[7] = const HYS_Seg_Table_st_t stHYSSegTableTemp[7] =
{ {
{0U, 470U}, // 0 {0U, 4700U}, // 0
{500U, 590U}, // 1 {5000U, 5900U}, // 1
{620U, 770U}, // 2 {6200U, 7700U}, // 2
{800U, 950U}, // 3 {8000U, 9500U}, // 3
{980U, 1120U}, // 4 {9800U, 11200U}, // 4
{1150U, 1990U}, // 5 {11500U, 19900U}, // 5
{1990U, 2000U}, // 6 {19900U, 20000U}, // 6
}; };
uint32_t u32CoolantDataTimeCount = 0UL; uint32_t u32CoolantDataTimeCount = 0UL;
uint32_t u32ColCurNum = 0UL; /*阻尼数显*/ uint32_t u32ColCurNum = 0UL; /*阻尼数显*/
uint32_t u32CoolantNum = 0UL;/*当前实际数据,与显示数值不完全一致*/
/* /*
u32CoolantDir:0:下行,1:上行 2:无变化 u32CoolantDir:0:下行,1:上行 2:无变化
*/ */
uint32_t Data_Coolant_Cal_Num(uint32_t u32CoolantCurSeg, uint32_t u32CoolantDir, uint32_t u32CoolantRemTime, uint32_t u32CoolantCurNum, uint32_t u32CoolantDesNum) uint32_t Data_Coolant_Cal_Num(uint32_t u32CoolantCurSeg, uint32_t u32CoolantDir, uint32_t u32CoolantRemTime, uint32_t u32CoolantCurNum, uint32_t u32CoolantDesNum)
{ {
uint32_t u32CoolantNum = u32CoolantCurNum;
uint32_t u32CoolantNumMax = 0UL; uint32_t u32CoolantNumMax = 0UL;
uint32_t u32CoolantNumMin = 0UL; uint32_t u32CoolantNumMin = 0UL;
uint32_t u32CoolantSegDesNum = 0UL; uint32_t u32CoolantSegDesNum = 0UL;
uint32_t u32CoolantCalBuf = 0UL; uint32_t u32CoolantCalBuf = 0UL;
uint32_t u32CoolantCalBuf1 = 0UL; uint32_t u32CoolantCalBuf1 = 0UL;
uint32_t u32CoolantCalResult = u32CoolantCurNum;
/*计算当前格对应的目标数值*/ /*计算当前格对应的目标数值*/
/*当前格数对应的数值范围,目标数值是否在这个范围内,如果在就直接用目标值。如果不在就根据上下行选择该范围内的极大和极小值。*/ /*当前格数对应的数值范围,目标数值是否在这个范围内,如果在就直接用目标值。如果不在就根据上下行选择该范围内的极大和极小值。*/
...@@ -138,17 +139,52 @@ uint32_t Data_Coolant_Cal_Num(uint32_t u32CoolantCurSeg, uint32_t u32CoolantDir, ...@@ -138,17 +139,52 @@ uint32_t Data_Coolant_Cal_Num(uint32_t u32CoolantCurSeg, uint32_t u32CoolantDir,
u32CoolantNum = u32CoolantSegDesNum; u32CoolantNum = u32CoolantSegDesNum;
} }
} }
u32CoolantCalResult = u32CoolantNum;
if (u32CoolantDir == 0) // down
{
// uint32_t u32CoolantCalBuf2 = 0UL;
// if (u32CoolantNum>u32CoolantCurNum)
// {
// u32CoolantCalBuf2 = u32CoolantNum-u32CoolantCurNum;
// }
// else
// {
// u32CoolantCalBuf2 = u32CoolantCurNum-u32CoolantNum;
// }
// if (u32CoolantCalBuf2>=100)
// {
// u32CoolantNum+=99UL;
// }
if ((u32CoolantNum+99)>=u32CoolantCurNum)
{
u32CoolantCalResult= u32CoolantCurNum;
}
else
{
u32CoolantCalResult= ((u32CoolantNum+99)/100*100);
}
}
} }
else // 0 else // 0
{ {
u32CoolantNum = u32CoolantSegDesNum; u32CoolantNum = u32CoolantSegDesNum;
u32CoolantCalResult = u32CoolantNum;
} }
} }
/*根据目标数值计算每个变化周期内数值变化的大小,*/ /*根据目标数值计算每个变化周期内数值变化的大小,*/
/*根据目标数值以及剩余时间,修改当前显示值*/ /*根据目标数值以及剩余时间,修改当前显示值*/
return u32CoolantNum; // return u32CoolantNum;
return u32CoolantCalResult;
} }
void Data_Coolant_Temp_Processing_Service(void) void Data_Coolant_Temp_Processing_Service(void)
...@@ -278,7 +314,7 @@ void Data_Coolant_Temp_Display ( void ) ...@@ -278,7 +314,7 @@ void Data_Coolant_Temp_Display ( void )
if(DataCoolantTemp_Dis.u8_CurSeg > DataCoolantTemp_Dis.u8_DestSeg ) if(DataCoolantTemp_Dis.u8_CurSeg > DataCoolantTemp_Dis.u8_DestSeg )
{ {
u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 0, (DataCoolantTemp_Dis.u8_Downtimer - DataCoolantTemp_Dis.u8_DownFlashtimer), u32ColCurNum, DataCoolantTemp.Value*10); u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 0, (DataCoolantTemp_Dis.u8_Downtimer - DataCoolantTemp_Dis.u8_DownFlashtimer), u32ColCurNum, DataCoolantTemp.Value*100);
DataCoolantTemp_Dis.u8_UpFlashtimer = 0; DataCoolantTemp_Dis.u8_UpFlashtimer = 0;
DataCoolantTemp_Dis.u8_Holdtimer = 0; DataCoolantTemp_Dis.u8_Holdtimer = 0;
DataCoolantTemp_Dis.u8_DownFlashtimer++; DataCoolantTemp_Dis.u8_DownFlashtimer++;
...@@ -290,7 +326,7 @@ void Data_Coolant_Temp_Display ( void ) ...@@ -290,7 +326,7 @@ void Data_Coolant_Temp_Display ( void )
} }
else if (DataCoolantTemp_Dis.u8_CurSeg < DataCoolantTemp_Dis.u8_DestSeg) else if (DataCoolantTemp_Dis.u8_CurSeg < DataCoolantTemp_Dis.u8_DestSeg)
{ {
u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 1, (DataCoolantTemp_Dis.u8_Uptimer - DataCoolantTemp_Dis.u8_UpFlashtimer), u32ColCurNum, DataCoolantTemp.Value*10); u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 1, (DataCoolantTemp_Dis.u8_Uptimer - DataCoolantTemp_Dis.u8_UpFlashtimer), u32ColCurNum, DataCoolantTemp.Value*100);
DataCoolantTemp_Dis.u8_DownFlashtimer = 0; DataCoolantTemp_Dis.u8_DownFlashtimer = 0;
DataCoolantTemp_Dis.u8_Holdtimer = 0; DataCoolantTemp_Dis.u8_Holdtimer = 0;
DataCoolantTemp_Dis.u8_UpFlashtimer++; DataCoolantTemp_Dis.u8_UpFlashtimer++;
...@@ -311,7 +347,7 @@ void Data_Coolant_Temp_Display ( void ) ...@@ -311,7 +347,7 @@ void Data_Coolant_Temp_Display ( void )
} }
/*目标格和当前格一致时,数显如何处理*/ /*目标格和当前格一致时,数显如何处理*/
/*5S后更新为目标数值*/ /*5S后更新为目标数值*/
u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 2, (CoolantFlashtimer-DataCoolantTemp_Dis.u8_Holdtimer ), u32ColCurNum, DataCoolantTemp.Value*10); u32ColCurNum = Data_Coolant_Cal_Num(DataCoolantTemp_Dis.u8_CurSeg, 2, (CoolantFlashtimer-DataCoolantTemp_Dis.u8_Holdtimer ), u32ColCurNum, DataCoolantTemp.Value*100);
} }
// warning // warning
...@@ -462,7 +498,7 @@ uint16_t GET_DataCoolantTempValueDisp(void) ...@@ -462,7 +498,7 @@ uint16_t GET_DataCoolantTempValueDisp(void)
} }
uint16_t GET_DataCoolantSegValue(void) uint16_t GET_DataCoolantSegValue(void)
{ {
return u32ColCurNum/10; return (u32ColCurNum)/100;
} }
uint8_t GET_DataCollantTempValueValid(void) uint8_t GET_DataCollantTempValueValid(void)
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment