tf中静态坐标订阅方实现

/*
订阅方:订阅发布的坐标相对关系,传入一个坐标点,调用·tf实现转换

流程:
1.包含头文件
2.编码,初始化节点 Nodehandle
3.创建订阅对象 ----> 订阅坐标相对关系
4组织一个坐标点的数据
5.转换算法,需要调用tf内置函数
6.最后输出
*/

#include "ros/ros.h"
#include "tf2_ros/transform_listener.h"
#include "tf2_ros/buffer.h"
#include "geometry_msgs/PointStamped.h"
#include "tf2_geometry_msgs/tf2_geometry_msgs.h"

int main(int argc, char *argv[])
{
    // 2.编码,初始化节点 Nodehandle
    setlocale(LC_ALL,"");
    ros::init(argc,argv,"static_sub");
    ros::NodeHandle nh;
    // 3.创建订阅对象  ----> 订阅坐标相对关系
    //3.1创建一个buffer缓存(#include "tf2_ros/buffer.h")
    tf2_ros::Buffer buffer;
    //3.2创建监听对象(将订阅的数据存入buffer,#include "tf2_ros/transform_listener.h")    
    tf2_ros::TransformListener listener(buffer);
    // 4.组织一个坐标点的数据
    geometry_msgs::PointStamped ps;	//#include "geometry_msgs/PointStamped.h"
    ps.header.frame_id="laser";
    ps.header.stamp=ros::Time::now();
    ps.point.x=2.0;
    ps.point.y=3.0;
    ps.point.z=5.0;
    //休眠
    ros::Duration(2).sleep();
    // 5.转换算法,需要调用tf内置函数
    ros::Rate rate(10);
    while (ros::ok())
    {
        //核心代码实现
        geometry_msgs::PointStamped ps_out;
        ps_out = buffer.transform(ps,"base_link");

        // 6.最后输出
        ROS_INFO("转换的坐标系:(%2.f,%2.f,%2.f),参考的坐标系:%s",
            ps_out.point.x,
            ps_out.point.y,
            ps_out.point.z,
            ps_out.header.frame_id.c_str()
        );
        rate.sleep();
        ros::spinOnce();
    }
    
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值