【ROS教程】ROS文件系統和基礎架構

来源:https://www.cnblogs.com/UnderTurrets/p/18384493
-Advertisement-
Play Games

@目錄1.工作空間目錄1.1 package.xml2.啟動節點的方式2.1 一次啟動一個2.2 一次啟動多個3.ROS常用命令3.1 增3.2 查3.3 執行3.3.1 載入環境變數3.3.2 運行節點3.4 查看計算圖4.創建功能包4.1 選擇工作目錄4.2 創建功能包目錄4.3 建立功能包 1 ...


@

目錄


1.工作空間目錄

在這裡插入圖片描述

WorkSpace --- 自定義的工作空間

    |--- build:編譯空間,用於存放CMake和catkin的緩存信息、配置信息和其他中間文件。

    |--- devel:開發空間,用於存放編譯後生成的目標文件,包括頭文件、動態&靜態鏈接庫、可執行文件等。

    |--- src:源碼

        |-- package:功能包(ROS基本單元)包含多個節點、庫與配置文件,包名所有字母小寫,只能由字母、數字與下劃線組成

            |-- CMakeLists.txt:配置編譯規則,比如源文件、依賴項、目標文件

            |-- package.xml:包信息,比如:包名、版本、作者、依賴項...(以前版本是 manifest.xml)

            |-- scripts:存儲python文件

            |-- src:存儲C++源文件

            |-- include:頭文件

            |-- msg:消息通信格式文件

            |-- srv:服務通信格式文件

            |-- action:動作格式文件

            |-- launch:可一次性運行多個節點 

            |-- config:配置信息

            |-- CMakeLists.txt:編譯的基本配置

1.1 package.xml

  • 固定格式
<?xml version="1.0"?>
<!-- 格式: 以前是 1,推薦使用格式 2 -->
<package format="2">
  <!-- 包名 -->
  <name><the name of package></name>
  <!-- 版本 -->
  <version>0.0.0</version>
  <!-- 描述信息 -->
  <description>The <the name of package> package</description>

  <!-- One maintainer tag required, multiple allowed, one person per tag -->
  <!-- Example:  -->
  <!-- <maintainer email="[email protected]">Jane Doe</maintainer> -->
  <!-- 維護人員 -->
  <maintainer email="*">XXX</maintainer>


  <!-- One license tag required, multiple allowed, one license per tag -->
  <!-- Commonly used license strings: -->
  <!--   BSD, MIT, Boost Software License, GPLv2, GPLv3, LGPLv2.1, LGPLv3 -->
  <!-- 許可證信息,ROS核心組件預設 BSD -->
  <license>TODO</license>


  <!-- Url tags are optional, but multiple are allowed, one per tag -->
  <!-- Optional attribute type can be: website, bugtracker, or repository -->
  <!-- Example: -->
  <!-- <url type="website">http://wiki.ros.org/demo01_hello_vscode</url> -->


  <!-- Author tags are optional, multiple are allowed, one per tag -->
  <!-- Authors do not have to be maintainers, but could be -->
  <!-- Example: -->
  <!-- <author email="[email protected]">Jane Doe</author> -->


  <!-- The *depend tags are used to specify dependencies -->
  <!-- Dependencies can be catkin packages or system dependencies -->
  <!-- Examples: -->
  <!-- Use depend as a shortcut for packages that are both build and exec dependencies -->
  <!--   <depend>roscpp</depend> -->
  <!--   Note that this is equivalent to the following: -->
  <!--   <build_depend>roscpp</build_depend> -->
  <!--   <exec_depend>roscpp</exec_depend> -->
  <!-- Use build_depend for packages you need at compile time: -->
  <!--   <build_depend>message_generation</build_depend> -->
  <!-- Use build_export_depend for packages you need in order to build against this package: -->
  <!--   <build_export_depend>message_generation</build_export_depend> -->
  <!-- Use buildtool_depend for build tool packages: -->
  <!--   <buildtool_depend>catkin</buildtool_depend> -->
  <!-- Use exec_depend for packages you need at runtime: -->
  <!--   <exec_depend>message_runtime</exec_depend> -->
  <!-- Use test_depend for packages you need only for testing: -->
  <!--   <test_depend>gtest</test_depend> -->
  <!-- Use doc_depend for packages you need only for building documentation: -->
  <!--   <doc_depend>doxygen</doc_depend> -->
  <!-- 依賴的構建工具,這是必須的 -->
  <buildtool_depend>catkin</buildtool_depend>

  <!-- 指定構建此軟體包所需的軟體包 -->
  <build_depend>roscpp</build_depend>
  <build_depend>rospy</build_depend>
  <build_depend>std_msgs</build_depend>

  <!-- 指定根據這個包構建庫所需要的包 -->
  <build_export_depend>roscpp</build_export_depend>
  <build_export_depend>rospy</build_export_depend>
  <build_export_depend>std_msgs</build_export_depend>

  <!-- 運行該程式包中的代碼所需的程式包 -->  
  <exec_depend>roscpp</exec_depend>
  <exec_depend>rospy</exec_depend>
  <exec_depend>std_msgs</exec_depend>


  <!-- The export tag contains other, unspecified, tags -->
  <export>
    <!-- Other tools can request additional information be placed here -->

  </export>
</package>

2.啟動節點的方式

2.1 一次啟動一個

rosrun <the name of package> <the name of executable file>
  • executable file:對於C語言,這個文件就是CMakeLists.txt中用add_executable生成的可執行文件;對於python,這個文件就是CMakeLists.txt中用catkin_install_python指向的文件

