Launch启动文件的使用方法

2023-05-16

Launch启动文件的使用方法

  • 案例一:运行两个节点
  • 案例二:加载参数与命名空间
  • 案例三:小海龟跟随的launch启动方法
  • 案例四:remap修改节点名

Launch文件可以通过XML文件实现多节点的配置和启动,省去了启动多个终端与多个节点的复杂操作,同时launch文件也不用进行roscore

案例一:运行两个节点

在工作空间src文件夹内新建一个learning_launch功能包

catkin_creat_pkg learning_launch

touch一个simple.launch文件,打开文件在设置-高亮可以更改为xml语法高亮

<launch>
    <node pkg="learning_topic" type="person_subscriber" name="talker" output="screen" />
    <node pkg="learning_topic" type="person_publisher" name="listener" output="screen" /> 
</launch>

<!-- <launch>和</launch>为launch根标签,分别代表开始和结束 -->
<!-- <node pkg=" " type=" " name=" " output=" " /> 为node标签,作用是开启一个节点,pkg为节点所在功能包名称,type为节点的可执行文件名称,name为节点执行后运行时的名称
     output是将日志信息打印到终端 -->

catkin_make编译
roslaunch learning_launch simple.launch运行

案例二:加载参数与命名空间

在这里插入图片描述

<launch>
<!-- <param name=" "  value=" " /> 将名为name,值为value的参数加载到参数服务器中-->
    <param name="/turtle_number"   value="2"/>

    <node pkg="turtlesim" type="turtlesim_node" name="turtlesim_node">
		<param name="turtle_name1"   value="Tom"  />
		<param name="turtle_name2"   value="Jerry"/>
<!-- <rosparam file="$(find 功能包名)/功能包下的文件夹名/文件夹下的yaml文件" command="load"/> 将这个yaml文件整个加载到参数服务器中-->
		<rosparam file="$(find learning_launch)/config/param.yaml" command="load"/>
    </node>

    <node pkg="turtlesim" type="turtle_teleop_key" name="turtle_teleop_key" output="screen"/>


</launch>

<!-- <launch>和</launch>为launch根标签,分别代表开始和结束 -->
<!-- <node pkg=" " type=" " name=" " output=" " /> 为node标签,作用是开启一个节点,pkg为节点所在功能包名称,type为节点的可执行文件名称,name为节点执行后运行时的名称 -->

在这里插入图片描述注意在运行前,要在功能包内创建config文件夹,并创建param.yaml文件,内容如下,group加缩进也为命名空间
在这里插入图片描述

案例三:小海龟跟随的launch启动方法

小海龟跟随见上节ROS中的坐标系管理系统
运行c++文件

 <launch>

    <!-- Turtlesim Node-->
    <node pkg="turtlesim" type="turtlesim_node" name="sim"/>
    <node pkg="turtlesim" type="turtle_teleop_key" name="teleop" output="screen"/>

    <node pkg="learning_tf" type="turtle_tf_broadcaster" args="/turtle1" name="turtle1_tf_broadcaster" />
    <node pkg="learning_tf" type="turtle_tf_broadcaster" args="/turtle2" name="turtle2_tf_broadcaster" />

    <node pkg="learning_tf" type="turtle_tf_listener" name="listener" />

  </launch>


运行python文件,type中加.py

<launch>

	<!-- Turtlesim Node-->
	<node pkg="turtlesim" type="turtlesim_node" name="sim"/>
	<node pkg="turtlesim" type="turtle_teleop_key" name="teleop" output="screen"/>

	<node name="turtle1_tf_broadcaster" pkg="learning_tf" type="turtle_tf_broadcaster.py">
	  <param name="turtle" type="string" value="turtle1" />
	</node>
	<node name="turtle2_tf_broadcaster" pkg="learning_tf" type="turtle_tf_broadcaster.py">
	  <param name="turtle" type="string" value="turtle2" /> 
	</node>

    <node pkg="learning_tf" type="turtle_tf_listener.py" name="listener" />

</launch>

案例四:remap修改节点名

<launch>
<!-- 先包含learning_launch/launch/simple.launch头文件 -->
    <include file="$(find learning_launch)/launch/simple.launch" />

    <node pkg="turtlesim" type="turtlesim_node" name="turtlesim_node">
<!-- 启动后把from原命名改为to新命名 -->
		<remap from="/turtle1/cmd_vel" to="/cmd_vel"/>
    </node>

</launch>


roslaunch learning_launch turtlesim_remap.launch
重新打开终端输入rostopic list查看当前话题
在这里插入图片描述
之前的/turtle1/cmd_vel已经改为/cmd_vel,可以用这个话题名发布速度指令
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Launch启动文件的使用方法 的相关文章

随机推荐