1. 机器人定位装置的构建

按照上面的针脚使用杜邦线将救援机器人定位装置的主从蓝牙连接到主控板上,注意错误的连接会导致模块损坏【参考视频

2. 机器人位置的获取与发送

(1) 在机器人定位装置的控制板中烧录以下程序(robot.ino)

/*------------------------------------------------------------------------------------

版权说明:Copyright 2022 Robottime(Beijing) Technology Co., Ltd. All Rights Reserved.

Distributed under MIT license.See file LICENSE for detail or copy at

https://opensource.org/licenses/MIT

by 机器谱 2022-5-30 https://www.robotway.com/

-------------------------------------------------------------------------------------*/

//救援机器人定位装置例程

//配置模块:(模块在配置时与正常工作时TX、RX线序不同,请注意)

//第一步:使用AT指令将所使用的两个模块其中一个设置为主模式,另外一个为从模式;所有模块波特率全部为默认的9600,并记录主从模块的地址(AT+ADDR?);

//第二步:将主模块在未连接时清除之前的配对信息(AT+CLEAR),再设置其工作类型为类型1(AT+IMME即上后处于等待状态,收到AT+START,AT+DISC,AT+CONNL等指令后开始工作);

//开始工作:

//第三步:将所有模块上电(主从模块按照上面介绍的连接方式连接即可);

//第四步:将本程序下载进MEGA2560中,将从模块分别摆开,观察显示屏数据;

/*********从设备地址********/

// "D8A98B788750",

// "D8A98B788732",

// "380B3CFFC5B0"

/*********从设备地址********/

/**********头文件***************/

#include <Arduino.h>

#include <Wire.h>

#include <MultiLCD.h>

#include <RssiPositionComputer.h>

/***********宏定义**************/

#define DEBUG_SERIAL Serial //打印信息串口

#define CON_SERIAL Serial1 //蓝牙通信串口

#define SEND_SERIAL Serial2 //数据发送串口

#define CMD_CON "AT+CON"

#define CMD_DIS_CON "AT"

#define CMD_GET_RSSI "AT+RSSI?"

RssiPositionComputer myPositionComputer;

Point2D master_point; //基站数量

#define SLAVENUMBER 3 //基站地址

String BLUETOOTHADDRESS[3] = {

"D8A98B788750",

"D8A98B788732",

"380B3CFFC5B0"

};

//位置发送蓝牙地址

// F83002253178

String search_result_string[SLAVENUMBER] = {""};

String rssi[SLAVENUMBER] = {""};

float distance[SLAVENUMBER] = {};

void setup()

{

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.begin(9600);

#endif

CON_SERIAL.begin(9600);

SEND_SERIAL.begin(9600);

delay(1000);

init_ble();

}

void loop()

{

read_ble(BLUETOOTHADDRESS);

to_axis(distance, &master_point);

} //读取串口

String serial_read(int _len)

{

String data = "";

int len = 0;

unsigned long t = millis() + 1000;

while(1)

{

while(CON_SERIAL.available())

{

char c = CON_SERIAL.read();

data += c; len++;

}

if(len == _len)

{

break;

}

if(millis() > t)

break;

}

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.print("Serialread_data=");

DEBUG_SERIAL.println(data);

#endif

return data;

}

//初始化

void init_ble()

{

CON_SERIAL.print(CMD_DIS_CON);

delay(100);

serial_read(2);

}

//获取设备1 RSSI

void read_ble(String * address)

{

DEBUG_SERIAL.println("-----------------Start------------------");

for(int i=0;i<SLAVENUMBER;i++)

{

CON_SERIAL.print(CMD_DIS_CON);

delay(500);

serial_read(2);

CON_SERIAL.print(CMD_CON + address[i]);

serial_read(8);

delay(800);

CON_SERIAL.print(CMD_GET_RSSI);

String rssi_str = serial_read(10);

String _rssi = rssi_str.substring(7, rssi_str.length());

//rssi

rssi[i] = _rssi;

//distance

distance[i] = rssiToDistance(rssi[i].toFloat());

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.println("BLE_" + String(i) + ": " + rssi[i]);

DEBUG_SERIAL.println("BLE_" + String(i) + ": " + distance[i]);

#endif

//delay(800);

}

DEBUG_SERIAL.println("------------------End------------------");

DEBUG_SERIAL.println();

}

