教程网址:http://wiki.ros.org/cn/ROS/Tutorials。
本博客为10-16小节。
Header header
string child_frame_id
geometry_msgs/PoseWithCovariance pose
geometry_msgs/TwistWithCovariance twist
srv文件分为请求和响应两部分,由’—’分隔。
int64 A
int64 B
---
int64 Sum
其中 A 和 B 是请求, 而Sum 是响应。
创建完.msg文件后,为了确保msg文件被转换成为C++、Python和其他语言的源代码,package.xml要包含一下两条语句:
<build_depend>message_generationbuild_depend>
<run_depend>message_runtimerun_depend>
然后在 CMakeLists.txt文件中,利用find_packag函数,增加对message_generation的依赖,这样就可以生成消息了。
# Do not just add this line to your CMakeLists.txt, modify the existing line
find_package(catkin REQUIRED COMPONENTS roscpp rospy std_msgs message_generation)
同样,你需要确保你设置了运行依赖:
catkin_package(
...
CATKIN_DEPENDS message_runtime ...
...)
并且,找到如下代码块:
# add_message_files(
# FILES
# Message1.msg
# Message2.msg
# )
去掉注释符号#,用你的.msg文件替代Message*.msg。
最后,我们要确保CMake知道在什么时候重新配置我们的project。 确保添加了如下代码:
generate_messages()
通过rosmsg show命令,检查ROS是否能够识消息。
$ rosmsg show [message type]
从其他的package中复制一个服务:
$ roscp [package_name] [file_to_copy_path] [copy_path]
同msg文件类似,你也需要在package.xml和CMakeLists.txt文件中做一些修改。
同样可以通过rosmsg show命令,检查ROS是否能够识该服务。
$ rossrv show
在CMakeLists.txt中找到如下部分:
# generate_messages(
# DEPENDENCIES
# # std_msgs # Or other packages containing msgs
# )
去掉注释并附加上所有你消息文件所依赖的那些含有.msg文件的package(这个例子是依赖std_msgs,不要添加roscpp,rospy),结果如下:
generate_messages(
DEPENDENCIES
std_msgs
)
重新编译我们的package。所有在msg路径下的.msg文件都将转换为ROS所支持语言的源代码。生成的C++头文件将会放置在~/catkin_ws/devel/include/beginner_tutorials/
。 Python脚本语言会在 ~/catkin_ws/devel/lib/python2.7/dist-packages/beginner_tutorials/msg
目录下创建。
$ rosmsg -h
同样也可以获得子命令的帮助:
$ rosmsg show -h
mkdir -p ~/catkin_ws/src/beginner_tutorials/src
这个文件夹将会用来放置 beginner_tutorials package 的所有源代码。
修改CMakeLists.txt文件,添加:
include_directories(include ${catkin_INCLUDE_DIRS})
add_executable(talker src/talker.cpp)
target_link_libraries(talker ${catkin_LIBRARIES})
add_executable(listener src/listener.cpp)
target_link_libraries(listener ${catkin_LIBRARIES})
这会生成两个可执行文件, talker 和 listener, 默认存储在~/catkin_ws/devel/lib/ 中.
然后要为可执行文件添加对生成的消息文件的依赖:
add_dependencies(talker beginner_tutorials_generate_messages_cpp)
这样就可以确保自定义消息的头文件在被使用之前已经被生成。
运行catkin_make
。
create a ‘scripts’ folder to store our Python scripts:mkdir scripts && cd scripts
编写.py并改变其为可执行文件:$ chmod +x talker.py
类似
Go to your catkin workspace and run catkin_make
:
运行roscore
。
如果使用catkin,确保你在调用catkin_make后,在运行你自己的程序前,已经source了catkin工作空间下的setup.sh文件
启动a publisher called “talker”:
$ rosrun beginner_tutorials talker (C++)
$ rosrun beginner_tutorials talker.py (Python)
运行一个名为”listener”的订阅器节点:
$ rosrun beginner_tutorials listener (C++)
$ rosrun beginner_tutorials listener.py (Python)
CMakeLists.txt添加如下代码:
add_executable(add_two_ints_server src/add_two_ints_server.cpp)
target_link_libraries(add_two_ints_server ${catkin_LIBRARIES})
add_dependencies(add_two_ints_server beginner_tutorials_gencpp)
add_executable(add_two_ints_client src/add_two_ints_client.cpp)
target_link_libraries(add_two_ints_client ${catkin_LIBRARIES})
add_dependencies(add_two_ints_client beginner_tutorials_gencpp)
然后运行catkin_make
命令将生成两个可执行程序”add_two_ints_server”和”add_two_ints_client”,这两个可执行程序默认被放在~/catkin_ws/devel/lib/share/。你可以直接调用可执行程序,或者使用rosrun命令去调用它们。
Don’t forget to make the node executable:
chmod +x scripts/add_two_ints_server.py
run catkin_make
In a new terminal, run
$ cd ~/catkin_ws
$ . devel/setup.bash
$ rosrun beginner_tutorials add_two_ints_server.py
In a new terminal, run
$ cd ~/catkin_ws
$ . devel/setup.bash
$ rosrun beginner_tutorials add_two_ints_client.py 4 5
## 测试简单的Service和Client
### 运行Service
$ rosrun beginner_tutorials add_two_ints_server (C++)
$ rosrun beginner_tutorials add_two_ints_server.py (Python)
### 运行Client
$ rosrun beginner_tutorials add_two_ints_client 1 3 (C++)
$ rosrun beginner_tutorials add_two_ints_client.py 1 3 (Python)