1、将串口接收的数据转换为float型数据
float CXXDlg::FourChar2Float(char* szBuf, //HEX ASC数据
bool bBigEndian = false) //指示是否是Big Endian结构
{
typedef union
{
unsigned char uc[4];
float f;
}Float4Byte;
Float4Byte f4b;
if(bBigEndian) //大端模式 调整数据顺序(因为PC机是小端模式)
{
f4b.uc[0] = (unsigned char)szBuf[3];
f4b.uc[1] = (unsigned char)szBuf[2];
f4b.uc[2] = (unsigned char)szBuf[1];
f4b.uc[3] = (unsigned char)szBuf[0];
}
else
{
f4b.uc[0] = (unsigned char)szBuf[0];
f4b.uc[1] = (unsigned char)szBuf[1];
f4b.uc[2] = (unsigned char)szBuf[2];
f4b.uc[3] = (unsigned char)szBuf[3];
}
return f4b.f; //返回浮点数数据
}
2、将float型数据转换成CString显示,精确到小数点nDigit位
void CXXDlg::Float2CString(float fIn, CString& csOut, int nDigit)
{
char szTmp[32] = {0};
//fIn四舍五入,保留小数点后nDigit位
float fTimes = pow((float)10, nDigit);
int nTmp = (int)(fIn*fTimes + 0.5);
fIn = nTmp/fTimes;
sprintf_s(szTmp, sizeof(szTmp), "%f", fIn);//将fIn转为字符串
CString csTmp = szTmp;
int nPos = 0;
nPos = csTmp.Find(".");
csOut = csTmp.Left(nPos);//小数点左边的部分
csOut += csTmp.Mid(nPos, nDigit+1);//小数点后面nDigit位,包括小数点
}
注:变量f为float型,n为int类型,则能实现将f中的数值保留小数点后两位,第三位四舍五入运算的表达式是
n=f*100+0.5,f=n/100.0