找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7686|回复: 8
收起左侧

VL53l0x激光测距程序和资料

  [复制链接]
ID:227242 发表于 2017-8-12 14:30 | 显示全部楼层 |阅读模式
vl530l0x资料
0.png

单片机源程序如下:
  1. /*****************************
  2. 更新日期2017年2月28日

  3. 模拟串口参考stc官方程序
  4. 来自arduino实例

  5. 使用11.0592MHz内部RC;
  6. VL53L0X:
  7. SCL-->P3.3
  8. SDA-->P3.2
  9. 串口:
  10. P3.0 RXD
  11. P3.1 TXD
  12. *******************************/

  13. #include"stc.h"
  14. #include"i2c.h"
  15. #include"VL53L0X.h"
  16. #include "intrins.h"
  17. #define uchar unsigned char
  18. #define uint unsigned int


  19. /***********全局变量定义**************/
  20. bit flag;
  21. uchar val1;
  22. short val_s;
  23. uchar gbuf[16];
  24. uint acnt ;
  25. uint scnt;
  26. uint dist ;
  27. uchar DeviceRangeStatusInternal;

  28. #define BAUD  0xFE80                  // 9600bps @ 11.0592MHz


  29. //sfr AUXR = 0x8E;
  30. sbit RXB = P3^0;                        //define UART TX/RX port
  31. sbit TXB = P3^1;

  32. typedef bit BOOL;
  33. typedef unsigned char BYTE;
  34. typedef unsigned int WORD;

  35. BYTE TBUF,RBUF;
  36. BYTE TDAT,RDAT;
  37. BYTE TCNT,RCNT;
  38. BYTE TBIT,RBIT;
  39. BOOL TING,RING;
  40. BOOL TEND,REND;

  41. void UART_INIT();



  42. void delay()
  43. {
  44.     unsigned char i;
  45.     for(i=0; i<100; i++);
  46. }
  47. void Delay1ms()                //@11.0592MHz
  48. {
  49.     unsigned char i, j;

  50.     _nop_();
  51.     i = 11;
  52.     j = 190;
  53.     do
  54.     {
  55.         while (--j);
  56.     } while (--i);
  57. }

  58. void delay_ms(unsigned int time)
  59. {
  60.     unsigned char
  61.     i;
  62.     for(i=1; i<=time; i++)
  63.         Delay1ms();
  64. }


  65. void uartsend_int16(short val)
  66. {
  67.     uchar val1;
  68.     val1=val/10000;
  69.     while(!TEND);
  70.     TEND=0;
  71.     TBUF='0'+val1;
  72.     TING=1;
  73.     val1=val%10000/1000;
  74.     while(!TEND);
  75.     TEND=0;
  76.     TBUF='0'+val1;
  77.     TING=1;
  78.     val1=val%1000/100;
  79.     while(!TEND);
  80.     TEND=0;
  81.     TBUF='0'+val1;
  82.     TING=1;
  83.     val1=val%100/10;
  84.     while(!TEND);
  85.     TEND=0;
  86.     TBUF='0'+val1;
  87.     TING=1;
  88.     val1=val%10/1;
  89.     while(!TEND);
  90.     TEND=0;
  91.     TBUF='0'+val1;
  92.     TING=1;
  93. }
  94. void uartprintf(char *s)
  95. {
  96.     int i=0;
  97.     while(s[i]!='\0')
  98.     {
  99.         while(!TEND);
  100.         TEND=0;
  101.         TBUF=s[i];
  102.         TING=1;
  103.         i++;
  104.     }
  105. }
  106. void uartprintenter()
  107. {
  108.     while(!TEND);
  109.     TEND=0;
  110.     TBUF=0x0d;
  111.     TING=1;
  112.         while(!TEND);
  113.     TEND=0;
  114.     TBUF=0x0a;
  115.     TING=1;
  116. }
  117. void main()
  118. {
  119.     uchar val = 0;
  120.     int cnt = 0;
  121.     TMOD = 0x00;                        //timer0 in 16-bit auto reload mode
  122.     AUXR = 0x80;                        //timer0 working at 1T mode
  123.     TL0 = BAUD;
  124.     TH0 = BAUD>>8;                      //initial timer0 and set reload value
  125.     TR0 = 1;                            //tiemr0 start running
  126.     ET0 = 1;                            //enable timer0 interrupt
  127.     PT0 = 1;                            //improve timer0 interrupt priority
  128.     EA = 1;                             //open global interrupt switch

  129.     UART_INIT();
  130.     uartprintf("start");
  131.     while (1)
  132.     {
  133.         vl53l0x_send(VL53L0X_REG_SYSRANGE_START, 0x01);
  134.         while (cnt < 100) { // 1 second waiting time max
  135.             delay_ms(10);
  136.             val = vl53l0x_read(VL53L0X_REG_RESULT_RANGE_STATUS);
  137.             if (val & 0x01) break;
  138.             cnt++;
  139.         }
  140.         if (val & 0x01) uartprintf("ready");
  141.         else uartprintf("not ready");
  142.                                 uartprintenter();
  143.         //vl53l0x_read_block(0x14, 12);
  144.                                 gbuf[0]=vl53l0x_read(0x14);
  145.                                 gbuf[7]=vl53l0x_read(0x14+7);
  146.                                 gbuf[6]=vl53l0x_read(0x14+6);
  147.                                 gbuf[9]=vl53l0x_read(0x14+9);
  148.                                 gbuf[8]=vl53l0x_read(0x14+8);
  149.                                 gbuf[11]=vl53l0x_read(0x14+11);
  150.                                 gbuf[10]=vl53l0x_read(0x14+10);
  151.         acnt = makeuint16(gbuf[7], gbuf[6]);
  152.         scnt = makeuint16(gbuf[9], gbuf[8]);
  153.         dist = makeuint16(gbuf[11], gbuf[10]);
  154.         DeviceRangeStatusInternal = ((gbuf[0] & 0x78) >> 3);
  155.                                 if(DeviceRangeStatusInternal==11&&dist>20&&dist<1200)
  156.                                 {
  157.                                         uartprintf("distance:");
  158.                                         uartsend_int16(dist);
  159.                                         uartprintf("mm");
  160.                                         uartprintenter();
  161.                                 }
  162.                                 else
  163.                                 {
  164.                                         uartprintf("error");
  165.                                         uartprintenter();
  166.                                 }
  167.         delay_ms(100);

  168.     }
  169. }
  170. void tm0() interrupt 1 using 1
  171. {
  172.     if (RING)
  173.     {
  174.         if (--RCNT == 0)
  175.         {
  176.             RCNT = 3;                   //reset send baudrate counter
  177.             if (--RBIT == 0)
  178.             {
  179.                 RBUF = RDAT;            //save the data to RBUF
  180.                 RING = 0;               //stop receive
  181.                 REND = 1;               //set receive completed flag
  182.             }
  183.             else
  184.             {
  185.                 RDAT >>= 1;
  186.                 if (RXB) RDAT |= 0x80;  //shift RX data to RX buffer
  187.             }
  188.         }
  189.     }
  190.     else if (!RXB)
  191.     {
  192.         RING = 1;                       //set start receive flag
  193.         RCNT = 4;                       //initial receive baudrate counter
  194.         RBIT = 9;                       //initial receive bit number (8 data bits + 1 stop bit)
  195.     }

  196.     if (--TCNT == 0)
  197.     {
  198.         TCNT = 3;                       //reset send baudrate counter
  199.         if (TING)                       //judge whether sending
  200.         {
  201.             if (TBIT == 0)
  202.             {
  203.                 TXB = 0;                //send start bit
  204.                 TDAT = TBUF;            //load data from TBUF to TDAT
  205.                 TBIT = 9;               //initial send bit number (8 data bits + 1 stop bit)
  206.             }
  207.             else
  208. ……………………

  209. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
VL53l0x激光测距.rar (62.09 KB, 下载次数: 174)



回复

使用道具 举报

ID:280484 发表于 2018-1-28 19:57 | 显示全部楼层
感谢分享,多谢了呃
回复

使用道具 举报

ID:280484 发表于 2018-1-28 19:58 | 显示全部楼层
感谢您的分享,这份资料太难找了
回复

使用道具 举报

ID:216667 发表于 2019-9-22 23:05 | 显示全部楼层
怎么没初始化,跑起来有问题
回复

使用道具 举报

ID:606251 发表于 2019-9-23 08:47 | 显示全部楼层
谢谢分享,感谢楼主!
回复

使用道具 举报

ID:284075 发表于 2019-11-11 23:31 | 显示全部楼层
写得太乱了,
回复

使用道具 举报

ID:927341 发表于 2021-8-16 16:39 | 显示全部楼层
这个显示用的是哪个
回复

使用道具 举报

ID:892596 发表于 2021-8-17 09:40 | 显示全部楼层
这个芯片最近挺火的,它的精度可以达到什么程度?
回复

使用道具 举报

ID:72243 发表于 2022-5-2 21:28 | 显示全部楼层
这个芯片最近挺火的,不知精度如何。
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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