当前位置: 首页 > article >正文

《Ubuntu20.04环境下的ROS进阶学习7》

一、使用nav_msgs消息包显示小车轨迹

        在我们跑实验的时候通常希望看到小车的轨迹,在ROS1中可以将小车的路径存储在nav_msgs::Path 这种消息类型里,发布出来后使用rviz来显示小车轨迹。

二、了解nav_msgs消息包

        那么首先我们要来了解一下nav_msgs这个消息包了。这里可以下载common_interfaces这个功能包,里面有常用的很多种消息包可供选择。

使用  git clone https://github.com/ros2/common_interfaces.git

其中nav_msgs消息包中有四种消息格式分别是:

①  GridCells.msg  :一般用于显示网格单元的状态,通常用于显示区域中的障碍和自用空间。

②  MapMetaData.msg  :提供关于栅格地图的元数据,通常与①一起用。

③  OccupancyGrid.msg  :表示一个二维栅格地图,用于描述环境的占用状态。

④  Odometry.msg  :提供有关机器人位姿和速度的信息,通常用于定位和导航。

⑤  Path.msg  :表示一条路径,通常用于导航算法中的路径规划和跟踪。

这里我们选择第五种消息包,显示一条路径。

这里如果你直接去查看这些消息格式是比较麻烦的,因为他们通常会递归很久才会找到终止条件,即基例,我们可以使用 rosmsg show nav_msgs/Path.msg 来查看这个消息格式。

通过观察缩进可以看到消息的子父类关系。

三、使用nav_msgs::Path.h操作一把

a、编写程序

/*
本文件由jk编辑,本文件主要目的是通过一个小例程了解nav_msgs的使用

*/

//C++库相关
#include <iostream>
#include <cmath>


//ROS库相关
#include <ros/ros.h>
#include <nav_msgs/Path.h>


using namespace std;

int main(int argc , char ** argv)
{
	//初始化ros
	ros::init(argc , argv , "nav_path_pub");
	
	ros::NodeHandle node;
	
	//创建一个路径的发布者
	ros::Publisher Path_pub_car0 = node.advertise<nav_msgs::Path>("/path_car0" , 10);
	
	//创建路径的消息存储数据
	nav_msgs::Path nav_path_msgs_car0;
	
	//设置发布频率
	ros::Rate loop_rate(10);
	
	//从传感器获取的位置信息 x , y , z 这里我们不关心z轴信息,则忽视它
	double path_x = 0;
	double path_y = 0.2;
	
	//从传感器获取的角度
	double roll = 0.0;
	double pitch = 0.0;
	double yaw = 0.0;
	
	cout << "i will go while" << endl;
	while(ros::ok())
	{
		//退出循环条件
		if(path_x > 10)
		{
			cout << "i will break" << endl;
			break;
		}
		
		
		//获取路径 , 这里大概率是从您的传感器获得的数据
		path_x = path_x + 0.1;
		path_y = path_y * (-1);
		cout << "path_x = " << path_x << endl;
		cout << "path_y = " << path_y << endl;
		//获取角度 , 这里大概率是从您的传感器获得的数据
		double Quaternion_w = cos(0.5*roll)*cos(0.5*pitch)*cos(0.5*yaw) + sin(0.5*roll)*sin(0.5*pitch)*sin(0.5*yaw);
		double Quaternion_x = sin(0.5*roll)*cos(0.5*pitch)*cos(0.5*yaw) - cos(0.5*roll)*sin(0.5*pitch)*sin(0.5*yaw);
		double Quaternion_y = cos(0.5*roll)*sin(0.5*pitch)*cos(0.5*yaw) + sin(0.5*roll)*cos(0.5*pitch)*sin(0.5*yaw);
		double Quaternion_z = cos(0.5*roll)*cos(0.5*pitch)*sin(0.5*yaw) - sin(0.5*roll)*sin(0.5*pitch)*cos(0.5*yaw);
		
		//这里创建一个临时的变量存储位置和姿态信息
		geometry_msgs::PoseStamped this_pose_stamped;
		//创建一个存储时间的临时变量,用于给header.stamp赋值 获得当前的时间
		ros::Time current_time = ros::Time::now();
		
		//下面是存储要发布的数据	注意这里的frame_id 可能会需要修改 
		nav_path_msgs_car0.header.stamp = current_time;
		nav_path_msgs_car0.header.frame_id = "map";
		this_pose_stamped.header.stamp = current_time;
		this_pose_stamped.header.frame_id = "map";
		this_pose_stamped.pose.position.x = path_x;
		this_pose_stamped.pose.position.y = path_y;
		this_pose_stamped.pose.position.z = 0.0;
		this_pose_stamped.pose.orientation.w = Quaternion_w;
		this_pose_stamped.pose.orientation.x = Quaternion_x;
		this_pose_stamped.pose.orientation.y = Quaternion_y;
		this_pose_stamped.pose.orientation.z = Quaternion_z;

		nav_path_msgs_car0.poses.push_back(this_pose_stamped);
		
		//将上面的数据发布出去
		Path_pub_car0.publish(nav_path_msgs_car0);
		
		//设置发布频率
		loop_rate.sleep();
		
	}
	
	
	return 0;
}





b、修改CMakeList.txt 和 package.xml文件

        这里就不多展示了,之前的文章都有过详细说明。

c、使用rviz展示效果

        这里需要添加Path,选择合适的话题和坐标系就可以显示路径了。


http://www.kler.cn/a/330059.html

相关文章:

  • 【WPF】Prism学习(八)
  • 多品牌摄像机视频平台EasyCVR视频融合平台+应急布控球:打造城市安全监控新体系
  • 英语中do(做没做)和can(有能力/资格做)的区分
  • 【Apache Paimon】-- 2 -- 核心特性 (0.9.0)
  • 区块链中的wasm合约是什么?
  • STM32 创建一个工程文件(寄存器、标准库)
  • Windows 10再次成为Steam上最受欢迎的操作系统 Linux用户比例略有下降
  • Redis:初识Redis
  • 【git】提交更改到仓库
  • 让CSS flex布局最后一行列表左对齐的N种方法
  • fastAPI教程:路由操作及HTTP请求响应
  • python的几个基本数据类型及其相关操作(字符串str,元组tuple,列表list,字典dict)
  • ros2 自定义工作空间添加source
  • k8s架构,从clusterIP到光电半导体,再从clusterIP到企业管理
  • 微信小程序实战教程:如何使用map组件实现地图功能
  • TCP/UDP初识
  • 物联网智能项目探究和方案设计
  • 叶国富“推翻”马云新零售,零售新王此刻登基?
  • 栈与队列相关知识(二)
  • LLM基础概念:模型训练
  • 基于SpringBoot的校园健康信息管理系统
  • 相机基础概念
  • 【分布式训练 debug】VS Code Debug 技巧:launch.json实用参数
  • Grafana链接iframe嵌入Web前端一直跳登录页面的问题记录
  • RabbitMQ 延迟消息
  • 51单片机系列-按键检测原理