0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

ROS操作系統(tǒng)學(xué)習(xí)筆記4

jf_78858299 ? 來源:機(jī)器人網(wǎng) ? 作者:機(jī)器人網(wǎng) ? 2023-05-19 17:37 ? 次閱讀

第3步,設(shè)置CMakeLists.txt&package.xmlCMakeLists.txt:

find_package(catkin REQUIRED COMPONENTS
 roscpp
 std_msgs
)//告訴系統(tǒng)編譯本包時(shí),需要找到這兩個(gè)包

catkin_package(
# INCLUDE_DIRS include
# LIBRARIES study
CATKIN_DEPENDS roscpp std_msgs
# DEPENDS system_lib
)//聲明依賴本包同時(shí)需要里面這兩個(gè)ros包

add_executable(${PROJECT_NAME}_node src/study_listen_node.cpp)//編譯本包生成的可執(zhí)行文件

add_dependencies(${PROJECT_NAME}_node ${${PROJECT_NAME}_EXPORTED_TARGETS} ${catkin_EXPORTED_TARGETS})//鏈接可執(zhí)行文件和依賴庫

//一般情況而已,CMakeLists.txt是創(chuàng)建包同時(shí),系統(tǒng)自動(dòng)生成的,然后,我們需要的工作,一般情況就是把上面基本地方去掉#號(hào)就行了(目的告訴系統(tǒng),關(guān)于該包,在哪,依賴是啥)

package.xml:

roscppclass="hljs-name"build_depend>
std_msgsclass="hljs-name"build_depend>
roscppclass="hljs-name"exec_depend>
std_msgsclass="hljs-name"exec_depend>
//主要修改類似樣式,當(dāng)然,本例子比較簡(jiǎn)單,系統(tǒng)生成的,不需要做其他修改,但是,如果節(jié)點(diǎn)添加新的依賴,需要在這些地方添加相應(yīng)的包

第4步,編譯

$ catkin_make  #注意在要做工作空間的一級(jí)目錄下使用該指令

第5步,驗(yàn)證

$ roscore & #運(yùn)行一個(gè)ROS master
$ rosrun study study_node & #包名+節(jié)點(diǎn)名;由于測(cè)試listener的節(jié)點(diǎn),所以需要啟動(dòng)一個(gè)talker的node才行
$ rostopic echo #study_topic
data: "hello study world!432"
---
data: "hello study world!433" //表示發(fā)布成功
#開啟一個(gè)新終端
$ rosrun study study_listen_node #包名+節(jié)點(diǎn)名
[ INFO] [1606043574.419247936]: I can see you again,hello study world!178 //表示監(jiān)聽成功

這時(shí),從零開始創(chuàng)建的listener節(jié)點(diǎn)node,成功創(chuàng)建完成

  1. 自定義消息類型并發(fā)布演示

這里主要就是定義一個(gè)消息類型是重點(diǎn),然后,在上面創(chuàng)建的talker以及l(fā)istener包里面頭文件包含,然后在CMakeLists.txt&package.xml兩文件中,添加新的頭文件類型即可使用新定義的消息類型了。

第一步,創(chuàng)建一個(gè)包:

$ catkin_create_pkg study_msgs std_msgs roscpp

第二步,在包創(chuàng)建一個(gè)msg文件夾( 注意文件夾名稱一定是這樣子的,否則,在cmakelists要修改很多 )

第三步,在文件夾中新建文件,StudyMsg.msg(注意命名方式以及后綴)

string detail
int32 id

注意,自定義的消息類型,記得一定不能寫其他說明性內(nèi)容進(jìn)去,否則發(fā)生編譯錯(cuò)誤

第四步,設(shè)置CMakeLists.txt&package.xmlCMakeLists.txt:

find_package(catkin REQUIRED COMPONENTS
roscpp
std_msgs message_generation
)

## Generate messages in the 'msg' folder//這里可以看出,系統(tǒng)只會(huì)在msg文件夾中查找,對(duì)應(yīng)第二步
add_message_files(
  FILES
  StudyMsg.msg
)

## Generate added messages and services with any dependencies listed here
generate_messages(
  DEPENDENCIES
  std_msgs
)

package.xml:

<build_depend>message_generation<span class="hljs-name"build_depend>
  <exec_depend>message_runtime<span class="hljs-name"exec_depend>

