找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2096|回复: 0
打印 上一主题 下一主题
收起左侧

Arduino bmp280温度湿度传感器,串口发送

[复制链接]
跳转到指定楼层
楼主
ID:443546 发表于 2019-11-25 10:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include "mbed.h"
  2. Serial pc(PA_9, PA_10);//定义串口
  3. I2C i2c(PB_7, PB_6);//定义i2c通信
  4. unsigned short int dig_P1, dig_T1;//定义引脚,变量
  5. short int dig_P2, dig_P3, dig_P4, dig_P5, dig_P6, dig_P7, dig_P8, dig_P9, dig_T2, dig_T3;
  6. double wendu, qiya, t_fine;//温度,气压,补偿
  7. const int addw = 0xEC;//写入地址  Pin6:SDO(传感器地址控制位,接GND的时候I2C中器件地址为0xEC,接高电平为0xEc+1
  8. const int addr = 0xED;//读取地址
  9. //测量控制寄存器(ctrl_meas)(0xF4):
  10. //Bit7~Bit5:osrs_t[2:0] 控制温度采样模式,主要是采样数据的位数(位数越大,精度越高),具体配置如下(本次三位都配置为1,最大采样位数20Bit):
  11. //Bit4~Bit2:osrs_p[2:0] 控制大气压强采样模式,主要是采样数据的位数(位数越大,精度越高),具体配置如下(本次三位都配置为1,最大采样位数20Bit):
  12. //Bit1~Bit0:mode[1:0] 传感器工作模式控制,00为Sleep Mode,01/10为Forced Mode,11为 Normal Mode(本次配置为11)。
  13. //配置寄存器(config)(0xF5):
  14. //Bit7~Bit5:t_sb[2:0] 设置Normal Mode下的转换间隔时间,具体配置如下(本次配置为000,0.5ms转换一次)
  15. //Bit4~Bit2:filter[2:0] 设置传感器接收外界信号时的,前端滤波电路的滤波系数的,可以有效减少外界环境的干扰: 本次000,不使用
  16. //Bit0:spi3w_en 与SPI模式有关,本次没用到,没设置。

  17. //身份编号寄存器(id)(0xD0):
  18. //寄存器内固定值为0x58,读取0xD0数据的时候,传感器返回0x58,代表身份辨认完毕。
  19. //复位寄存器(reset)(0xE0):
  20. //写入0xB6时,所有寄存器(除身份编号寄存器)数据全部清零。



  21. /*
  22. 函数功能:读取制定地址的数据
  23. 参数:寄存器地址
  24. 返回值:读出的数据
  25. */
  26. uint8_t i2cread(char shuju)
  27. {
  28.     char cmd[2];
  29.     cmd[0] = shuju;
  30.     i2c.write(addw, cmd, 1);
  31.     i2c.read(addr, cmd, 1);
  32.     return cmd[0];
  33. }

  34. /*
  35. 函数功能:计算温度
  36. 参数:无
  37. 返回值:温度
  38. */

  39. float bmp280_wendu()
  40. {
  41.     long adc_P;
  42.     uint32_t var1, var2;
  43.     float T, p;
  44.     var1 = (((double)wendu) / 16384.0 - ((double)dig_T1) / 1024.0) * ((double)dig_T2);
  45.     var2 = ((((double)wendu) / 131072.0 - ((double)dig_T1) / 8192.0) * (((double)wendu) / 131072.0 - ((double)dig_T1) / 8192.0)) * ((double)dig_T2);
  46.     t_fine = (uint32_t)(var1 + var2);
  47.     T = (var1 + var2) / 5120.0;
  48.    //bmp280自带的补偿算法
  49.     return T;
  50. }

  51. /*
  52. 函数功能:计算气压
  53. 参数:无
  54. 返回值:无
  55. */
  56. float bmp280_qiya()
  57. {
  58.     uint32_t var1, var2;
  59.     float T, p;
  60.     var1 = ((double)t_fine / 2.0) - 64000.0;
  61.     var2 = var1 * var1 * ((double)dig_P6) / 32768.0;
  62.     var2 = var2 + var1 * ((double)dig_P5) * 2.0;
  63.     var2 = (var2 / 4.0) + (((double)dig_P4) * 65536.0);
  64.     var1 = (((double)dig_P3) * var1 * var1 / 524288.0 + ((double)dig_P2) * var1) / 524288.0;
  65.     var1 = (1.0 + var1 / 32768.0) * ((double)dig_P1);
  66.     p = 1048576.0 - (double)qiya;
  67.     p = (p - (var2 / 4096.0)) * 6250.0 / var1;
  68.     var1 = ((double)dig_P9) * p * p / 2147483648.0;
  69.     var2 = p * ((double)dig_P8) / 32768.0;
  70.     p = p + (var1 + var2 + ((double)dig_P7)) / 16.0;
  71.     return p;//bmp280自带补偿算法
  72. }

  73. /*
  74. 函数功能:读取温度,气压数据,存入定义的变量中
  75. 参数:无
  76. 返回值:无
  77. */
  78. void bmp280_shujucaiji(void)
  79. {
  80.     uint8_t lsb, msb, xlsb;
  81.     msb = i2cread(0xfa);//高8位
  82.     lsb = i2cread(0xfb);//低8位
  83.     xlsb = i2cread(0xfc);
  84.     wendu = (msb << 12) | (lsb << 4) | (xlsb >> 4);//高位放最左边,低位中间,xlsb后四位不要,注意datesheet中给的低位高位地址,是反的

  85.     msb = i2cread(0xf7);
  86.     lsb = i2cread(0xf8);
  87.     xlsb = i2cread(0xf9);
  88.     qiya = (msb << 12) | (lsb << 4) | (xlsb >> 4);
  89. }

  90. /*
  91. 函数功能:读取实时补偿
  92. 参数:无
  93. 返回值:无
  94. */
  95. void bmp280_buchang(void)
  96. {
  97.     uint8_t lsb, msb;
  98.     lsb = i2cread(0x88);
  99.     msb = i2cread(0x89);
  100.     dig_T1 = (msb << 8) | lsb;
  101.     lsb = i2cread(0x8A);
  102.     msb = i2cread(0x8B);
  103.     dig_T2 = (msb << 8) | lsb;
  104.     lsb = i2cread(0x8c);
  105.     msb = i2cread(0x8d);
  106.     dig_T3 = (msb << 8) | lsb;

  107.     lsb = i2cread(0x8e);
  108.     msb = i2cread(0x8f);
  109.     dig_P1 = msb << 8 | lsb;
  110.     lsb = i2cread(0x90);
  111.     msb = i2cread(0x91);
  112.     dig_P2 = msb << 8 | lsb;
  113.     lsb = i2cread(0x92);
  114.     msb = i2cread(0x93);
  115.     dig_P3 = msb << 8 | lsb;
  116.     lsb = i2cread(0x94);
  117.     msb = i2cread(0x95);
  118.     dig_P4 = msb << 8 | lsb;
  119.     lsb = i2cread(0x96);
  120.     msb = i2cread(0x97);
  121.     dig_P5 = msb << 8 | lsb;
  122.     lsb = i2cread(0x98);
  123.     msb = i2cread(0x99);
  124.     dig_P6 = msb << 8 | lsb;
  125.     lsb = i2cread(0x9a);
  126.     msb = i2cread(0x9b);
  127.     dig_P7 = msb << 8 | lsb;
  128.     lsb = i2cread(0x9c);
  129.     msb = i2cread(0x9d);
  130.     dig_P8 = msb << 8 | lsb;
  131.     lsb = i2cread(0x9e);
  132.     msb = i2cread(0x9f);
  133.     dig_P9 = msb << 8 | lsb;
  134. }

  135. /*
  136. 函数功能:配置bmp280寄存器参数
  137. 参数:无
  138. 返回值:无
  139. */
  140. void bmp280_init(void)
  141. {
  142.     char cmd[2], str[2];
  143.     cmd[0] = 0xf4;
  144.     cmd[1] = 0xff;
  145.     str[0] = 0xf5;
  146.     str[1] = 0x00;
  147.     i2c.write(addw, cmd, 2);
  148.     i2c.write(addw, str, 2);
  149. }
  150. int main()
  151. {
  152.     bmp280_init();
  153.     pc.baud(9600);//波特率配置
  154.     wait(1);
  155.     pc.printf("%d\n", i2cread(0xD0));

  156.     while (1)
  157.     {
  158.         bmp280_buchang();
  159.         bmp280_shujucaiji();
  160.         pc.printf("%.6f\n", bmp280_wendu());
  161.         pc.printf("%.6f\n", bmp280_qiya());
  162.         wait(1);
  163.     }
  164. }
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表