ROS1/2机器人之从命令调用到程序编写

举报
zhangrelay 发表于 2022/03/27 00:03:53 2022/03/27
【摘要】 难度级别: 容易☞命令调用 困难☞程序编写 命令调用简单案例 ROS1: rosrun package-name executable-name *ROS1必须要保证主节点运行,才能单独使用rosrun。 (roscore) ROS2: ros2 run package-name executable-n...

难度级别:

容易☞命令调用

困难☞程序编写


命令调用简单案例

ROS1:

rosrun package-name executable-name

*ROS1必须要保证主节点运行,才能单独使用rosrun。

(roscore)

ROS2:

ros2 run package-name executable-name

比如启动键盘遥控turtlesim

ROS1:

roscore

rosrun turtlesim turtlesim_node

rosrun turtlesim turtle_teleop_key

大多数 ROS1 节点在启动时连接到节点管理器上,如果运行中连接中断,则不会尝试重新连接。因此,如果 roscore 被终止,当前运行的其他节点将无法建立新的连接,即使 稍后重启 roscore 也无济于事。

于是,引入DDS!(当然这只是其中一个重要原因)

ROS2:

ros2 run turtlesim turtlesim_node

ros2 run turtlesim turtle_teleop_key

ROS 2建立在DDS / RTPS之上,将其作为中间件,提供发现、序列化和传输等功能。 总述一下,DDS是一 个端到端的中间件,它提供了ROS系统相关的功能,例如分布式发现(并不是ROS 1采用的集中式,如roscore)和控制传输不同 “服务质量”的选项。

DDS是一个行业标准,然后由一系列供应商实施,如:RTI 的实现版本-Connext或ADLink的实现版本-OpenSplice RTPS(又 名DDSI-RTPS)是DDS用于通过网络进行通信的有线协议,虽 然有些实现并不能满足完整的DDS API,但可以为ROS 2提供足够的功能,例如eProsima的实现版本-快速RTPS。 ROS 2支持多种DDS / RTPS实现,因此在选择供应商/实现时,并不是“一刀切”。在选择中间件实现时,可能会考虑许多因 素:许可、技术、平台可用性或计算占用空间等因素。供应商可能会提供多个针对满足不同需求的DDS或RTPS实现版本。例如,RTI有一些Connext实现的变化,其目的各不相同,例如专门 针对微控制器而另一个针对需要特殊安全认证的应用(目前ROS 2仅支持其标准桌面版本)。为 了 使 用 DDS / RTPS 实 现 与 ROS 2 , ROS 中 间 接 口 “ROS Middleware interface, RMW”(又名rmw接口或rmw)封装需要创建一个使用DDS实现或RTPS实现的API和工具抽象ROS中 间件接口。实现和维护RMW包用于支持DDS开发需要做很多工作,但至少支持一些实现对于确保ROS 2代码库不依赖于任何一 个特定实现非常重要,因为用户依据具体项目的需求,可能希望根据需要切换实现版本。


程序编写简单案例

为何package-name是turtlesim?

这是功能包的名字?


  
  1. cmake_minimum_required(VERSION 3.5)
  2. project(turtlesim)
  3. if(NOT CMAKE_CXX_STANDARD)
  4. set(CMAKE_CXX_STANDARD 14)
  5. endif()
  6. if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
  7. add_compile_options(-Wall -Wextra -Wpedantic)
  8. endif()
  9. find_package(ament_cmake REQUIRED)
  10. find_package(ament_index_cpp REQUIRED)
  11. find_package(geometry_msgs REQUIRED)
  12. find_package(Qt5 REQUIRED COMPONENTS Widgets)
  13. find_package(rclcpp REQUIRED)
  14. find_package(rclcpp_action REQUIRED)
  15. find_package(rosidl_default_generators REQUIRED)
  16. find_package(std_msgs REQUIRED)
  17. find_package(std_srvs REQUIRED)
  18. include_directories(include ${Qt5Widgets_INCLUDE_DIRS})
  19. rosidl_generate_interfaces(${PROJECT_NAME}
  20. "action/RotateAbsolute.action"
  21. "msg/Color.msg"
  22. "msg/Pose.msg"
  23. "srv/Kill.srv"
  24. "srv/SetPen.srv"
  25. "srv/Spawn.srv"
  26. "srv/TeleportAbsolute.srv"
  27. "srv/TeleportRelative.srv")
  28. set(dependencies "ament_index_cpp" "geometry_msgs" "rclcpp" "rclcpp_action" "std_msgs" "std_srvs")
  29. set(turtlesim_node_SRCS
  30. src/turtlesim.cpp
  31. src/turtle.cpp
  32. src/turtle_frame.cpp
  33. )
  34. set(turtlesim_node_HDRS
  35. include/turtlesim/turtle_frame.h
  36. )
  37. qt5_wrap_cpp(turtlesim_node_MOCS ${turtlesim_node_HDRS})
  38. add_executable(turtlesim_node ${turtlesim_node_SRCS} ${turtlesim_node_MOCS})
  39. target_link_libraries(turtlesim_node Qt5::Widgets)
  40. ament_target_dependencies(turtlesim_node ${dependencies})
  41. rosidl_target_interfaces(turtlesim_node ${PROJECT_NAME} "rosidl_typesupport_cpp")
  42. add_executable(turtle_teleop_key tutorials/teleop_turtle_key.cpp)
  43. ament_target_dependencies(turtle_teleop_key ${dependencies})
  44. rosidl_target_interfaces(turtle_teleop_key ${PROJECT_NAME} "rosidl_typesupport_cpp")
  45. add_executable(draw_square tutorials/draw_square.cpp)
  46. ament_target_dependencies(draw_square ${dependencies})
  47. rosidl_target_interfaces(draw_square ${PROJECT_NAME} "rosidl_typesupport_cpp")
  48. add_executable(mimic tutorials/mimic.cpp)
  49. ament_target_dependencies(mimic ${dependencies})
  50. rosidl_target_interfaces(mimic ${PROJECT_NAME} "rosidl_typesupport_cpp")
  51. install(TARGETS turtlesim_node turtle_teleop_key draw_square mimic
  52. DESTINATION lib/${PROJECT_NAME})
  53. install(DIRECTORY images
  54. DESTINATION share/${PROJECT_NAME}
  55. FILES_MATCHING PATTERN "*.png" PATTERN "*.svg")
  56. install(DIRECTORY launch
  57. DESTINATION share/${PROJECT_NAME})
  58. ament_package()