//计算距离

float rssiToDistance(float rssi)

{

float dis = 0;

//dis = pow(10.0,((abs(rssi)-56)/10.0/1.05));

dis = pow(10.0,((abs(rssi)-56)/5.0/1.65));

return dis;

}

//转换为2d坐标x,y

void to_axis(float * dis, Point2D* actual_master_point)

{

//myPositionComputer.distanceToPoint(*dis,*(dis+1),*(dis+2),actual_master_point);

myPositionComputer.distanceToPoint(*dis,*(dis+1),random(0,77),actual_master_point);

int x = master_point.x*100;

int y = master_point.y*100;

char point[100];

sprintf(point, "[bx:%3d,by:%3d]\n",abs(x),abs(y));

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.println(point);

#endif

SEND_SERIAL.print(point);

}

(2)在中控台的主控板中烧录以下程序(master.ino)

/*------------------------------------------------------------------------------------

版权说明:Copyright 2022 Robottime(Beijing) Technology Co., Ltd. All Rights Reserved.

Distributed under MIT license.See file LICENSE for detail or copy at

https://opensource.org/licenses/MIT

by 机器谱 2022-5-30 https://www.robotway.com/

-------------------------------------------------------------------------------------*/

//救援指挥中心例程

//配置模块:(模块在配置时与正常工作时TX、RX线序不同,请注意)

//第一步:使用AT指令将所使用的两个模块设置为主模式;所有模块波特率全部为默认的9600,并记录待救援设备从模块的地址(AT+ADDR?);

//第二步:将主模块在未连接时清除之前的配对信息(AT+CLEAR),再设置其工作类型为类型1(AT+IMME即上后处于等待状态,收到AT+START,AT+DISC,AT+CONNL等指令后开始工作);

//开始工作:

//第三步:将所有模块上电(主模块参考控制中心的连接进行接线,待救援设备从模块参考相应的连接);

//第四步:将本程序下载进MEGA2560中,将从模块分别摆开,观察显示屏数据;

#include <Arduino.h>

#include <Wire.h>

#include <MultiLCD.h>

#define DATA_SERIAL Serial   //信息打印串口

#define HUMAN_SERIAL Serial1 //待救援数据

#define ROBOT_SERIAL Serial2 //救援机器人数据

#define CMD_CON "AT+CON"

#define CMD_DIS_CON "AT"

#define CMD_START "AT+START"

LCD_SSD1306 lcd;

String human_address = "F83002253650";   //待救援设备地址

String robot_address = "F83002253178";   //救援机器人设备地址

String human_point = "[ax: 0 , ay: 0]";

String robot_point = "[bx: 0 , by: 0]";

void setup() {

DATA_SERIAL.begin(9600);

HUMAN_SERIAL.begin(9600);

ROBOT_SERIAL.begin(9600);

lcd.begin();

master_init();

}

void loop() {

read_human_point();

read_robot_point();

point_display();

}

void connect_ble(){

//连接待救援设备地址

//   HUMAN_SERIAL.print(CMD_START);delay(1000);

HUMAN_SERIAL.print(CMD_DIS_CON);delay(200);

HUMAN_SERIAL.print(CMD_CON + human_address);

//连接救援机器人设备地址

ROBOT_SERIAL.print(CMD_DIS_CON);delay(200);

ROBOT_SERIAL.print(CMD_CON + robot_address);

}

//读取待救援位置

void read_human_point(){

while(1){

String str;

while(HUMAN_SERIAL.available() > 0){

str = HUMAN_SERIAL.readStringUntil('\n');

str.trim();

}

if(!str.equals("")){

Serial.println(str);

human_point = str;

break;

}

}

}

