ROS 2(Robot Operating System 2)示例项目代码

2024-08-26 14:28

本文主要是介绍ROS 2(Robot Operating System 2)示例项目代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一个简单的ROS 2(Robot Operating System 2)示例项目代码,这个项目将包括两个节点:一个发布者(Publisher)节点和一个订阅者(Subscriber)节点。在这个例子中,发布者节点将周期性地发布一个字符串消息,而订阅者节点将接收这个消息并打印出来。

第一步:创建ROS 2工作空间

首先,你需要有一个ROS 2环境设置好。然后,你可以创建一个新的工作空间并初始化它:

mkdir -p ~/dev_ws/src  
cd ~/dev_ws  
source /opt/ros/<ros2-distro>/setup.bash  # 替换<ros2-distro>为你的ROS 2发行版名称  
colcon build --symlink-install --packages-select your_package_name  # 稍后创建包后使用  
source install/setup.bash

第二步:创建ROS 2包

src目录下创建一个新的ROS 2包:

cd ~/dev_ws/src  
ros2 pkg create --build-type ament_cmake my_talker_listener 
cd my_talker_listener

第三步:编写发布者节点

my_talker_listener包中,创建talker.cpp文件:

// src/talker.cpp
#include <memory>
#include "rclcpp/rclcpp.hpp"
#include "std_msgs/msg/string.hpp"using namespace std::chrono_literals;class Talker : public rclcpp::Node {
public:Talker() : Node("talker") {publisher_ = this->create_publisher<std_msgs::msg::String>("chatter", 10);timer_ = this->create_wall_timer(500ms, std::bind(&Talker::timer_callback, this));}private:void timer_callback() {auto message = std_msgs::msg::String();message.data = "Hello, world! " + std::to_string(this->get_clock()->now().nanoseconds() % 100);RCLCPP_INFO(this->get_logger(), "Publishing: '%s'", message.data.c_str());publisher_->publish(message);}rclcpp::TimerBase::SharedPtr timer_;rclcpp::Publisher<std_msgs::msg::String>::SharedPtr publisher_;
};int main(int argc, char **argv) {rclcpp::init(argc, argv);rclcpp::spin(std::make_shared<Talker>());rclcpp::shutdown();return 0;
}

第四步:编写订阅者节点

my_talker_listener包中,创建listener.cpp文件:

// src/listener.cpp
#include <memory>
#include "rclcpp/rclcpp.hpp"
#include "std_msgs/msg/string.hpp"class Listener : public rclcpp::Node {
public:Listener() : Node("listener") {subscription_ = this->create_subscription<std_msgs::msg::String>("chatter", 10,std::bind(&Listener::topic_callback, this, std::placeholders::_1));}private:void topic_callback(const std_msgs::msg::String::SharedPtr msg) const {RCLCPP_INFO(this->get_logger(), "I heard: [%s]", msg->data.c_str());}rclcpp::Subscription<std_msgs::msg::String>::SharedPtr subscription_;
};int main(int argc, char **argv) {rclcpp::init(argc, argv);rclcpp::spin(std::make_shared<Listener>());rclcpp::shutdown();return 0;
}

第五步:修改CMakeLists.txt

确保你的CMakeLists.txt能够找到并编译这些源文件。这里是一个基本的例子:

cmake_minimum_required(VERSION 3.0.2)
project(my_talker_listener)# find dependencies
find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(std_msgs REQUIRED)# add cpp files
add_executable(talker src/talker.cpp)
ament_target_dependencies(talker rclcpp std_msgs)add_executable(listener src/listener.cpp)
ament_target_dependencies(listener rclcpp std_msgs)# install targets
install(TARGETStalkerlistenerDESTINATION lib/${PROJECT_NAME}
)ament_package()

它的package.xml文件可能如下所示:

<?xml version="1.0"?>  
<package format="3">  <name>my_talker_listener</name>  <version>0.0.1</version>  <description>这是一个ROS 2的示例功能包。</description>  <maintainer email="maintainer@example.com">John Doe</maintainer>  <license>BSD-3-Clause</license>  <!-- 编译依赖 -->  <buildtool_depend>ament_cmake</buildtool_depend>  <build_depend>rclcpp</build_depend>  <build_depend>std_msgs</build_depend>  <!-- 运行依赖 -->  <exec_depend>rclcpp</exec_depend>  <exec_depend>std_msgs</exec_depend>  <!-- 其他配置(可选) -->  <!-- 例如,测试依赖、导出信息等 -->  
</package>

第六 构建包

在你的工作空间根目录下,运行以下命令来构建你的包:

cd ~/dev_ws
colcon build

这将会编译my_talker_listener包以及它的所有依赖项。

第七 设置环境

在运行任何ROS 2节点之前,你需要设置你的工作空间的环境变量。这可以通过在你的shell中运行以下命令来完成:

. install/setup.bash

注意:如果你使用的是zsh或其他shell,可能需要使用. install/setup.zsh或其他相应的命令。

第八 运行节点

现在,你可以同时打开两个终端窗口来分别运行talkerlistener节点。

第一个终端窗口(运行talker节点):

ros2 run my_talker_listener talker

第二个终端窗口(运行listener节点):

ros2 run my_talker_listener listener

你应该在listener节点的终端窗口中看到类似“I heard: ‘Hello, world! x’”的消息,其中x是一个递增的数字,表示消息被接收的次数。同时,talker节点的终端窗口会显示它正在发布的消息。

第九 清理和重新构建

如果你对代码进行了修改并希望重新构建你的包,你可以首先清理旧的构建文件,然后重新构建。

在你的工作空间根目录下,运行以下命令来清理旧的构建文件:

colcon clean --packages-select my_talker_listener

然后,再次运行构建命令:

colcon build --packages-select my_talker_listener

这样,你就可以继续开发和测试你的ROS 2节点了。

这篇关于ROS 2(Robot Operating System 2)示例项目代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108819

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队