功能包名字参考:project(turtlesim)

与此类似,节点名字如下:

add_executable(turtlesim_node ${turtlesim_node_SRCS} ${turtlesim_node_MOCS})
target_link_libraries(turtlesim_node Qt5::Widgets)
ament_target_dependencies(turtlesim_node ${dependencies})
rosidl_target_interfaces(turtlesim_node ${PROJECT_NAME} "rosidl_typesupport_cpp")

add_executable(turtle_teleop_key tutorials/teleop_turtle_key.cpp)
ament_target_dependencies(turtle_teleop_key ${dependencies})
rosidl_target_interfaces(turtle_teleop_key ${PROJECT_NAME} "rosidl_typesupport_cpp")


命令调用,通俗不严谨说类似API;

编写程序,通俗不严谨说类似APP。

调用API难,还是开发APP难?不言而喻呢。


只使用命令调用(受制于程序):

如果程序编写则可以(自由飞翔的舞台):


 


  
  1. #include "turtlesim/turtle_frame.h"
  2. #include <QPointF>
  3. #include <cstdlib>
  4. #include <ctime>
  5. #define DEFAULT_BG_R 0x65
  6. #define DEFAULT_BG_G 0x65
  7. #define DEFAULT_BG_B 0x65
  8. namespace turtlesim
  9. {
  10. TurtleFrame::TurtleFrame(rclcpp::Node::SharedPtr& node_handle, QWidget* parent, Qt::WindowFlags f)
  11. : QFrame(parent, f)
  12. , path_image_(888, 888, QImage::Format_ARGB32)
  13. , path_painter_(&path_image_)
  14. , frame_count_(0)
  15. , id_counter_(0)
  16. {
  17. setFixedSize(888, 888);
  18. setWindowTitle("TurtleSim奇妙曲线");
  19. srand(time(NULL));
  20. update_timer_ = new QTimer(this);
  21. update_timer_->setInterval(16);
  22. update_timer_->start();
  23. connect(update_timer_, SIGNAL(timeout()), this, SLOT(onUpdate()));
  24. nh_ = node_handle;
  25. rcl_interfaces::msg::IntegerRange range;
  26. range.from_value = 0;
  27. range.step = 1;
  28. range.to_value = 255;
  29. rcl_interfaces::msg::ParameterDescriptor background_r_descriptor;
  30. background_r_descriptor.description = "Red channel of the background color";
  31. background_r_descriptor.integer_range.push_back(range);
  32. rcl_interfaces::msg::ParameterDescriptor background_g_descriptor;
  33. background_g_descriptor.description = "Green channel of the background color";
  34. background_g_descriptor.integer_range.push_back(range);
  35. rcl_interfaces::msg::ParameterDescriptor background_b_descriptor;
  36. background_b_descriptor.description = "Blue channel of the background color";
  37. background_b_descriptor.integer_range.push_back(range);
  38. nh_->declare_parameter("background_r", rclcpp::ParameterValue(DEFAULT_BG_R), background_r_descriptor);
  39. nh_->declare_parameter("background_g", rclcpp::ParameterValue(DEFAULT_BG_G), background_g_descriptor);
  40. nh_->declare_parameter("background_b", rclcpp::ParameterValue(DEFAULT_BG_B), background_b_descriptor);

 

 

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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