ROS实践12 自定义源文件并调用

运行环境:

ubuntu20.04 noetic
宏基暗影骑士笔记本

思路:

上一期:类和函数:
头文件 声明
可执行文件 定义

本期:类和函数:
头文件 声明
源文件 定义
可执行文件 调用

添加include路径
新建c++库
链接c++库和ros库
链接可执行文件和新建c++库

原理:

头文件将源文件和可执行文件链接起来

1.1 头文件编写

1)在功能包下的 include/功能包名 目录下新建头文件 hello.h
2)配置 includepath 详情见上期

#ifndef _HAHA_H
#define _HAHA_H

namespace hello_ns {

class My {

public:
    void run();

};

}

#endif

1.2 编写源文件

1)在 src 目录下新建文件:haha.cpp

#include "demo01_pub/haha.h"
#include "ros/ros.h"

namespace hello_ns{

void My::run(){
    ROS_INFO("hello,head and src ...");
}

}

1.3 编写可执行文件

1)在 src 目录下新建文件 use_head.cpp
#include " 功能包/.h "

#include "ros/ros.h"
#include "demo01_pub/haha.h"

int main(int argc, char *argv[])
{
    ros::init(argc,argv,"hahah");
    hello_ns::My my;
    my.run();
    return 0;
}

1.4 🏯配置文件🏯

配置CMakeLists.txt文件

添加include路径
新建c++库
链接c++库和ros库

# 添加inlude路径
include_directories(
include
  ${catkin_INCLUDE_DIRS}
)

# 新建名为head的c++,将头文件和源文件添加到库中
add_library(head
  include/demo01_pub/haha.h
  src/haha.cpp
)

# 链接c++库和ros库
target_link_libraries(head
  ${catkin_LIBRARIES}
)

可执行文件配置:链接可执行文件和新建c++库

add_executable(use_head.cpp src/use_head.cpp)

target_link_libraries(use_head.cpp
  head
  ${catkin_LIBRARIES}
)

1.5 编译运行

# 编译
ctrl+shift+B

# 运行
roscore
source ./devel/setup.bash
rosrun demo01_pub use_head.cpp

在这里插入图片描述


⭐⭐⭐ 嘟嘟崽 ⭐⭐⭐
⭐⭐⭐ 祝你成功 ⭐⭐⭐
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ROS 中,我们可以使用自定义的消息类型来传递任何我们想要的数据。下面是一个简单的示例,展示了如何在 C++自定义消息类型,并在节点之间传递该消息。 1. 创建消息 首先,我们需要创建一个新的消息类型。我们可以使用 ROS 中的 `genmsg` 工具来自动生成消息类型的代码。假设我们想要创建一个名为 `MyMessage` 的消息类型,可以按照以下步骤操作: 1. 在 ROS 包的 `msg` 目录下创建一个名为 `MyMessage.msg` 的文件,其中包含消息类型的定义。例如: ``` string name int32 age ``` 这个消息类型包含两个字段,一个字符串类型的 `name` 字段和一个整数类型的 `age` 字段。 2. 在 ROS 包的 `CMakeLists.txt` 文件中添加以下内容,以生成消息类型的代码: ``` add_message_files( FILES MyMessage.msg ) generate_messages( DEPENDENCIES std_msgs ) ``` `add_message_files` 函数告诉 ROS 构建系统要生成哪些消息类型的代码。`generate_messages` 函数则实际执行代码生成操作。 3. 在 ROS 包的 `package.xml` 文件中添加以下内容,以声明该包依赖的消息类型: ``` <build_depend>message_generation</build_depend> <exec_depend>message_runtime</exec_depend> ``` `message_generation` 是用于代码生成的依赖,`message_runtime` 是用于运行时的依赖。 2. 编写发布者节点 现在我们可以编写一个发布者节点,用于向某个话题发布 `MyMessage` 类型的消息。假设我们想要向 `my_topic` 话题发布一个名为 `Alice`,年龄为 `25` 的消息,可以按照以下步骤操作: 1. 在 ROS 包的 `src` 目录下创建一个名为 `publisher.cpp` 的 C++ 文件。 2. 在 `publisher.cpp` 中添加以下代码: ```cpp #include <ros/ros.h> #include <my_package/MyMessage.h> int main(int argc, char **argv) { ros::init(argc, argv, "my_publisher"); ros::NodeHandle nh; ros::Publisher pub = nh.advertise<my_package::MyMessage>("my_topic", 10); my_package::MyMessage msg; msg.name = "Alice"; msg.age = 25; ros::Rate rate(10); while (ros::ok()) { pub.publish(msg); rate.sleep(); } return 0; } ``` 在这段代码中,我们首先包含了 ROSC++ API 和我们自定义的消息类型头文件。然后,我们初始化了一个 ROS 节点,并创建了一个 `my_package::MyMessage` 类型的发布者。我们创建了一个名为 `msg` 的消息,并将 `name` 和 `age` 字段设置为 `Alice` 和 `25`。最后,我们使用 `publish` 函数将该消息发布到 `my_topic` 话题中。 3. 编写订阅者节点 现在我们可以编写一个订阅者节点,用于接收 `MyMessage` 类型的消息。假设我们想要接收 `my_topic` 话题发布的消息,并将消息的内容打印到终端上,可以按照以下步骤操作: 1. 在 ROS 包的 `src` 目录下创建一个名为 `subscriber.cpp` 的 C++ 文件。 2. 在 `subscriber.cpp` 中添加以下代码: ```cpp #include <ros/ros.h> #include <my_package/MyMessage.h> void callback(const my_package::MyMessage::ConstPtr& msg) { ROS_INFO("Received a message: name = %s, age = %d", msg->name.c_str(), msg->age); } int main(int argc, char **argv) { ros::init(argc, argv, "my_subscriber"); ros::NodeHandle nh; ros::Subscriber sub = nh.subscribe("my_topic", 10, callback); ros::spin(); return 0; } ``` 在这段代码中,我们首先包含了 ROSC++ API 和我们自定义的消息类型头文件。然后,我们定义了一个回调函数 `callback`,该函数会在每次接收到一条消息时被调用。在回调函数中,我们使用 `ROS_INFO` 函数将消息的内容打印到终端上。最后,我们初始化了一个 ROS 节点,并创建了一个 `my_package::MyMessage` 类型的订阅者。我们使用 `subscribe` 函数订阅 `my_topic` 话题,并将回调函数 `callback` 注册为该订阅者的回调函数。最后,我们使用 `ros::spin` 函数让 ROS 节点保持运行状态。 3. 构建和运行节点 现在我们可以构建和运行这两个节点了。假设我们的 ROS 包名为 `my_package`,可以按照以下步骤操作: 1. 在 ROS 包的根目录下执行以下命令,以构建该包: ``` catkin_make ``` 2. 在一个终端窗口中执行以下命令,以运行发布者节点: ``` rosrun my_package publisher ``` 3. 在另一个终端窗口中执行以下命令,以运行订阅者节点: ``` rosrun my_package subscriber ``` 现在你应该能够在订阅者节点的终端窗口中看到类似以下的输出: ``` [ INFO] [1234567890.123456789]: Received a message: name = Alice, age = 25 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

圆嘟嘟2019

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值