组态王与单片机通信协议3

此浮点数格式的转换:

1)ASCII码到浮点数:

 

float C4toD(char * c)

{

       BYTE     Hd[30], Jiema[30];

       float   DTc[30];

       float  Decimal = 0;

 

       memset(Hd, 0, sizeof(Hd));

       memset(Jiema, 0, sizeof(Jiema));

       memset(DTc, 0, sizeof(DTc));

 

       float   returnflo = 0;

       BOOL     ShuFU = FALSE, JieFU = FALSE;

 

       if((c[7] > 0x40) && (c[7] < 0x47))

              Hd[7] = ((c[7]  - 0x37) & 0x0f);

       else if((c[7] > 0x60) && (c[7] < 0x67))

              Hd[7] = ((c[7]  - 0x57) & 0x0f);

       else

              Hd[7] = ((c[7]  - 0x30) & 0x0f);

 

       if((c[6] > 0x40) && (c[6] < 0x47))

              Hd[6] = ((c[6]  - 0x37) & 0x0f);

       else if((c[6] > 0x60) && (c[6] < 0x67))

              Hd[6] = ((c[6]  - 0x57) & 0x0f);

       else

              Hd[6] = ((c[6]  - 0x30) & 0x0f);

 

       DTc[2] = (float)(((float)(Hd[6] * 16.0) + (float)(Hd[7])) / 256.0);

 

       if((c[5] > 0x40) && (c[5] < 0x47))

              Hd[5] = ((c[5]  - 0x37) & 0x0f);

       else if((c[5] > 0x60) && (c[5] < 0x67))

              Hd[5] = ((c[5]  - 0x57) & 0x0f);

       else

              Hd[5] = ((c[5]  - 0x30) & 0x0f);

 

       if((c[4] > 0x40) && (c[4] < 0x47))

              Hd[4] = ((c[4]  - 0x37) & 0x0f);

       else if((c[4] > 0x60) && (c[4] < 0x67))

              Hd[4] = ((c[4]  - 0x57) & 0x0f);

       else

              Hd[4] = ((c[4]  - 0x30) & 0x0f);

 

       DTc[1] = (float)((((float)(Hd[4] * 16.0) + (float)Hd[5]) + DTc[2]) / 256.0);

 

       if((c[3] > 0x40) && (c[3] < 0x47))

              Hd[3] = ((c[3]  - 0x37) & 0x0f);

       else if((c[3] > 0x60) && (c[3] < 0x67))

              Hd[3] = ((c[3]  - 0x57) & 0x0f);

       else

              Hd[3] = ((c[3]  - 0x30) & 0x0f);

 

       if((c[2] > 0x40) && (c[2] < 0x47))

              Hd[2] = ((c[2]  - 0x37) & 0x0f);

       else if((c[2] > 0x60) && (c[2] < 0x67))

              Hd[2] = ((c[2]  - 0x57) & 0x0f);

       else

              Hd[2] = ((c[2]  - 0x30) & 0x0f);

 

       Decimal = (float)(((float)(Hd[2] * 16) + (float)(Hd[3]) + DTc[1])/ 256.0);

 

       if((c[1] > 0x40) && (c[1] < 0x47))

              Jiema[1] = ((c[1]  - 0x37) & 0x0f);

       else if((c[1] > 0x60) && (c[1] < 0x67))

              Jiema[1] = ((c[1]  - 0x57) & 0x0f);     

       else

              Jiema[1] = ((c[1]  - 0x30) & 0x0f);

 

       if((c[0] > 0x40) && (c[0] < 0x47))

              Jiema[0] = ((c[0]  - 0x37) & 0x0f);

       else if((c[0] > 0x60) && (c[0] < 0x67))

              Jiema[0] = ((c[0]  - 0x57) & 0x0f);

       else

              Jiema[0] = ((c[0]  - 0x30) & 0x0f);

 

 

       ShuFU = ((Jiema[0] & 0x08) >> 3) > 0;

       JieFU = ((Jiema[0] & 0x04) >> 2) > 0;

 

       Jiema[2] = (Jiema[0] & 0x03) * 16 + Jiema[1];

      

       if(JieFU)

              returnflo = (float)pow(2, (-1) * Jiema[2]) * Decimal;

       else

              returnflo = (float)pow(2, Jiema[2]) * Decimal;

 

       if(ShuFU)

              returnflo = (-1) * returnflo;

 

       return returnflo;

}

