使用Visual Studio Code 运行ROS
Posted ʚVVcatɞ
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Visual Studio Code 运行ROS相关的知识,希望对你有一定的参考价值。
学习目标:
Visual Studio Code 运行ROS
环境:
- ubuntu:18.04.5 LTS
- VMware:15.5.0
- Visual Studio Code:1.59.0
- ROS:melodic
- Python:3.6.9
- gcc:7.5.0
Visual Studio Code下载:https://code.visualstudio.com/docs?start=true
Visual Studio Code 历史版本下载链接: https://code.visualstudio.com/updates
操作步骤:
ROS中的程序即使使用不同的编程语言,实现流程大致如下:
- 创建工作空间
- 编译工作空间
- 创建ROS功能包
- 进入ROS包的src目录编辑源文件
- 编辑功能包下的Cmakelist.txt文件
- 进入工作空间目录并编译(ROS版本为melodic,Python无需编译)
- 配置环境变量
- 启动ROS Master 和 执行编写的源文件
Visual Studio Code下载
进入Visual Studio Code官方找到 Download 的点击进行下载。
由于使用的操作系统格式ubuntu,选择 .deb 64bit 进行下载。
以下是下载完以后在电脑本地的安装包。
Visual Studio Code安装与卸载
安装
方式1:双击安装即可(或右击选择安装)
方式2:sudo dpkg -i xxxx.deb
sudo dpkg -i code_1.59.0-1628120042_amd64.deb
把Visual Studio Code添加到收藏夹
Show Applications → 搜索 Visual Studio Code → 右击选择 Add to Favorites
以下为启动 Visual Studio Code,看到的界面。
卸载
使用以下指令卸载 Visual Studio Code
sudo dpkg --purge code
集成 ROS 插件
使用 VScode 开发 ROS 程序,需要先安装一些插件,常用插件如下:
- Python
- C/C++
- CMake Tools
- ROS
打开插件插件库,安装第三方插件。
通过搜索框搜索 CMake Tools和ROS插件。
安装完成后,加载的插件有以下几个,就算安装成功了。
使用步骤
4.vscode 使用_基本配置
创建 ROS 工作空间
格式:
mkdir -p xxx_ws/src(必须得有 src)
例如:
mkdir -p day02_ws/src
创建成功后,会在Home目录下生成 day02_ws 工作空间
进入刚创建的工作空间
cd ~/day02_ws
编译工作空间
catkin_make
启动 vscode打开工作空间
cd ~/day02_ws
创建完工作空间后,要使用vscode打开工作空间,使用以下命令。
code .
在 vscode 中可以看到,工作空间下有以下文件
- .vscode
- build:编译空间
- devel:开发空间
- src:代码空间
- .catkin_workspace
使用vscode 编译 ros
在vscode中设置快捷键编译的方法如下:
先使用快捷键 ctrl + shift + B 调用编译选项配置
选择: catkin_make:build
可以点击配置设置为默认,修改 .vscode/tasks.json 文件
以下为vscode添加的默认配置。
如果需要设置快捷键编译,把 .vscode/tasks.json 文件的内容全部替换为以下内容:
{
// 有关 tasks.json 格式的文档,请参见
// https://go.microsoft.com/fwlink/?LinkId=733558
"version": "2.0.0",
"tasks": [
{
"label": "catkin_make:debug", //代表提示的描述性信息
"type": "shell", //可以选择shell或者process,如果是shell代码是在shell里面运行一个命令,如果是process代表作为一个进程来运行
"command": "catkin_make",//这个是我们需要运行的命令
"args": [],//如果需要在命令后面加一些后缀,可以写在这里,比如-DCATKIN_WHITELIST_PACKAGES=“pac1;pac2”
"group": {"kind":"build","isDefault":true},
"presentation": {
"reveal": "always"//可选always或者silence,代表是否输出信息
},
"problemMatcher": "$msCompile"
}
]
}
创建 ROS 功能包
选定 src 右击 —> create catkin package
设置包名
hello_world_c
设置完包名后,按下回车,需要继续设置依赖
添加依赖
roscpp rospy std_msgs
依赖添加成功后,会自动生成 hello_world_c 功能包所需要的相关文件。
注意:使用快捷键 ctrl + shift + B 调用编译,可以验证加入的依赖是否正确。
C++ 实现
在功能包的 src 下新建 cpp 文件
以下为hello_ros_c.cpp文件内容
/*
控制台输出 Hello ROS !!!
*/
#include "ros/ros.h"
int main(int argc, char *argv[])
{
setlocale(LC_ALL,""); // 防止输出日志乱码
//执行节点初始化
ros::init(argc,argv,"HelloVSCode");
//输出日志
ROS_INFO("Hello ROS !!!");
return 0;
}
注:: main 函数的参数不可以被 const 修饰
python 实现
在 功能包 下新建 scripts 文件夹,添加 python 文件,并添加可执行权限
以下为hello_ros_p.py文件内容
#-*- coding: UTF-8 -*-
#! /usr/bin/env python
##指定解释器
# 1.导包
import rospy
#2.编写主入口
if __name__ == "__main__":
# 3.初始化 ROS 节点
rospy.init_node("hello_world")
# 4.输出日志
rospy.loginfo("你好 Python ....")
选择Open in Integrated Terminal (在集成终端中打开)。
给所有的Python文件加上可执行权限
chmod +x *.py
通过以下命令查看Python文件的权限
ls -l
配置 CMakeLists.txt
C++ 配置格式:
add_executable(节点名称
src/C++源文件名.cpp
)
target_link_libraries(节点名称
${catkin_LIBRARIES}
)
配置如下:
add_executable(hello_ros_c
src/hello_ros_c.cpp
)
target_link_libraries(hello_ros_c
${catkin_LIBRARIES}
)
Python 配置格式:
Python 配置:
catkin_install_python(PROGRAMS scripts/自定义文件名.py
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)
配置如下:
catkin_install_python(PROGRAMS
scripts/hello_ros_p.py
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)
配置完成后,使用快捷键 ctrl + shift + B 编译
执行ROS功能包
打开vscode自带的终端启动编写好的ros项目,可以在vscode中打开多个终端,执行以下命令。
roscore
配置环境变量
source ./devel/setup.bash
使用C++在控制台输出 Hello ROS !!!
rosrun hello_world_c hello_ros_c
使用Python在控制台输出 你好 Python
rosrun hello_world_c hello_ros_p.py
添加launch文件启动ROS节点
创建launch文件
在launch文件配置以下信息
<launch>
<node pkg="hello_world_c" type="hello_ros_c" name="hello" output="screen" />
<node pkg="hello_world_c" type="hello_ros_c" name="hello" output="screen" />
</launch>
设置环境变量
source ~/工作空间名/devel/setup.bash
使用以下命令启动launch文件
roslaunch hello_world_c start_turtle.launch
roslaunch 功能包名 自定义launch文件名.launch
launch文件的使用:https://blog.csdn.net/qq_44989881/article/details/118607995
踩坑
注意1.
:当使用C++编写的ROS__INFO 终端输出有中文时,会出现乱码
INFO: ???
解决办法:在函数开头加入下面代码的任意一句
setlocale(LC_CTYPE, "zh_CN.utf8");
setlocale(LC_ALL, "");
当使用Python编写的loginfo终端输出有中文时,会出现以下错误
SyntaxError: Non-ASCII character ‘\\xe7’ in file /home/vvcat/day02_ws/src/hello_world_c/scripts /hello_ros_p.py on line 4, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details
解决办法:在Python文件的开头加上以下代码
#-*- coding: UTF-8 -*-
注意2.
:如果在编写c++代码没有代码提示
需要修改 .vscode/c_cpp_properties.json 文件。
我的.vscode/c_cpp_properties.json文件如下
{
"configurations": [
{
"browse": {
"databaseFilename": "",
"limitSymbolsToIncludedHeaders": true
},
"includePath": [
"/home/vvcat/catkin_ws/devel/include/**",
"/opt/ros/melodic/include/**",
"/home/vvcat/catkin_ws/src/test_pkg/include/**",
"/usr/include/**"
],
"name": "ROS",
}
],
"version": 4
}
在 “name”: “ROS”,后面添加了
"intelliSenseMode": "gcc-x64",
"compilerPath": "/usr/bin/gcc",
"cStandard": "gnu17",
"cppStandard": "c++17"
添加后成功解决代码提示问题。
注:除了 “name”: “ROS” 后面添加几条内容,其它地方无需修改。
修改完后的.vscode/c_cpp_properties.json文件如下:
{
"configurations": [
{
"browse": {
"databaseFilename": "",
"limitSymbolsToIncludedHeaders": true
},
"includePath": [
"/home/vvcat/catkin_ws/devel/include/**",
"/opt/ros/melodic/include/**",
"/home/vvcat/catkin_ws/src/test_pkg/include/**",
"/usr/include/**"
],
"name": "ROS",
"intelliSenseMode": "gcc-x64",
"compilerPath": "/usr/bin/gcc",
"cStandard": "gnu17",
"cppStandard": "c++17"
}
],
"version": 4
}
注意3.
:
如果抛出异常: /usr/bin/env: “python”: 没有那个文件或目录
解决1:Linux中在代码的第一行解释器声明,可以使用绝对路径定位到 python3 的安装路径
#! /usr/bin/python3
或
# !/usr/bin/python
解决2: 创建一个链接符号到 python 命令:
sudo ln -s /usr/bin/python3 /usr/bin/python
解决3:
在 CMakeLists.txt 文件下 添加以下内容
catkin_install_python(PROGRAMS
scripts/自定义文件名.py
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
)
总结
编译: ctrl + shift + B
执行: 和之前一致,只是可以在 VScode 中添加终端,首先执行:
source ./devel/setup.bash
使用其它开发工具集成ROS插件:http://wiki.ros.org/IDEs
以上是关于使用Visual Studio Code 运行ROS的主要内容,如果未能解决你的问题,请参考以下文章