ESP32与ROS调试笔记(Linux和Windows)

举报
zhangrelay 发表于 2021/07/15 02:42:18 2021/07/15
【摘要】 ESP32支持ROS1和ROS2,很方便使用,有两种主流方式: arduino IDE (1.8.13)esp idf(4.2) 网上和Github上有很多方式,用了一下都感觉不适合我! 其实很简单,和esp8266类似,只用arduino自带的ros包即可,注意版本号0.7.8。 参考如下:ESP8266和ESP32配置(需使用ROS1和ROS2) 这里,主要看源码...

ESP32支持ROS1和ROS2,很方便使用,有两种主流方式:

  • arduino IDE (1.8.13)
  • esp idf(4.2)

网上和Github上有很多方式,用了一下都感觉不适合我!

其实很简单,和esp8266类似,只用arduino自带的ros包即可,注意版本号0.7.8。

参考如下:ESP8266和ESP32配置(需使用ROS1和ROS2)

这里,主要看源码需要修改的地方,头文件!

esp8266使用/home/ros/.arduino15/packages/esp8266/hardware/esp8266/2.7.4/libraries/ESP8266WiFi/src

  • ESP8266WiFi.h

  
  1. #ifndef WiFi_h
  2. #define WiFi_h
  3. #include <stdint.h>
  4. extern "C" {
  5. #include "include/wl_definitions.h"
  6. }
  7. #include "IPAddress.h"
  8. #include "ESP8266WiFiType.h"
  9. #include "ESP8266WiFiSTA.h"
  10. #include "ESP8266WiFiAP.h"
  11. #include "ESP8266WiFiScan.h"
  12. #include "ESP8266WiFiGeneric.h"
  13. #include "WiFiClient.h"
  14. #include "WiFiServer.h"
  15. #include "WiFiServerSecure.h"
  16. #include "WiFiClientSecure.h"
  17. #include "BearSSLHelpers.h"
  18. #include "CertStoreBearSSL.h"
  19. #ifdef DEBUG_ESP_WIFI
  20. #ifdef DEBUG_ESP_PORT
  21. #define DEBUG_WIFI(fmt, ...) DEBUG_ESP_PORT.printf_P( (PGM_P)PSTR(fmt), ##__VA_ARGS__ )
  22. #endif
  23. #endif
  24. #ifndef DEBUG_WIFI
  25. #define DEBUG_WIFI(...) do { (void)0; } while (0)
  26. #endif
  27. class ESP8266WiFiClass : public ESP8266WiFiGenericClass, public ESP8266WiFiSTAClass, public ESP8266WiFiScanClass, public ESP8266WiFiAPClass {
  28. public:
  29. // workaround same function name with different signature
  30. using ESP8266WiFiGenericClass::channel;
  31. using ESP8266WiFiSTAClass::SSID;
  32. using ESP8266WiFiSTAClass::RSSI;
  33. using ESP8266WiFiSTAClass::BSSID;
  34. using ESP8266WiFiSTAClass::BSSIDstr;
  35. using ESP8266WiFiScanClass::SSID;
  36. using ESP8266WiFiScanClass::encryptionType;
  37. using ESP8266WiFiScanClass::RSSI;
  38. using ESP8266WiFiScanClass::BSSID;
  39. using ESP8266WiFiScanClass::BSSIDstr;
  40. using ESP8266WiFiScanClass::channel;
  41. using ESP8266WiFiScanClass::isHidden;
  42. // ----------------------------------------------------------------------------------------------
  43. // ------------------------------------------- Debug --------------------------------------------
  44. // ----------------------------------------------------------------------------------------------
  45. public:
  46. void printDiag(Print& dest);
  47. friend class WiFiClient;
  48. friend class WiFiServer;
  49. };
  50. extern ESP8266WiFiClass WiFi;
  51. #endif

esp32使用/home/ros/.arduino15/packages/esp32/hardware/esp32/1.0.4/libraries/WiFi/src

  • WiFi.h

这个会和系统目录中wifi.h重合,请务必保证编译时头文件路径正确!


  
  1. #ifndef WiFi_h
  2. #define WiFi_h
  3. #include <stdint.h>
  4. #include "Print.h"
  5. #include "IPAddress.h"
  6. #include "IPv6Address.h"
  7. #include "WiFiType.h"
  8. #include "WiFiSTA.h"
  9. #include "WiFiAP.h"
  10. #include "WiFiScan.h"
  11. #include "WiFiGeneric.h"
  12. #include "WiFiClient.h"
  13. #include "WiFiServer.h"
  14. #include "WiFiUdp.h"
  15. class WiFiClass : public WiFiGenericClass, public WiFiSTAClass, public WiFiScanClass, public WiFiAPClass
  16. {
  17. public:
  18. using WiFiGenericClass::channel;
  19. using WiFiSTAClass::SSID;
  20. using WiFiSTAClass::RSSI;
  21. using WiFiSTAClass::BSSID;
  22. using WiFiSTAClass::BSSIDstr;
  23. using WiFiScanClass::SSID;
  24. using WiFiScanClass::encryptionType;
  25. using WiFiScanClass::RSSI;
  26. using WiFiScanClass::BSSID;
  27. using WiFiScanClass::BSSIDstr;
  28. using WiFiScanClass::channel;
  29. public:
  30. void printDiag(Print& dest);
  31. friend class WiFiClient;
  32. friend class WiFiServer;
  33. friend class WiFiUDP;
  34. };
  35. extern WiFiClass WiFi;
  36. #endif