//读取救援机器人位置

void read_robot_point(){

while(1){

String str;

while(ROBOT_SERIAL.available() > 0){

str = ROBOT_SERIAL.readStringUntil('\n');

str.trim();

}

if(!str.equals("")){

Serial.println(str);

robot_point = str;

break;

}

}

}

void point_display(){

lcd.clear();

lcd.setCursor(10, 1);

lcd.print("a: human   b: robot");

lcd.setCursor(20, 3);

lcd.print(human_point);

lcd.setCursor(20, 5);

lcd.print(robot_point);

}

void master_init(){

lcd.clear();

lcd.setCursor(25, 3);

lcd.print("Hello World!");

delay(1000);

point_display();

connect_ble();

while(true){

if(HUMAN_SERIAL.available() > 0 || ROBOT_SERIAL.available() > 0)

break;

}

}

(3)在待救援定位装置的控制板中烧录以下程序(human.ino)

/*------------------------------------------------------------------------------------

版权说明:Copyright 2022 Robottime(Beijing) Technology Co., Ltd. All Rights Reserved.

Distributed under MIT license.See file LICENSE for detail or copy at

https://opensource.org/licenses/MIT

by 机器谱 2022-5-30 https://www.robotway.com/

-------------------------------------------------------------------------------------*/

//待救援主控例程

//配置模块:(模块在配置时与正常工作时TX、RX线序不同,请注意)

//第一步:使用AT指令将所使用的两个模块其中一个设置为主模式,另外一个为从模式;所有模块波特率全部为默认的9600,并记录主从模块的地址(AT+ADDR?);

//第二步:将主模块在未连接时清除之前的配对信息(AT+CLEAR),再设置其工作类型为类型1(AT+IMME即上后处于等待状态,收到AT+START,AT+DISC,AT+CONNL等指令后开始工作);

//开始工作:

//第三步:将所有模块上电(主从模块按照上面介绍的连接方式连接即可);

//第四步:将本程序下载进MEGA2560中,将从模块分别摆开,观察显示屏数据;

/*********从设备地址********/

//   "7CEC79613E1B",

//   "20C38FF2BAA9",

//   "7C669D9B281B"

/*********从设备地址********/

/**********头文件***************/

#include <Arduino.h>

#include <Wire.h>

#include <MultiLCD.h>

#include <RssiPositionComputer.h>

/***********宏定义**************/

//#define DEBUG_SERIAL Serial //打印信息串口

#define CON_SERIAL Serial1 //蓝牙通信串口

#define SEND_SERIAL Serial2 //数据发送串口

#define CMD_CON "AT+CON"

#define CMD_DIS_CON "AT"

#define CMD_GET_RSSI "AT+RSSI?"

RssiPositionComputer myPositionComputer;

Point2D master_point;

//基站数量

#define SLAVENUMBER 3

//基站地址

String BLUETOOTHADDRESS[3] = {

"D8A98B788750",

"D8A98B788732",

"380B3CFFC5B0"

};

//位置发送蓝牙地址

// 20CD397F05B7

String search_result_string[SLAVENUMBER] = {""};

String rssi[SLAVENUMBER] = {""};

float distance[SLAVENUMBER] = {};

void setup() {

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.begin(9600);

#endif

CON_SERIAL.begin(9600);

SEND_SERIAL.begin(9600);

delay(1000);

init_ble();

}

void loop() {

read_ble(BLUETOOTHADDRESS);

to_axis(distance, &master_point);

}

//读取串口

String serial_read(int _len){

String data = "";

int len = 0;

unsigned long t = millis() + 500;

while(1)

{

while(CON_SERIAL.available()){

char c = CON_SERIAL.read();

data += c;

len++;

}

if(len == _len){

break;

}

if(millis() > t)

break;

}

#if defined(DEBUG_SERIAL)

//DEBUG_SERIAL.println(data);

#endif

return data;

}

//初始化

void init_ble(){

CON_SERIAL.print(CMD_DIS_CON);delay(100);

serial_read(2);

}

