使用C++向Rviz发送简单的形状

本文详细介绍了如何在RVIZ环境中使用C++和visualization_msgs::Marker类型的消息发送立方体、球体、箭头和圆柱等基本形状。通过实例代码展示了设置形状属性、帧ID、时间戳、命名空间、ID、颜色、规模和发布过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
按照RVIZ的官方教材来一步步来,Markers: Sending Basic Shapes (C++),第一步先学习如何使用visualization_msgs/Marker 类型的消息发送简单的形状给RVIZ。
在~/rviz_ws/src中运行

catkin_create_pkg using_markers roscpp visualization_msgs
gedit using_markers/src/basic_shapes.cpp

cpp的代码如下:

#include <ros/ros.h>
#include <visualization_msgs/Marker.h>

int main( int argc, char** argv )
{
  ros::init(argc, argv, "basic_shapes");
  ros::NodeHandle n;
  ros::Rate r(1);
  ros::Publisher marker_pub = n.advertise<visualization_msgs::Marker>("visualization_marker", 1);

  // Set our initial shape type to be a cube
  uint32_t shape = visualization_msgs::Marker::CUBE;

  while (ros::ok())
  {
    visualization_msgs::Marker marker;
    // Set the frame ID and timestamp.  See the TF tutorials for information on these.
    marker.header.frame_id = "/my_frame";
    marker.header.stamp = ros::Time::now();

    // Set the namespace and id for this marker.  This serves to create a unique ID
    // Any marker sent with the same namespace and id will overwrite the old one
    marker.ns = "basic_shapes";
    marker.id = 0;

    // Set the marker type.  Initially this is CUBE, and cycles between that and SPHERE, ARROW, and CYLINDER
    marker.type = shape;

    // Set the marker action.  Options are ADD, DELETE, and new in ROS Indigo: 3 (DELETEALL)
    marker.action = visualization_msgs::Marker::ADD;

    // Set the pose of the marker.  This is a full 6DOF pose relative to the frame/time specified in the header
    marker.pose.position.x = 0;
    marker.pose.position.y = 0;
    marker.pose.position.z = 0;
    marker.pose.orientation.x = 0.0;
    marker.pose.orientation.y = 0.0;
    marker.pose.orientation.z = 0.0;
    marker.pose.orientation.w = 1.0;

    // Set the scale of the marker -- 1x1x1 here means 1m on a side
    marker.scale.x = 1.0;
    marker.scale.y = 1.0;
    marker.scale.z = 1.0;

    // Set the color -- be sure to set alpha to something non-zero!
    marker.color.r = 0.0f;
    marker.color.g = 1.0f;
    marker.color.b = 0.0f;
    marker.color.a = 1.0;

    marker.lifetime = ros::Duration();

    // Publish the marker
    while (marker_pub.getNumSubscribers() < 1)
    {
      if (!ros::ok())
      {
        return 0;
      }
      ROS_WARN_ONCE("Please create a subscriber to the marker");
      sleep(1);
    }
    marker_pub.publish(marker);

    // Cycle between different shapes
    switch (shape)
    {
    case visualization_msgs::Marker::CUBE:
      shape = visualization_msgs::Marker::SPHERE;
      break;
    case visualization_msgs::Marker::SPHERE:
      shape = visualization_msgs::Marker::ARROW;
      break;
    case visualization_msgs::Marker::ARROW:
      shape = visualization_msgs::Marker::CYLINDER;
      break;
    case visualization_msgs::Marker::CYLINDER:
      shape = visualization_msgs::Marker::CUBE;
      break;
    }

    r.sleep();
  }
}

头文件不解释了

  ros::init(argc, argv, "basic_shapes");
  ros::NodeHandle n;
  ros::Rate r(1);
  ros::Publisher marker_pub = n.advertise<visualization_msgs::Marker>("visualization_marker", 1);

这四句话可以参考ROS教程中创建一个消息发布器的内容理解。
先初始化ROS。之后为这个进程的节点创建一个句柄。第一个创建的NodeHandle会为节点进行初始化,最后一个销毁的NodeHandle则会释放该节点所占用的所有资源。
定义循环频率。它会追踪记录自上一次调用Rate::sleep()后时间的流逝,并休眠直到一个频率周期的时间。
告诉 master 我们将要在visualization_marker(话题名) 上发布visualization_msgs::Marker消息类型的消息。这样 master 就会告诉所有订阅了visualization_marker话题的节点,将要有数据发布。第二个参数是发布序列的大小。如果我们发布的消息的频率太高,缓冲区中的消息在大于 1个的时候就会开始丢弃先前发布的消息。

uint32_t shape = visualization_msgs::Marker::CUBE;

定义一个变量shape表示我们Marker的类型。

visualization_msgs::Marker marker;
// Set the frame ID and timestamp.  See the TF tutorials for information on these.
marker.header.frame_id = "/my_frame";
marker.header.stamp = ros::Time::now();

