串口通信中的float型数据的处理

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

你可能感兴趣的:(C/C++)