博客参考:https://blog.csdn.net/cocoiehl/article/details/83351307 和 https://blog.csdn.net/weixin_38294178/article/details/78844744
ROS2官方安装引导: https://index.ros.org/doc/ros2/Installation/Crystal/Windows-Install-Binary/
TIPS: 设置choco后续软件的安装位置,可以设置环境变量ChocolateyInstall,变量值为安装路径即可。
首先创建桌面命令行快捷方式 -- 桌面右键新建一个快捷方式
C:\Windows\System32\cmd.exe /k "C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\Common7\Tools\VsDevCmd.bat" -arch=amd64 -host_arch=amd64
右键快捷方式,选择高级选项,设置管理员权限运行
1. 安装Chocolatey
管理员权限打开命令行窗口,输入如下指令即可完成Chocolatey的安装,安装目录为 C:\ProgramData\chocolatey\bin\chocolatey.exe
@"%SystemRoot%\System32\WindowsPowerShell\v1.0\powershell.exe" -NoProfile -InputFormat None -ExecutionPolicy Bypass -Command "iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))" && SET "PATH=%PATH%;%ALLUSERSPROFILE%\chocolatey\bin"
指令会将Chocolatey所在的安装目录设置为全局路径(C:\ProgramData\chocolatey\bin),所以命令行输入chocolatey 或者 choco -?会有相应的打印信息
2. Chocolatey 安装python
choco install python
3. 安装OpenSSL
Download an OpenSSL installer from this page. Scroll to the bottom of the page and download Win64 OpenSSL v1.0.2.不要下载Win32 or Light versions. 安装好之后,设置换进变量信息
setx -m OPENSSL_CONF C:\OpenSSL-Win64\bin\openssl.cfg
Path中添加OpenSSL路径信息
C:\OpenSSL-Win64\bin\
4. 安装 Visual Studio
1. 安装 VS2015, 如果使用Ardent or earlier
2. 安装VS2017, 如果使用Bouncy or a nightly
Warning
Visual Studio 2017 v15.8 seems to have a compiler bug preventing from building some ROS 2 packages. Please try installing an older version of Visual Studio 2017.
Microsoft provides a free of charge version of Visual Studio 2017, named Community, which can be used to build applications that use ROS 2:
https://visualstudio.microsoft.com/downloads/
Make sure that the Visual C++ features are installed. An easy way to make sure they’re installed is to select the Desktop development with C++ workflow during the install.
5. 安装DDS Implementations
ROS 2 builds on top of DDS. It is compatible with multiple DDS or RTPS (the DDS wire protocol) vendors.
The package you downloaded has been built with optional support for multiple vendors: eProsima FastRTPS, Adlink OpenSplice, and (as of ROS 2 Bouncy) RTI Connext as the middleware options. Run-time support for eProsima’s Fast RTPS is included bundled by default. If you would like to use one of the other vendors you will need to install their software separately.
If you want to use OpenSplice, you will need to download the latest supported version. * For ROS 2 Crystal version 6.9.181126OSS-HDE-x86_64.win-vs2017 or later is required. * For ROS 2 Bouncy version 6.7.180404OSS-HDE-x86_64.win-vs2017 or later is required.
Download the latest supported version For ROS 2 releases up to and including Ardent, extract it but do not do anything else at this point. For ROS 2 releases later than Ardent, set the OSPL_HOME
environment variable to the unpacked directory that contains the release.bat
script.
To use RTI Connext DDS there are options available for university, purchase or evaluation
After installing, run RTI launcher and point it to your license file.
Set the NDDSHOME
environment variable:
set "NDDSHOME=C:\Program Files\rti_connext_dds-5.3.1"
RTI Connext需要注册账号,之后会将注册使用的License发到邮箱,按照邮箱的Instruction安装即可或者https://www.rti.com/free-trial/dds-files。
下载完成解压之后,得到如下文件
6. 安装OpenCV
Some of the examples require OpenCV to be installed.
You can download a precompiled version of OpenCV 3.4.1 from https://github.com/ros2/ros2/releases/download/opencv-archives/opencv-3.4.1-vc15.VS2017.zip
Assuming you unpacked it to C:\opencv
, type the following on a Command Prompt (requires Admin privileges):
setx -m OpenCV_DIR C:\opencv
Since you are using a precompiled ROS version, we have to tell it where to find the OpenCV libraries. You have to extend the PATH
variable to c:\opencv\x64\vc15\bin
These releases used OpenCV 2. You can download a precompiled version of OpenCV 2.4.13.2 from https://github.com/ros2/ros2/releases/download/release-beta2/opencv-2.4.13.2-vc14.VS2015.zip
Since you are using a precompiled ROS version, we have to tell it where to find the OpenCV libraries. Assuming you were extracting OpenCV to c:\
you have to extend your PATH
variable to
c:\opencv-2.4.13.2-vc14.VS2015\x64\vc14\bin
7. 安装一些依赖
There are a few dependencies not available in the Chocolatey package database. In order to ease the manual installation process, we provide the necessary Chocolatey packages.
As some chocolatey packages rely on it, we start by installing CMake
choco install -y cmake
You will need to append the CMake bin folder C:\Program Files\CMake\bin
to your PATH.
Please download these packages from this GitHub repository.
asio.1.12.1.nupkg
eigen-3.3.4.nupkg
tinyxml-usestl.2.6.2.nupkg
tinyxml2.6.0.0.nupkg
log4cxx.0.10.0.nupkg
Once these packages are downloaded, open an administrative shell and execute the following command:
choco install -y -s
Please replace <PATH\TO\DOWNLOADS>
with the folder you downloaded the packages to.
You must also install some python dependencies for command-line tools:
python -m pip install -U catkin_pkg empy lark-parser opencv-python pyparsing pyyaml setuptools
python -m pip install -U pydot PyQt5
python -m pip install -U lxml
8. 下载ROS2
Go the releases page: https://github.com/ros2/ros2/releases
Download the latest package for Windows, e.g., ros2-package-windows-AMD64.zip
.
Notes:
there may be more than one binary download option which might cause the file name to differ.
[ROS Bouncy only] To download the ROS 2 debug libraries you’ll need to download ros2-bouncy-windows-Debug-AMD64.zip
Unpack the zip file somewhere (we’ll assume C:\dev\ros2
).
9. 设置ROS2运行环境
Start a command shell and source the ROS 2 setup file to set up the workspace:
call C:\dev\ros2\local_setup.bat
For ROS 2 releases up to and including Ardent, if you downloaded a release with OpenSplice support you must additionally source the OpenSplice setup file manually (this is done automatically for ROS 2 releases later than Ardent; this step can be skipped). It is normal that the previous command, if nothing else went wrong, outputs “The system cannot find the path specified.” exactly once. Only do this step after you have sourced the ROS 2 setup file:
call "C:\opensplice69\HDE\x86_64.win64\release.bat"
10. Demo运行测试
In a command shell, set up the ROS 2 environment as described above and then run a talker
:
ros2 run demo_nodes_cpp talker
Start another command shell and run a listener
:
ros2 run demo_nodes_py listener
You should see the talker
saying that it’s Publishing
messages and the listener
saying I heard
those messages. Hooray!
If you have installed support for an optional vendor, see this page for details on how to use that vendor.
If at one point your example would not start because of missing dll’s, please verify that all libraries from external dependencies such as OpenCV are located inside your PATH
variable.
If you forget to call the local_setup.bat
file from your terminal, the demo programs will most likely crash immediately.
If you would like to build your own packages, refer to the tutorial "Using Colcon to build packages".
Questions
1. failed to create process
ros2 run demo_nodes_cpp talker
命令行窗口直接打印
failed to create process.
解决方案参考: https://www.gitmemory.com/issue/ros2/ros2/525/490069329
ros2-script.py the first line (shebang line) demands that the script is run with C:\Python37\Python_d.exe
2. the ordinal 4689 could not be located in the dynamic link library fastrtps-1.7.dll
解决方法:libeay32.dll 和 ssleay32.dll to install\bin (OpenSSL内动态库)
3. 更多问题查询 https://github.com/ros2/ros2/issues
VS2017 编写ROS2 参考博客 https://blog.csdn.net/zwwang2014/article/details/84839579
手机扫一扫
移动阅读更方便
你可能感兴趣的文章