ROS入门3.2(实例1)

本文围绕ROS的topic_demo实例展开,给出了talker.cpp、listener.cpp的代码,实现消息的发布与订阅,还展示了CmakeLists.txt和package.xml的配置内容,帮助开发者了解在ROS中如何进行消息通信及项目配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实例:topic_demo

在这里插入图片描述在这里插入图片描述3.talker.cpp

//ROS头文件
#include <ros/ros.h>
//自定义msg产生的头文件
#include <topic_demo/gps.h>

int main(int argc, char **argv)
{
//用于解析ROS参数,第三个参数为本节点名
ros::init(argc, argv, “talker”);

//实例化句柄,初始化node
ros::NodeHandle nh;

//自定义gps msg
topic_demo::gps msg;
msg.x = 1.0;
msg.y = 1.0;
msg.state = “working”;

//创建publisher
ros::Publisher pub = nh.advertise<topic_demo::gps>(“gps_info”, 1);

//定义发布的频率
ros::Rate loop_rate(1.0);
//循环发布msg
while (ros::ok())
{
//以指数增长,每隔1秒更新一次
msg.x = 1.03 * msg.x ;
msg.y = 1.01 * msg.y;
ROS_INFO("Talker: GPS: x = %f, y = %f ", msg.x ,msg.y);
//以1Hz的频率发布msg
pub.publish(msg);
//根据前面定义的频率, sleep 1s
loop_rate.sleep();//根据前面的定义的loop_rate,设置1s的暂停
}

return 0;
}
4.listener.cpp

//ROS头文件
#include <ros/ros.h>
//包含自定义msg产生的头文件
#include <topic_demo/gps.h>
//ROS标准msg头文件
#include <std_msgs/Float32.h>

void gpsCallback(const topic_demo::gps::ConstPtr &msg)
{
//计算离原点(0,0)的距离
std_msgs::Float32 distance;
distance.data = sqrt(pow(msg->x,2)+pow(msg->y,2));
//float distance = sqrt(pow(msg->x,2)+pow(msg->y,2));
ROS_INFO(“Listener: Distance to origin = %f, state: %s”,distance.data,msg->state.c_str());
}

int main(int argc, char **argv)
{
ros::init(argc, argv, “listener”);
ros::NodeHandle n;
ros::Subscriber sub = n.subscribe(“gps_info”, 1, gpsCallback);
//ros::spin()用于调用所有可触发的回调函数。将进入循环,不会返回,类似于在循环里反复调用ros::spinOnce()。
ros::spin();
return 0;
}
5.CmakeLists.txt

cmake_minimum_required(VERSION 2.8.3)
project(topic_demo)

find_package(catkin REQUIRED COMPONENTS
message_generation
roscpp
rospy
std_msgs
)
add_message_files(
FILES
gps.msg
)

generate_messages(
DEPENDENCIES
std_msgs
)

catkin_package(

CATKIN_DEPENDS roscpp rospy std_msgs message_runtime

include_directories(
include
${catkin_INCLUDE_DIRS}
)

add_executable(talker src/talker.cpp )
#必须添加add_dependencies,否则找不到自定义的msg产生的头文件
add_dependencies(talker topic_demo_generate_messages_cpp)
target_link_libraries(talker ${catkin_LIBRARIES})

add_executable(listener src/listener.cpp )
add_dependencies(listener topic_demo_generate_messages_cpp)
target_link_libraries(listener ${catkin_LIBRARIES})

package.xml

<?xml version="1.0"?> topic_demo 0.0.0 The publish_subscribe_demo package

davidhan

BSD

<buildtool_depend>catkin</buildtool_depend>
<build_depend>message_generation</build_depend>
<build_depend>roscpp</build_depend>
<build_depend>rospy</build_depend>
<build_depend>std_msgs</build_depend>
<run_depend>roscpp</run_depend>
<run_depend>rospy</run_depend>
<run_depend>std_msgs</run_depend>
<run_depend>message_runtime</run_depend>

ROS(Robot Operating System)是一种用于构建机器人应用程序的开源框架,它提供了一系列工具、库和约定,用于简化机器人软件开发和集成。下面我将以一个简单实例来介绍ROS入门使用。 假设我们要编写一个控制机器人移动的程序。首先,我们需要在ROS中创建一个包(package),这可以通过使用指令`catkin_create_pkg package_name`来完成。包的目的是用于组织和管理我们的程序。 然后,我们需要编写一个节点(node),节点是ROS中基本的执行单元,可以理解为一个独立的进程,通过使用指令`roscpp_create_pkg node_name`来创建节点。节点是用于执行我们的具体任务,比如控制机器人移动、接收传感器数据等。 接下来,我们需要定义并发布一个移动指令的主题(topic),通过使用指令`rostopic pub topic_name message_type data`来发布主题。主题是一种在ROS中用于节点之间通信的机制,我们可以通过发布主题来传递控制指令。 最后,我们需要编写一个订阅主题的节点,来实现对移动指令的接收和执行。这个节点将订阅我们在上一步中发布的移动指令主题,一旦接收到指令,就会执行相应的动作。 通过以上的步骤,我们就可以完成一个简单ROS实例,用于控制机器人的移动。当然,这只是一个入门级的例子,实际中ROS有更复杂的功能和应用场景,比如SLAM(Simultaneous Localization and Mapping)、路径规划等。希望这个例子能帮助你快速入门ROS,更多的学习和实践可以让你更加熟练地使用ROS来构建各种机器人应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值