一切正常愉快玩耍:

编译如有问题请自行查错修订,测试过代码如下,wifi名和密码为***,请用实际替换,UART使用如教程一致:


  
  1. #include "WiFi.h"
  2. #include <ros.h>
  3. #include <std_msgs/String.h>
  4. #include <std_msgs/Int16.h>
  5. #include <std_msgs/Float64.h>
  6. #include <rosserial_arduino/Adc.h>
  7. //
  8. // WiFi Definitions //
  9. //
  10. const char* ssid = "********";
  11. const char* password = "*********";
  12. IPAddress server(172, 20, 10, 3); // ip of your ROS server
  13. IPAddress ip_address;
  14. int status = WL_IDLE_STATUS;
  15. WiFiClient client;
  16. class WiFiHardware {
  17. public:
  18. WiFiHardware() {};
  19. void init() {
  20. // do your initialization here. this probably includes TCP server/client setup
  21. client.connect(server, 11411);
  22. }
  23. // read a byte from the serial port. -1 = failure
  24. int read() {
  25. // implement this method so that it reads a byte from the TCP connection and returns it
  26. // you may return -1 is there is an error; for example if the TCP connection is not open
  27. return client.read(); //will return -1 when it will works
  28. }
  29. // write data to the connection to ROS
  30. void write(uint8_t* data, int length) {
  31. // implement this so that it takes the arguments and writes or prints them to the TCP connection
  32. for(int i=0; i<length; i++)
  33. client.write(data[i]);
  34. }
  35. // returns milliseconds since start of program
  36. unsigned long time() {
  37. return millis(); // easy; did this one for you
  38. }
  39. };
  40. int i;
  41. void chatterCallback(const std_msgs::String& msg) {
  42. i = atoi(msg.data);
  43. }
  44. std_msgs::String str_msg;
  45. rosserial_arduino::Adc adc_msg;
  46. ros::Publisher chatter("chatter", &str_msg);
  47. ros::Publisher p("adc", &adc_msg);
  48. ros::Subscriber<std_msgs::String> sub("message", &chatterCallback);
  49. ros::NodeHandle_<WiFiHardware> nh;
  50. char hello[20] = "ESP32 wifi alive!";
  51. void setupWiFi()
  52. {
  53. WiFi.begin(ssid, password);
  54. Serial.print("\nConnecting to "); Serial.println(ssid);
  55. uint8_t i = 0;
  56. while (WiFi.status() != WL_CONNECTED && i++ < 20) delay(500);
  57. if(i == 21){
  58. Serial.print("Could not connect to"); Serial.println(ssid);
  59. while(1) delay(500);
  60. }
  61. Serial.print("Ready! Use ");
  62. Serial.print(WiFi.localIP());
  63. Serial.println(" to access client");
  64. }
  65. int averageAnalog(int pin){
  66. int v=0;
  67. for(int i=0; i<4; i++) v+= analogRead(pin);
  68. return v/4;
  69. }
  70. void setup() {
  71. Serial.begin(115200);
  72. setupWiFi();
  73. delay(2000);
  74. nh.initNode();
  75. nh.advertise(chatter);
  76. nh.subscribe(sub);
  77. nh.advertise(p);
  78. }
  79. void loop() {
  80. str_msg.data = hello;
  81. chatter.publish( &str_msg );
  82. adc_msg.adc0 = averageAnalog(0);
  83. p.publish(&adc_msg);
  84. nh.spinOnce();
  85. delay(500);
  86. }

主机端配置对应IP。

rosrun rosserial_python serial_node.py tcp

连接成功!!!

查看一下主题?

很愉快,一次成功,没有遇到什么奇怪的问题。和8266几乎一致,但是esp32性能强于8266。

windows环境下测试:

先看IP是否匹配,注意UART看串口号,wifi看IP,一定要正确才可以!

接着,直接用可以使用了。

然后启动,tcp节点:

rosrun rosserial_server socket_node tcp

查看一下:

注意,如果配置不正确,无法看到/adc,/chatter,/message等主题哦。

支持ros版本(melodic,neotic),系统版本(linux,windows),已全部测试均可以。

C:\ros_ws>set ROS_IP=172.20.10.3 C:\ros_ws>set ROS_MASTER_URI=http://172.20.10.3:11311 C:\ros_ws>roscore ... logging to C:\Users\zhangrelay\.ros\log\56128ade-1a25-11eb-9f50-94b86dd78b23\roslaunch-LAPTOP-5REQ7K1L-10872.log Checking log directory for disk usage. This may take a while. Press Ctrl-C to interrupt Done checking log file disk usage. Usage is <1GB. started roslaunch server http://172.20.10.3:60658/ ros_comm version 1.14.9 SUMMARY ======== PARAMETERS * /rosdistro: melodic * /rosversion: 1.14.9 NODES auto-starting new master process[master]: started with pid [12060] ROS_MASTER_URI=http://172.20.10.3:11311/ setting /run_id to 56128ade-1a25-11eb-9f50-94b86dd78b23 process[rosout-1]: started with pid [13192] started core service [/rosout] 
 

-fin-


 

文章来源: zhangrelay.blog.csdn.net,作者:zhangrelay,版权归原作者所有,如需转载,请联系作者。

原文链接:zhangrelay.blog.csdn.net/article/details/109380412

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。