第五步,編譯,catkin_make

第六步,查看

$ cd include/study_msgs
$ ls
StudyMsg.h   //表示該頭文件生成成功

這時(shí)候,自定義消息類型生成成功,并且,可以被其他包通過頭文件#include"study_msgs/StudyMsg.h"方式,就可以正常使用。下面,以發(fā)布一個(gè)talker節(jié)點(diǎn)來展示,并且發(fā)布的topic名稱為/study_topic_new當(dāng)然,CMakeLists.txt&package.xml要做相應(yīng)的補(bǔ)充,CMakeLists.txt:

find_package(catkin REQUIRED COMPONENTS
roscpp
std_msgs study_msgs
)

catkin_package(
# INCLUDE_DIRS include
# LIBRARIES study
CATKIN_DEPENDS roscpp std_msgs study_msgs
# DEPENDS system_lib
)
//兩者都是添加新消息類型study_msgs

package.xml:

study_msgsclass="hljs-name"build_depend>
study_msgsclass="hljs-name"exec_depend>
//添加新消息類型study_msgs

此時(shí),study_node.cpp為:

#include"ros/ros.h"
#include"std_msgs/String.h"
#include
#include"study_msgs/StudyMsg.h"//使用自定義消息類型

int main(int argc,char **argv){
   ros::init(argc,argv,"study_talker");//node's attribute name
   ros::NodeHandle n;
   ros::Publisher study_pub=n.advertise

終端查看:

$ rostopic echo /study_topic_new
---
detail: "hello study world! new"
id: 29975
---

4.** 參數(shù)中心rosparam的使用演示**

開始展示之前,一定要記得在study_listen包的CMakeLists.txt&package.xml做好跟上面的talker包study一樣準(zhǔn)備,保證可以使用自定義消息類型。

study_node.cpp:

#include"ros/ros.h"
#include"std_msgs/String.h"
#include
#include"study_msgs/StudyMsg.h"

int main(int argc,char **argv){
   ros::init(argc,argv,"study_talker");//node's attribute name
   ros::NodeHandle n;
   ros::Publisher study_pub=n.advertise

study_listen_node.cpp:

#include"ros/ros.h"
#include"std_msgs/String.h"
#include"study_msgs/StudyMsg.h"


void studyCallback(const std_msgs::String::ConstPtr& msg){
  ROS_INFO("I can see you again,%s ",msg->data.c_str());
}//測(cè)試是監(jiān)聽study_topic成功與否

void studyCallback_new(const study_msgs::StudyMsg::ConstPtr& msg){
  ROS_INFO("I think I cant forget you,%s,%d",msg->detail.c_str(),msg->id);
}//測(cè)試監(jiān)聽自定義消息成功與否

void studyCallback_param(const study_msgs::StudyMsg::ConstPtr& msg){
  ROS_INFO("I think I cant forget you,%s,%d",msg->detail.c_str(),msg->id);
}//測(cè)試rosparam參數(shù)中心是否工作成功

int main(int argc,char ** argv){
  ros::init(argc,argv,"study_listener");
  ros::NodeHandle n;
  ros::Subscriber sub=n.subscribe("/study_topic",10,studyCallback);
  ros::Subscriber sub_new=n.subscribe("study_topic_new",10,studyCallback_new);
  ros::Subscriber sub_param=n.subscribe("/params_topic",10,studyCallback_param);
  ros::spin();
  return 0;
}

修改了上面的兩個(gè)文件,接下來就是編譯整個(gè)工作空間并成功,接著在終端執(zhí)行

$ roscore &  #啟動(dòng)ros master
$ rosrun study study_node & #啟動(dòng)talker節(jié)點(diǎn)
$ rosrun study_listen study_listen_node #啟動(dòng)listener節(jié)點(diǎn)
[ INFO] [1606047990.464340880]: I can see you again,hello study world!99
[ INFO] [1606047990.464436530]: I think I cant forget you,hello study world! new,100
[ INFO] [1606047990.476383810]: I think I cant forget you,cc,100

這時(shí)候我們發(fā)現(xiàn),上面我們定義的回調(diào)函數(shù),都成功調(diào)用了(表示上面的talker/listener/自定義消息 類型都是編寫并運(yùn)行正常的)當(dāng)我們?cè)诮K端2啟動(dòng)參數(shù)中心rosparam設(shè)置參數(shù):

$ rosparam set /myparam "yqy"

終端1的顯示調(diào)整為:

[ INFO] [1606048163.371016634]: I can see you again,hello study world!368
[ INFO] [1606048163.371113447]: I think I cant forget you,hello study world! new,369
[ INFO] [1606048163.394940978]: I think I cant forget you,yqy,369

也就是將周期第三個(gè),cc調(diào)整為yqy了。

本章小結(jié):創(chuàng)建一個(gè)包,需要定義好CmakeLists.txt 、package.xml兩個(gè)文件,主要就是告訴系統(tǒng),我這個(gè)包編譯和運(yùn)行時(shí)依賴是什么;talker和listener的編寫也是基本套路一樣的,重新發(fā)布的主題以及消息類型以及內(nèi)容就發(fā)布o(jì)k了;listener的回調(diào)函數(shù),注意是無返回類型的;重新自定義一個(gè)消息類型,注意文件夾命名以及文件后綴名稱?;臼沁@些。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 仿真
    +關(guān)注

    關(guān)注

    50

    文章

    4023

    瀏覽量

    133338
  • 調(diào)試
    +關(guān)注

    關(guān)注

    7

    文章

    571

    瀏覽量

    33874
  • ROS
    ROS
    +關(guān)注

    關(guān)注

    1

    文章

    276

    瀏覽量

    16942
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    嵌入式Linux操作系統(tǒng)學(xué)習(xí)規(guī)劃,不看肯定后悔

    嵌入式Linux操作系統(tǒng)學(xué)習(xí)規(guī)劃,不看肯定后悔
    發(fā)表于 04-28 06:22

    探討嵌入式操作系統(tǒng)

    嵌入式操作系統(tǒng)學(xué)習(xí)筆記
    發(fā)表于 10-27 06:56

    嵌入式Linux操作系統(tǒng)學(xué)習(xí)規(guī)劃

    嵌入式Linux操作系統(tǒng)學(xué)習(xí)規(guī)劃ARM+LINUX路線,主攻嵌入式Linux操作系統(tǒng)及其上應(yīng)用軟件開發(fā)目標(biāo):(1) 掌握主流嵌入式微處理器的結(jié)構(gòu)與原理(初步定為arm9)(2) 必須掌握一個(gè)嵌入式
    發(fā)表于 11-05 06:45

    Linux操作系統(tǒng)下的Python語言程序設(shè)計(jì)

    文章目錄前言導(dǎo)引前言由于本專欄涉及內(nèi)容較多,如果大家希望系統(tǒng)學(xué)習(xí)Linux操作系統(tǒng)下的Python語言程序設(shè)計(jì),可參考此文章。按本文章所列文章內(nèi)容進(jìn)行學(xué)習(xí)即可,其它文章作為輔助參考資料使用。導(dǎo)引(1
    發(fā)表于 12-22 06:17

    UCOSII操作系統(tǒng)的簡(jiǎn)介

    前言這是我將UCOSII操作系統(tǒng)移植在STM32單片機(jī)上后進(jìn)行UCOSII操作系統(tǒng)學(xué)習(xí)的一些筆記與理解,此文最后會(huì)附上我自己在UCOSII操作系統(tǒng)下使用STM32寫
    發(fā)表于 01-12 06:00

    ROS是什么?機(jī)器人操作系統(tǒng)ROS的介紹

    Robotics Foundation,Inc) 公司維護(hù)的開源項(xiàng)目。 1、首先是一個(gè)操作系統(tǒng) 根據(jù) wikipedia 定義,操作系統(tǒng)是用來管理計(jì)算機(jī)硬件與軟件資源,并提供一些公用的 服務(wù)的系統(tǒng)軟件。而
    發(fā)表于 09-13 17:23 ?14次下載
    <b class='flag-5'>ROS</b>是什么?機(jī)器人<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>ROS</b>的介紹

    ROS的含義與機(jī)器人操作系統(tǒng)ROS的介紹

    Operating System 的縮寫,原本是斯坦福大學(xué)的一個(gè)機(jī)器人項(xiàng)目,后來由 WillowGarage 公司發(fā)展,目前由 OSRF(Open Source Robotics Foundation,Inc)公司維護(hù)的開源項(xiàng)目。 1、首先是一個(gè)操作系統(tǒng) 根據(jù) wikipedia 定義,
    發(fā)表于 09-26 14:08 ?12次下載

    機(jī)器人操作系統(tǒng)ROS詳細(xì)介紹

    機(jī)器人操作系統(tǒng)ROS詳細(xì)介紹 ROS( 機(jī)器人 操作系統(tǒng),RobotOperatingSystem),是專為機(jī)器人軟件開發(fā)所設(shè)計(jì)出來的一套電腦操作系
    發(fā)表于 11-18 18:09 ?2340次閱讀

    嵌入式操作系統(tǒng)學(xué)習(xí)筆記

    嵌入式操作系統(tǒng)學(xué)習(xí)筆記
    發(fā)表于 10-20 13:51 ?3次下載
    嵌入式<b class='flag-5'>操作系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>

    嵌入式系統(tǒng)學(xué)習(xí)筆記

    嵌入式系統(tǒng)學(xué)習(xí)筆記https://app.yinxiang.com/fx/97dd59b5-21f1-470c-969c-d3509ee38fce
    發(fā)表于 10-20 19:50 ?0次下載
    嵌入式<b class='flag-5'>系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>

    51操作系統(tǒng)學(xué)習(xí)筆記(三):建立一個(gè)屬于自己的AVR的RTOS(1)

    這篇筆記雖然是“51操作系統(tǒng)學(xué)習(xí)筆記”,但沒有找到合適的代碼。用楊明記的感覺還有點(diǎn)難度。因而轉(zhuǎn)學(xué)《建立一個(gè)屬于自己的AVR的RTOS》這篇文章絕對(duì)是學(xué)操作系統(tǒng)入門經(jīng)典之作。經(jīng)典之處在于
    發(fā)表于 11-15 18:36 ?9次下載
    51<b class='flag-5'>操作系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>(三):建立一個(gè)屬于自己的AVR的RTOS(1)

    51操作系統(tǒng)學(xué)習(xí)筆記(四):建立一個(gè)屬于自己的AVR的RTOS(2)

    承接51操作系統(tǒng)學(xué)習(xí)筆記(三):建立一個(gè)屬于自己的AVR的RTOS(1),在avr中調(diào)試一下下面的程序.為了加深學(xué)習(xí)應(yīng)用,決定把代碼全部輸一遍,比復(fù)制的學(xué)些效果應(yīng)該好一些吧。打開Avr studio
    發(fā)表于 11-15 21:06 ?7次下載
    51<b class='flag-5'>操作系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>(四):建立一個(gè)屬于自己的AVR的RTOS(2)

    ROS操作系統(tǒng)學(xué)習(xí)筆記1

    機(jī)器人操作系統(tǒng)(Robot operating system ,ROS)是一個(gè)應(yīng)用于機(jī)器人上的基礎(chǔ)框架,它把原本松散的零部件耦合在一起,提供通信的架構(gòu),近似上ROS是一個(gè)中間件。 ros
    的頭像 發(fā)表于 05-19 17:20 ?736次閱讀
    <b class='flag-5'>ROS</b><b class='flag-5'>操作系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>1

    ROS操作系統(tǒng)學(xué)習(xí)筆記2

    機(jī)器人操作系統(tǒng)(Robot operating system ,ROS)是一個(gè)應(yīng)用于機(jī)器人上的基礎(chǔ)框架,它把原本松散的零部件耦合在一起,提供通信的架構(gòu),近似上ROS是一個(gè)中間件。 ros
    的頭像 發(fā)表于 05-19 17:21 ?563次閱讀

    ROS操作系統(tǒng)學(xué)習(xí)筆記3

    摘要:這篇文章主要介紹ROS常用工具、ROSPY和ROSCPP常用模塊,完全看完三篇文章,可以說ROS就基本入門,可以自己動(dòng)手做實(shí)驗(yàn)了。 **ROS常用工具** ROS工具
    的頭像 發(fā)表于 05-19 17:37 ?964次閱讀
    <b class='flag-5'>ROS</b><b class='flag-5'>操作系統(tǒng)學(xué)習(xí)</b><b class='flag-5'>筆記</b>3