//获取设备 RSSI

void read_ble(String * address){

for(int i=0;i<SLAVENUMBER;i++){

CON_SERIAL.print(CMD_DIS_CON);delay(100);

serial_read(2);

CON_SERIAL.print(CMD_CON + address[i]);

serial_read(8);

delay(500);

CON_SERIAL.print(CMD_GET_RSSI);

String rssi_str = serial_read(10);

String _rssi = rssi_str.substring(7, rssi_str.length());

//rssi

rssi[i] = _rssi;

//distance

distance[i] = rssiToDistance(rssi[i].toFloat());

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.println("BLE_" + String(i) + ": " + rssi[i]);

//DEBUG_SERIAL.println("BLE_" + String(i) + ": " + distance[i]);

#endif

//delay(800);

}

}

//计算距离

float rssiToDistance(float rssi){

float dis = 0;

//dis = pow(10.0,((abs(rssi)-56)/10.0/1.05));

dis = pow(10.0,((abs(rssi)-56)/5.0/1.65));

return dis;

}

//转换为2d坐标x,y

void to_axis(float * dis, Point2D* actual_master_point){

//myPositionComputer.distanceToPoint(*dis,*(dis+1),*(dis+2),actual_master_point);

myPositionComputer.distanceToPoint(*dis,*(dis+1),random(0,77),actual_master_point);

int x = master_point.x*100;

int y = master_point.y*100;

char point[100];

sprintf(point, "[ax:%3d,ay:%3d]\n",abs(x),abs(y));

#if defined(DEBUG_SERIAL)

DEBUG_SERIAL.println(point);

#endif

SEND_SERIAL.print(point);

}

(4)把定位装置安装在救援机器人身上

(5)依次开启信号塔、待救援定位装置、机器人定位装置、中控台的电源,中控台的OLED屏幕上即可同时显示待救援者和机器人的坐标值(注:中控台的电源必须最后打开)

(6)控制救援机器人移动,可看到机器人的定位坐标随着它的移动而变化。

接下来就可以控制机器人向待救援目标前进了。如果再给救援机器人增加一套WiFi视频遥控的功能(请参考斜三角履带机械臂小车),就可以构建出一套完整的机器人救援场景模型了。

3. 资料内容

① 双目标显示-例程

② 蓝牙配置说明.txt

资料内容下载请参考如何用蓝牙实现无线定位

---------------------------------------------------完结---------------------------------------------------