其实这里我没有太明白。要设置frame的ID和时间戳。教程说让我去看tf的教程,好的,下次一定。
程序其他没有什么太难理解的地方。
之后就是修改CmakeLists.txt,在最后加上两句话生成可执行文件

add_executable(basic_shapes src/basic_shapes.cpp)
target_link_libraries(basic_shapes ${catkin_LIBRARIES})

准备运行\

cd ~/rviz_ws
catkin_make
roscore
rosrun using_markers basic_shapes

接下来启动RVIZ

rosrun rviz rviz

修改Fixed Frame
在这里插入图片描述

接下来添加一个Marker
在这里插入图片描述
之后就能看到我们想要的结果了。
在这里插入图片描述在这里插入图片描述

<think>好的,用户想了解如何用C++实现ROS向RVIZ发送立方体数据的功能。首先,我需要回忆ROS中可视化的相关知识点。RVIZ通常使用Markers来显示各种形状,包括立方体。用户需要的是发布立方体的示例代码和教程步骤。 首先,应该考虑使用visualization_msgs/Marker消息类型。这个消息类型允许定义形状、位置、颜色等属性。立方体的形状对应的是Marker::CUBE。接下来需要确定发布的话题,通常是"/visualization_marker",并且需要正确设置命名空间和ID,以避免多个标记冲突。 然后,编写C++节点的步骤大致包括:初始化ROS节点,创建Publisher,设置Marker的各个字段,如header、type、action、pose、scale、颜色等。需要注意frame_id的设置,通常是某个坐标系,比如"base_link"。此外,可能需要循环发布以保持显示,或者使用latch机制让RVIZ保留标记。 接下来需要检查用户提供的引用内容是否有相关参考。用户提供的引用[1]提到了编译industrial_moveit的步骤,但可能与此问题无关。引用[2]是关于英语缩略语的,也不相关。所以主要依靠ROS官方文档和常见的Marker使用示例。 可能还需要提醒用户安装必要的ROS包,比如roscpp、visualization_msgs,以及在package.xml和CMakeLists.txt中添加依赖。运行示例时,要启动roscore,运行节点,并在RVIZ中添加Marker显示。 用户可能会遇到的问题包括Marker不显示,这时候需要检查frame_id是否正确,或者颜色值是否超出范围。另外,如果同时发布多个标记,要注意ID和命名空间的管理。还可能涉及到动态调整立方体的位置或属性,这时候需要更新Marker并重新发布。 最后,生成相关问题时要考虑用户可能的后续需求,比如如何显示多个形状、动态更新、使用不同的坐标系,或者与其他ROS功能集成,比如TF变换。</think>要使用C++实现ROS向RVIZ发送立方体数据,主要涉及`visualization_msgs/Marker`消息类型的使用。以下是实现步骤和代码示例: ### 一、创建ROS节点框架 ```cpp #include <ros/ros.h> #include <visualization_msgs/Marker.h> int main(int argc, char** argv) { ros::init(argc, argv, "cube_publisher"); ros::NodeHandle nh; ros::Publisher marker_pub = nh.advertise<visualization_msgs::Marker>("visualization_marker", 1); // 后续代码将插入此处 } ``` ### 二、配置立方体参数 ```cpp visualization_msgs::Marker marker; marker.header.frame_id = "base_link"; // 坐标系设置[^1] marker.header.stamp = ros::Time::now(); marker.ns = "basic_shapes"; marker.id = 0; marker.type = visualization_msgs::Marker::CUBE; marker.action = visualization_msgs::Marker::ADD; // 设置立方体位置和姿态 marker.pose.position.x = 0.5; marker.pose.position.y = 0; marker.pose.position.z = 0.5; marker.pose.orientation.w = 1.0; // 设置立方体尺寸(单位:米) marker.scale.x = 0.3; marker.scale.y = 0.2; marker.scale.z = 0.1; // 设置颜色(RGBA,0-1范围) marker.color.r = 0.0f; marker.color.g = 0.8f; marker.color.b = 0.2f; marker.color.a = 0.7f; marker.lifetime = ros::Duration(); // 持续显示 ``` ### 三、发布数据循环 ```cpp while (ros::ok()) { marker_pub.publish(marker); ros::spinOnce(); ros::Duration(1).sleep(); // 控制发布频率 } ``` ### 四、运行步骤 1. 在`package.xml`中添加依赖: ```xml <depend>roscpp</depend> <depend>visualization_msgs</depend> ``` 2. 编译后运行节点: ```bash rosrun your_package cube_publisher ``` 3. 启动RVIZ后添加`Marker`显示插件,设置`Fixed Frame`为`base_link` ### 五、效果验证 将在RVIZ中看到尺寸为$0.3 \times 0.2 \times 0.1$米的半透明绿色立方体,其中心点坐标为$(0.5, 0, 0.5)$[^1]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yhwang-hub

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值