“超声波”的版本间的差异
来自Labplus盛思维基百科
Tangliufeng(讨论 | 贡献) (→Arduino示例) |
Tangliufeng(讨论 | 贡献) (→Arduino示例) |
||
第31行: | 第31行: | ||
void setup() | void setup() | ||
{ | { | ||
− | Serial.begin(115200); | + | Serial.begin(115200); //串口初始化,波特率115200 |
− | Wire.begin(); | + | Wire.begin(); //I2C初始化 |
} | } | ||
− | uint8_t Distance(); | + | uint8_t Distance(); //声明超声波函数 |
void loop() | void loop() | ||
{ | { | ||
− | Serial.print(Distance()); | + | Serial.print(Distance()); //打印测距 |
Serial.println("cm"); | Serial.println("cm"); | ||
delay(100); | delay(100); | ||
第47行: | 第47行: | ||
uint8_t cm; | uint8_t cm; | ||
uint8_t temp[2]; | uint8_t temp[2]; | ||
− | Wire.beginTransmission(0x0b); | + | Wire.beginTransmission(0x0b); //传输给从机设备0x0B |
− | Wire.write(1); | + | Wire.write(1); //发送1指令 |
− | Wire.endTransmission(); | + | Wire.endTransmission(); //结束传输 |
− | Wire.requestFrom(0x0b, 2); | + | Wire.requestFrom(0x0b, 2); //接收从机设备0x0B,长度2字节 |
− | while (Wire.available()) { | + | while (Wire.available()) { |
temp[i] = Wire.read(); | temp[i] = Wire.read(); | ||
i++; | i++; | ||
} | } | ||
− | return cm = (temp[0] + temp[1] * 256) / 10; | + | return cm = (temp[0] + temp[1] * 256) / 10; |
} | } | ||
</pre> | </pre> |
2017年12月27日 (三) 10:29的版本
概述
用于超声波定位、测距、避障等应用场景。操作简单采用I2C通讯将测距值返回主控。有效测距范围3~300cm
技术参数
- 工作电压:3.3Vor5V
- 接口方式:I2C接口
- 超声波测量范围:3cm~300cm
- 误差:±1%
- 模块尺寸:24x46x7.5mm
引脚定义
VCC | 电源 |
ECHO | 连接I2C_SDA |
TRIG | 连接I2C_SCL |
GND | 地 |
使用教程
连接示意图
Arduino示例
#include <Wire.h> void setup() { Serial.begin(115200); //串口初始化,波特率115200 Wire.begin(); //I2C初始化 } uint8_t Distance(); //声明超声波函数 void loop() { Serial.print(Distance()); //打印测距 Serial.println("cm"); delay(100); } uint8_t Distance() { int i = 0; uint8_t cm; uint8_t temp[2]; Wire.beginTransmission(0x0b); //传输给从机设备0x0B Wire.write(1); //发送1指令 Wire.endTransmission(); //结束传输 Wire.requestFrom(0x0b, 2); //接收从机设备0x0B,长度2字节 while (Wire.available()) { temp[i] = Wire.read(); i++; } return cm = (temp[0] + temp[1] * 256) / 10; }
MicroPython示例
from microbit import * def Distance(): i2c.write(0x0b, bytearray([1])) sleep(2) temp=i2c.read(0x0b,2) distanceCM=(temp[0]+temp[1]*256)/10 return distanceCM # test code while True: print(Distance()) sleep(100)