[rviz]: Message Filter dropping message: frame ‘‘ at time 0.000 for reason ‘the frame id of the mess

报错原因

按照报错解释,以为是frame id没有正确设置,但其实代码没有问题。代码如下:

void publish_gnss_path(rclcpp::Publisher<nav_msgs::msg::Path>::SharedPtr pubPath)
{
    if (gnss_extrinsic_initialized == false) {
        return;
    }
    set_gps_posestamp(msg_gps_pose);
    msg_gps_pose.header.frame_id = "camera_init";
    msg_gps_pose.header.stamp = get_ros_time(lidar_end_time);

    /*** if path is too large, the rvis will crash ***/
    static int jjjj = 0;
    jjjj++;
    if (jjjj % 2 == 0) 
    {
        gps_path.poses.push_back(msg_gps_pose);
        pubPath->publish(gps_path);
    }
}

可以看到提示是在time = 0.0的时候,才有frame_id为空。所以联想到应该有一个初始化的动作,告诉这个topic它的frame_id。

解决办法

在初始化的时候,对gps_path的frame_id赋值。

gps_path.header.stamp = this->get_clock()->now();
gps_path.header.frame_id = "camera_init";
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值