如何用蓝牙实现无线定位(五)--双定位显示相关推荐

  1. 如何用蓝牙实现无线定位(三)--本地定位显示

    1. 被定位目标 本项目设计有两个定位装置,一个用于固定目标,一个用于可移动设备.在定位系统的帮助下,我们可以操作可移动设备向固定目标移动.假设这是一个救援场景的话,我们就可以把固定的目标看作等待救援 ...

  2. 如何用蓝牙实现无线定位(二)--信号塔设置

    1. 配置BLE4.0模块 根据三点定位原理,本项目需要使用3个信号塔.3个信号塔的主体均为BLE4.0模块,需要把BLE4.0模块的AT指令设置为"从设备". 方法为: (1)给 ...

  3. 如何用蓝牙实现无线定位(一)--系统原理

    1. 简介 本项目将利用多个BLE4.0蓝牙模块,配合主控板.OLED显示屏等,构建一个无线定位系统. 本项目的系统构成为:3个信号塔,1个中控台,2个被定位的目标. 无线定位的用途有很多.比如,我们 ...

  4. 无线定位服务器,智慧社区老人蓝牙APP无线定位系统方案物联网GPS定位系统手环接口...

    系统主要应用于小区内的儿童.老人及宠物的定位管理,亲属可以随时通过手机查 询他们在小区内实时的位置以及历史运动轨迹,以2D地图的方式呈现,如果离开小区 会自动报警. 系统主要由蓝牙AP定位器.蓝牙标签 ...

  5. 三角定位法java代码_GitHub - megagao/IndoorPos: 这是一个采用蓝牙4.0--iBeacon技术的室内定位服务端程序。...

    IndoorPos 这是一个采用iBeacon技术的室内定位服务端程序,里面包含了三种定位算法,三边定位算法.加权三边定位算法和三角形加权质心定位算法.程序采用Spring框架,简化了JDBC和RMI ...

  6. treelist自动定位行_国内首创!金川集团千米深井双定位补偿摇台投用

    新甘肃客户端金昌讯(新甘肃·甘肃日报记者谢晓玲)近日,金川集团二矿区18行副井提升系统罐笼自动化改造项目顺利完成并投入使用.项目研发的双定位补偿摇台是国内同行业首创,可以实现罐笼在井筒内水平和竖直方向 ...

  7. wifi rssi 计算 距离_SKYLAB:蓝牙室内定位与WiFi室内定位的对比分析

    一.Wi-Fi室内定位技术 简单来说,Wi-Fi室内定位技术采用的是三点定位的方式,即通过移动接收设备以及三个Wi-Fi网络接入点的无线信号来确定移动接收设备的位置.由于三个Wi-Fi网络接入点距离移 ...

  8. 转载 解密蓝牙mesh系列 | 第五篇 【好友(Friend)和低功耗节点(LPN)】【友谊(Friendship)参数】【友谊建立】【友谊(Friendship)消息传送】【安全性】【友谊终止】

    YD8801是一款低功耗高性能蓝牙低功耗SOC,集成了高性能2.4GHz射频收发机.32位ARM Cortex-M0处理器.128kB Flash存储器.以及丰富的数字接口.SYD8801片上集成了B ...

  9. 什么软件可以用蓝牙测试信号,litepoint IQview蓝牙测试仪/无线wifi网络信号测试仪...

    无线测试系统 LitePoint IQview®提供强大工具,能取得并测量WiFi及蓝牙讯号,并以分析功能提供装置运作说明,简化了WiFi与Bluetooth®装置的开发过程.IQview与IQfle ...

最新文章

  1. OpenCV中的TermCriteria模板类
  2. SEO数据监控技巧都有哪些?
  3. JavaScript 技术篇-js代码获取当前操作系统信息、浏览器版本信息实例演示,windows NT版本对照表
  4. php通过QQ号获取QQ信息,通过openId能获取到QQ号码吗?
  5. Ocelot中文文档-微服务ServiceFabric
  6. 教你玩转CSS Position(定位)
  7. java获取vm运行参数_如何获取在Java中运行Java VM的版本?
  8. 如何在PHP开启gzip页面压缩实例
  9. Intel Sandy Bridge/Ivy Bridge架构/微架构/流水线 (20) - IvyBridge微架构
  10. Python数据结构:二分查找
  11. 微信公众平台开发,API接入与推送事件(1)
  12. openstack neutron(tap、qvb、qvo详解)(转)
  13. 创建ArrayList对象,添加5个元素,使用Iterator遍历输出
  14. 汉字转拼音 - 输入汉字获取其拼音
  15. 多米诺骨牌问题Push Dominoes
  16. 【京东电商网站主界面仿写—
  17. Vista上StarForce驱动的卸载
  18. php设备在线报修,php企业设备报修系统
  19. poj1273 Drainage Ditches
  20. nvm npm nrm的简单理解

热门文章

  1. javafx布局类HBox和VBox
  2. 官宣 Vue3.0 抛弃支持 IE,把精力集中在这个上面
  3. java中找不到readKeyBoard_我想知道这个为什么一直说找不到符号
  4. SharePoint Online 入门实战教程-杨建宇(霖雨)-专题视频课程
  5. mov转gif怎么制作?怎么把mov视频转换成gif?
  6. A Speech Emotion Recognition Framework for Better Discrimination of Confusions-语音论文阅读
  7. 未来的计算机600字初中作文,未来可期初中作文600字大全
  8. Python Kmeans K均值分类
  9. 抓取豆瓣音乐Top 250数据存到Excel中
  10. 在微信小程序中做自己的数字键盘