對應語法:

add_executable(<the name of executable file>
               src/<the name of the source>.cpp
              )
catkin_install_python(PROGRAMS scripts/<the name of the source>.py
                      DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
                     )

2.2 一次啟動多個

如果想要一次性啟動一個包里的多個節點,而不是一行行地輸入rosrun指令...

  • 我們需要一個launch文件,它的固定格式是這樣的:
<launch>
    <node pkg="helloworld" type="demo_hello" name="hello" output="screen" />
    <node pkg="turtlesim" type="turtlesim_node" name="t1"/>
    <node pkg="turtlesim" type="turtle_teleop_key" name="key1" />
</launch>
  • node:包含的某個節點
  • pkg:功能包
  • type:被運行的節點文件
  • name:為節點命名
  • output:設置日誌的輸出目標

然後,在終端輸入:

roslaunch <the name of package> <the name of launch file>

3.ROS常用命令

3.1 增

創建新的ROS功能包:

catkin_create_pkg 自定義包名 依賴包

3.2 查

列出所有功能包:

rospack list

查找某個功能包是否存在,如果存在返回安裝路徑:

rospack find 包名

3.3 執行

3.3.1 載入環境變數

先進入工作目錄,然後:

source ./devel/setup.bash

3.3.2 運行節點

roscore:ROS的系統先決條件節點和程式的集合,必須運行 roscore 才能使 ROS 節點進行通信。新開一個終端並輸入

roscore #用法一
roscore -p xxxx #用法二,指定埠號

roscore 將啟動:

  • ros master
  • ros 參數伺服器
  • rosout 日誌節點

3.4 查看計算圖

在節點正在運行的情況下,終端輸入:

rosrun rqt_graph rqt_graph

在這裡插入圖片描述

4.創建功能包

4.1 選擇工作目錄

首先,選擇一個路徑作為工作目錄。這裡我選擇瞭如下路徑作為工作目錄
在這裡插入圖片描述

4.2 創建功能包目錄

mkdir src

然後,在工作空間目錄下

catkin_make

src目錄下會多出一個鎖定的CMakeLists.txt文件,不用管它。

4.3 建立功能包

先進入src目錄

cd src

然後使用ROS提供的指令直接創建功能包即可:

catkin_create_pkg <the name of your package> roscpp rospy std_msgs message_generatio

roscpp、rospy、std_msgs、message_generatio是你所需要的依賴,你可以自由決定想要哪些依賴

本文由博客一文多發平臺 OpenWrite 發佈!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • @目錄1.流程2.自定義發佈數據2.1 std_msgs內置類型2.2 編寫.msg文件2.3 修改package.xml文件2.3.1 完整的package.xml文件2.4 修改CMakeLists.txt文件2.4.1 修改find_package指令2.4.2 添加add_message_f ...
  • IOC與DI的理解 1.1、IoC是什麼 Ioc—Inversion of Control,即“控制反轉”,不是什麼技術,而是一種設計思想。在Java開發中,Ioc意味著將你設計好的對象交給容器控制,而不是傳統的在你的對象內部直接控制。如何理解好Ioc呢?理解好Ioc的關鍵是要明確“誰控制誰,控制什 ...
  • @目錄1.launch文件有哪些標簽2.node標簽2.1 必選屬性2.2 可選屬性2.3 可選子級標簽3.include標簽3.1 必選屬性3.2 可選屬性3.3 可選子級標簽4.remap標簽4.1 必選屬性5.param標簽5.1 必選屬性5.2 可選屬性6.rosparam標簽6.1 必選屬 ...
  • @目錄1.工作空間目錄2.載入環境變數3.打開CLion4.配置CLion5.編譯和調試軟體包 1.工作空間目錄 我們的一個工作空間目錄應該是這樣的 2.載入環境變數 先進入工作空間再載入 source ./devel/setup.bash 3.打開CLion 一定要在第二步的同一個終端下 clio ...
  • @目錄1.流程2.自定義請求和響應的數據2.1 std_msgs內置類型2.2 編寫.srv文件2.3 修改package.xml文件2.4 修改CMakeLists.txt文件2.4.1 修改find_package指令2.4.2 添加add_message_files指令2.4.3 添加gene ...
  • 所謂架構,意即系統架構,廣義上它涵蓋業務架構、運維架構、組織架構等所有系統構建場景,本文特指一般開發人員主要關註的開發架構。 關於架構的理論有很多,每個人也都有各自的理解,筆者相信很多人在實際運用中也會遇到各種各樣的問題和困惑,本文拋開教條,從一個實際項目的演化看何為架構。 項目背景 開始之前,先了 ...
  • @目錄1.配置Softerware & Updates2.添加軟體源3.設置key4.更新並安裝4.1 更新4.2 安裝(ros-noetic-desktop-full)4.2.1 安裝aptitude4.2.2 安裝ROS軟體包5.添加環境變數6.安裝構建依賴7.初始化和更新7.1 初始化7.1. ...
  • UML類圖 UML類圖 是一種靜態的結構圖,描述了系統的類的集合,類的屬性和類之間的關係,可以簡化了人們對系統的理解。UML類圖 是系統分析和設計階段的重要產物,是系統編碼和測試的重要模型。 圖示 類 解析 圓角矩形框,它就代表一個類(Class) 類圖分為三層: 第一層顯示類的名稱,如果是抽象類, ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...