ROS roslaunch 学习

roslaunch 用处:将多个rosnode 结合起来,一起运行。这样就不需要一个个的运行。

roslaunch格式
(add_two.launch)

<launch>
        <arg name="a" default="1" />
        <arg name="b" default="2" />
    <node pkg="beginner_tutorials" name="add_two_ints_server" type="add_two_ints_server"/>
    <node pkg="beginner_tutorials" name="add_two_ints_client" type="add_two_ints_client" args="$(arg a) $(arg b)"/>
    <node name = "stage" pkg="stage_ros" type = "stageros" args="$(find stage_ros)/world/willow-erratic.world"/>
   </launch>

launch文件为xml格式。
每个tag的格式至少包含下面三部分
1.pkg = “your package name”,

2.name = “your name”//一般为可执行文件的名称
可执行文件的名称是robot_cleaner_node

3.type =”可执行文件的名称”,
(即在CMakeList.txt中的add_executable(node_name src/c++file.cpp)中的node_name)
例如:add_executable(robot_cleaner_node src/robot_cleaner_move_rotate.cpp)中的robot_cleaner_node

此处的type是可执行文件的名称,而name则是可以任意给出的,它覆盖了原有文件中ros::init指定的node name。

4.(非必须)args 为运行时的参数
定义参数a,默认值为0,运行时可以重新赋值;
定义参数b,值为2,运行时不能赋值;
若赋值会出现错误:Invalid tag: cannot override arg ‘b’, which has already been set.

args="$(arg a) $(arg b)":a,b作为参数传入节点,运行时可以将a重新赋值,不赋值使用默认值1.

$(find package_name)找到package_name 所在路径
$(find stage_ros)/world/willow-erratic.world" 表示 /opt/ros/indigo/share/stage_ros/world/willow-erratic.world
运行:1.(未定义arg时) roslaunch beginner_tutorials add_two.launch a:=4 b:=5
2.(定义arg后) roslaunch beginner_tutorials add_two.launch 或者roslaunch beginner_tutorials add_two.launch a:=4(只给a赋值,b不需要)

运行之后输出会保存在log文件中:例如log file: /home/server/.ros/log/e907e8c8-9be8-11e6-bf00-74d43562c7a3/add_two_ints_client-2*.log,并不会出现在控制台
要想输出在控制台,添加output属性

<node name = "my_stage" pkg = "my_stage" type = "my_stage"
output = "screen" />

5 若显示所有nodes的输出,用–screen命令行。
$ roslaunch –screen package_name launch_file_name
6

 respawn="true"
eg:<node pkg="turtlesim" name="sim" type="turtlesim_node"  respawn="true"/>
  • 1

代表当我们启动一个node时,roslaunch会监控它,当它关闭时,比如启动turtlesim节点,当我们关闭turtlesim窗口时,roslaunch会重新启动一个新的。

7

required="true"
  • 1

此属性表示当这个节点退出后,roslaunch会关闭所有的节点,并退出。

8让一个节点在单独的终端窗口中启动:
roslaunch 使所有的节点都共用一个终端,要想节点有自己的终端可以使用

launch-prefix="xterm -e"
  • 1

9 命名空间ns

ns="turtlesim1"
  • 1

如果同一个节点使用这个属性可以创建了两个无关的节点。
eg:

<launch>
    <node
    name="turtlesim_node "
    pkg="turtlesim"
    type="turtlesim_node "
    ns="sim1"
    />
    <node
    pkg="turtlesim"
    type="turtle_teleop_key "
    name="teleop_key"
    required="true"
    launch −prefix="xterm −e"
    ns="sim1"
    />
    <node
    name="turtlesim_node "
    pkg="turtlesim"
    type="turtlesim_node "
    ns="sim2"
    />
    <node
    pkg="a gitr "
    type="pubvel"
    name="velocity_publisher "
    ns="sim2"
    />
</launch>
  • 1

10.remap :在launch文件中重新命名:使用 remap 元素
格式:<remap from="original-name" to="new-name" />
如果这个 remap 是 launch 元素的一个child(子类),与 node 元素同一层级, 并在 launch 元素内的最顶层。那么这个 remapping 将会作用于后续所有的节点。
将turtle1/pose 重新命名为tim
使用rosrun 命令rosrun turtlesim turtlesim_node turtle1/pose:=tim
使用roslaunch

 <node pkg="turtlesim" type="turtlesim_node"
        name="turtlesim" >
        <remap from="turtle1/pose" to="tim" />
    </node>
  • 1
  1. including
    这个属性期望我们添加想要包含的文件的完整路径。但是大多数时候,include 元素使用一个 find 命令来搜索一个程序包,代替一个明确的完整路径:
<include file="$(find package-name)/launch-file-name" />
  • 1

roslaunch 命令 将会在程序包(package)的子目录里搜索launch文件。 include 元素必须要指定文件的特定路径,你可以使用 find 来找到这个程序包,但是却不能在这个程序包目录里面自动的找到某个子目录里有launch文件。举例:

这样做是正确的:<include file = "find learning_tutrols"/launch/start_demo.launch" / >

这样做是错误的:<include file = "find learning_tutrols"/start_demo.launch" />
  • 1

include 元素也支持 ns 属性,可以让这个文件里的内容推送到一个命名空间里面:

<include file=". . . " ns="namespace" />
  • 1

一般我们都会给 include 元素设置一个 ns 属性。

12 .param 标签
wiki.ros.org/roslaunch/XML/param
定义了一个参数服务器上的参数,属性有
name : 参数名字
type :参数的类型,”str|int|double|bool”
value:参数的值,除了value还可以使用以下三种
textfile= $(find pkg-name)/path/file.txt,该文件的内容将被读取并存储为一个字符串,此文件必须是本地的,可访问的。所以强烈推荐使用$(find pkg-name) 形式来。避免在另一台机器上找不到文件路径运行失败。
binfile="$(find pkg-name)/path/file"该文件的内容将被读取并存储为Base64编码的XML-RPC二进制对象
command="$(find pkg-name)/exe '$(find pkg-name)/arg.txt'"
parameter server 参数除了上述方法外,可以通过以下方式设置
命令行 rosparam set / rosparam get 设置
代码中
roscpp: ros::param::set / ros::param::get
rospy: set_param / get_param

13.rosparam 标签
wiki.ros.org/roslaunch/XML/rosparam
rosparam :可以使用从rosparam YAML文件加载,删除,dump ,ROS参数服务器参数
rosparam 参数:
command=”load|dump|delete” (optional, default=load)
file=”$(find pkg-name)/path/foo.yaml” (load or dump commands)
param=”param-name”
ns=”namespace” (optional)
subst_value=true|false (optional) 是否允许替换yaml文本中的参数

eg:

<rosparam command="load" file="$(find rosparam)/example.yaml" />//加载文件中的参数
<rosparam command="delete" param="my/param" />//删除参数

<arg name="whitelist" default="[3, 2]"/>
<rosparam param="whitelist" subst_value="True">$(arg whitelist)</rosparam> //替换

<rosparam param="a_list">[1, 2, 3, 4]</rosparam>
<rosparam>
  a: 1
  b: 2
</rosparam>

参考:
blog.csdn.net/fengmengdan/article/details/42984429
blog.csdn.net/github_35160620/article/details/52618271


猜你喜欢

转载自blog.csdn.net/qq_21508727/article/details/80778044
今日推荐