2)浮点数到ASCII码:

 

void D4toC(char * c,float d)

{

    BYTE    i = 0, Jiema = 0;

       char    inbyte1[30];

       BOOL    ShuFu = FALSE, JieFu = FALSE;

       int     inbyte2 = 0, inbyte3 = 0, inbyte4 = 0;

       char    afterbyte2[30], afterbyte3[30], afterbyte4[30];

       float   F_afterbyte2 = 0, F_afterbyte3 = 0, F_afterbyte4 = 0;

 

       memset(inbyte1, 0x30, sizeof(inbyte1));

       memset(afterbyte2, 0x30, sizeof(afterbyte2));

       memset(afterbyte3, 0x30, sizeof(afterbyte3));

       memset(afterbyte4, 0x30, sizeof(afterbyte4));

      

       inbyte1[10] = 0x0;

       afterbyte2[10] = 0x0;

       afterbyte3[10] = 0x0;

       afterbyte4[10] = 0x0;

      

       if(d == 0)

       {

              for(int j = 0; j < 8; j++)

                     c[j] = 0x30;

              return;

       }

       if(d < 0)

       {

              ShuFu = TRUE;

              d = (-1) * d;

       }

      

       while(d > 1)

       {

              d =(float)(d / 2.0);

              i ++;

       }

 

       while(d <= 0.5)

       {

              JieFu = TRUE;

              d = (float)(d * 2.0);

              i ++;

       }

 

       if(d == 1)

       {

              for(int j = 2; j < 8; j++)

                     c[j] = 0x46;         

       }    

       else

       {    

              inbyte2 = (int)(d * 256);

              F_afterbyte2 = (d * 256) - (int)(d * 256);

              inbyte3 = (int)(F_afterbyte2 * 256);

              F_afterbyte3 = (F_afterbyte2 * 256) - (int)(F_afterbyte2 * 256);

              inbyte4 = (int)(F_afterbyte3 * 256);

              F_afterbyte4 = (F_afterbyte3 * 256) - (int)(F_afterbyte3 * 256);

 

              itoa(inbyte2, afterbyte2, 16);

              itoa(inbyte3, afterbyte3, 16);

              itoa(inbyte4, afterbyte4, 16);

 

              if(inbyte2 == 0)

              {

                     c[2] = 0x30;

                     c[3] = 0x30;

              }

              else if(inbyte2 < 16)

              {

                     c[2] = 0x30;

                     c[3] = afterbyte2[0];

              }

              else

              {

                     c[2] = afterbyte2[0];

                     c[3] = afterbyte2[1];

              }

              if(inbyte3 == 0)

              {

                     c[4] = 0x30;

                     c[5] = 0x30;

              }

              else if(inbyte3 < 16)

              {

                     c[4] = 0x30;

                     c[5] = afterbyte3[0];

              }

              else

              {

                     c[4] = afterbyte3[0];

                     c[5] = afterbyte3[1];

              }

              if(inbyte4 == 0)

              {

                     c[6] = 0x30;

                     c[7] = 0x30;

              }

              else if(inbyte4 < 16)

              {

                     c[6] = 0x30;

                     c[7] = afterbyte4[0];

              }

              else

              {

                     c[6] = afterbyte4[0];

                     c[7] = afterbyte4[1];

              }

       }

 

       if(JieFu)

       {

              if(i > 0x3f)

                     i = 0x3f;

       }

       else if(i > 0x32)

              i = 32;

       if(ShuFu)

              i = i | 0x80;

       if(JieFu)

              i = i | 0x40;

       itoa(i, inbyte1, 16);

 

       if(inbyte1 == 0)

       {

              c[0] = 0x30;

              c[1] = 0x30;

       }

       else if(i < 16)

       {

              c[0] = 0x30;

              c[1] = inbyte1[0];

       }

       else

       {

              c[0] = inbyte1[0];

              c[1] = inbyte1[1];

       }

      

       for(i = 0; i < 8; i ++)

       {

              if((c[i] > 0x60) && (c[i] < 0x67))

                     c[i] = c[i] - 0x20;

       }

 

       c[8] = 0x00;

}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 组态王是一款强大的工业自动化软件,广泛应用于监控和控制系统。组态王支持多种通信协议,包括Modbus、OPC、DDE等。然而,根据我的了解,目前组态王并不直接支持HJT212协议。 HJT212协议是中国水质在线监测仪器设备的行业标准协议,由中国电子标准化协会水污染控制仪器设备工作组制定。该协议规定了水质监测仪器与系统之间的通信协议和数据格式,旨在提供一种统一的数据交换方式。 尽管组态王当前不直接支持HJT212协议,但可以通过其他方式来实现与HJT212兼容的水质监测仪器的数据通信。一种方法是使用HJT212的应用程序编程接口(API),将仪器的数据以HJT212格式转换并传输到组态王系统中。另一种方法是通过第三方的数据转换工具,将HJT212格式的数据转换为组态王支持的其他协议,如Modbus或OPC,并实现数据的传输和显示。 总的来说,虽然组态王目前不直接支持HJT212协议,但仍然可以通过一些额外的设置和中间件来实现与HJT212兼容的数据通信。这样就能够将水质监测仪器的数据集成到组态王系统中,实现对水质监测过程的可视化和远程控制。 ### 回答2: 组态王是一款强大的工业自动化软件,它支持多种通信协议,其中包括HJT212协议。HJT212协议是中国国家标准化委员会发布的一种水污染源在线监控系统数据传输协议,用于水污染源监测仪器设备与数据传输机制之间的通信组态王作为工业自动化领域的领先软件,具备高度的定制化能力和兼容性,可以根据用户的需求进行灵活的配置和集成。因此,组态王可以轻松支持HJT212协议,实现与水污染源在线监控系统设备的数据交互。 通过可视化界面,用户可以在组态王中方便地创建HJT212协议的通信通道,并进行设备参数配置、数据传输监控等操作。同时,组态王还提供了强大的数据处理和分析功能,可以对HJT212协议传输的数据进行实时监测、报警处理、历史数据查询等操作,使用户能够更加全面和方便地管理水污染源监测系统。 总结而言,组态王作为一款功能丰富的工业自动化软件,完全支持HJT212协议。它通过配置和集成HJT212协议,实现与水污染源在线监控系统的通信和数据交互,为用户提供了强大的数据处理和分析功能,帮助用户更好地管理和监控水污染源。 ### 回答3: 组态王是一个用于工业控制系统的软件,用于监控和控制工业过程。根据我的了解,组态王支持多种通信协议,包括常见的Modbus、OPC、DDE等协议。然而,关于组态王是否支持HJT212协议,目前我无法给出明确答案。 HJT212协议是中国国家标准局发布的用于环境监测仪器与系统数据交换的协议。该协议定义了数据传输格式、通信方式等标准,旨在实现不同环境监测仪器与上位机系统之间的数据交换和统一管理。因此,对于使用HJT212协议的环境监测系统而言,是否支持组态王软件需要进一步确认。 如果你需要在组态王中使用HJT212协议,建议联系组态王的官方客服或技术支持,向他们咨询是否支持该协议,以获得更准确的答案。他们将能够提供关于组态王与HJT212协议的兼容性和支持情况的详细信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值