ros知识点总结--头文件

自定义头文件步骤: 下面的.h 和.cpp文件没必要细看,就是c++中写头文件的方法。
ROS中自己编写头文件,在其他cpp文件中调用,和一般的c++文件编写,基本差不多,但是也是需要配置CMakeLists.txt文件的几处地方,下面给出我原来写的一个简单A*算法的例子

atsar.h —一般创建在功能包下的include/功能包名/astar.h

//astar.h
#include "ros/ros.h"
#include <nav_msgs/Path.h>
#include <geometry_msgs/PoseStamped.h>
#include <stack>
#include "nav_msgs/OccupancyGrid.h"
    int toIndex(int x,int y,int width)
    {
        return width * y + x ;
    }
    struct Node{
        int x;
        int y;
        float cost;
        int G;//起点当当前点的代价
        int F;//终点到当前点的代价
        int pre_index;
        Node(int x,int y, int g,int f,int pre)
        {
            this->x = x;
            this->y = y;
            this->G = g;
            this->F = f;
            this->cost = g+f;
            this->pre_index = pre;
        }
    
    };
    class compare {
        public:
            bool operator()(const Node& a, const Node& b) const {
                return a.cost < b.cost;
        }
    };
    class astar{
        private:
            std::multiset<Node,compare> open_;//自动排序
            std::vector<int> close_;//大小等于地图数组大小,0---代表没有使用,i代表父节点,及open_出来的全标记为1;
            int width;
            int height;
            std::vector<int8_t> map_data;
            bool add(int x,int y,Node parent,int end_x,int end_y,int cost);
        public:
            astar(nav_msgs::OccupancyGrid data);
            nav_msgs::Path astar_path_planning(int begin_x,int begin_y,int end_x,int end_y,bool &symbol);//标志位为false,则规划不出一条可行路径.
    };

astar.cpp —创建在src/astar.cpp

#include "multi_robot/astar.h"
    astar::astar(nav_msgs::OccupancyGrid data)
    {
        map_data = data.data;
        width = data.info.width;
        height = data.info.height;
        close_ = std::vector<int>(data.data.size(),-1);//初始化为-1;
    }
    nav_msgs::Path astar::astar_path_planning(int begin_x,int begin_y,int end_x,int end_y,bool &symbol)
    {
        open_.insert(Node(begin_x,begin_y,0,0,0));
        while(open_.size()>0&&symbol == false)//
        {
            std::cout<<"main"<<open_.size()<<std::endl;
            Node top = *open_.begin();
            open_.erase(open_.begin());
            close_[toIndex(top.x,top.y,width)] = top.pre_index;
            symbol = add(top.x+1,top.y,top,end_x,end_y,10);
            if(symbol==true)
                break;
            symbol = add(top.x-1,top.y,top,end_x,end_y,10);
            if(symbol==true)
                break;
            symbol = add(top.x,top.y+1,top,end_x,end_y,10);
            if(symbol==true)
                break;
            symbol = add(top.x,top.y-1,top,end_x,end_y,10);
            if(symbol==true)
                break;
            symbol = add(top.x+1,top.y+1,top,end_x,end_y,14);
            if(symbol==true)
                break;
                symbol = add(top.x+1,top.y-1,top,end_x,end_y,14);
            if(symbol==true)
                break;
                symbol = add(top.x-1,top.y+1,top,end_x,end_y,14);
            if(symbol==true)
                break;
                symbol = add(top.x-1,top.y-1,top,end_x,end_y,14);
            if(symbol==true)
                break;
            
        }
        nav_msgs::Path path;
        if(symbol == false)
            return path;
        for(int i =0;i<=8;i++)
            std::cout<<close_[i]<<std::endl;
        std::stack<int> st;
        st.push(toIndex(end_x,end_y,width));
        int i = close_[toIndex(end_x,end_y,width)];

        while(i !=toIndex(begin_x,begin_y,width))
        {
            
            st.push(i);
            i = close_[i];
        }
        st.push(i);
        geometry_msgs::PoseStamped this_pose_stamped;
        while(st.size() != 0)
        {
            this_pose_stamped.pose.position.x = st.top()%width;
            this_pose_stamped.pose.position.y = st.top()/width;
            this_pose_stamped.pose.position.z = 0;
            this_pose_stamped.header.frame_id = "/map";
            this_pose_stamped.header.stamp = ros::Time::now();
            path.poses.push_back(this_pose_stamped);
            st.pop();
        }
        return path;
    }
    bool astar::add(int x,int y,Node parent,int end_x,int end_y,int cost)
    {
         std::cout<<"add"<<std::endl;
        if(x<0||x>=width||y<0||y>=height)
            return false;
        if(map_data[toIndex(x,y,width)] != 0)//表示占有
            return false;
        if(close_[toIndex(x,y,width)] !=-1)
        {
            return false;
            //open_.insert(Node(x,y, parent.G+10,10*(abs(end_x-x)+abs(end_y-y)) ,toIndex(parent.x,parent.y,width)));
        }
        bool sym=false;
        if(open_.size() != 0)
        {
            std::multiset<Node,compare>::iterator it = open_.begin();
        
            while(it != open_.end())
            {
                if((*it).x == x && (*it).y ==y)
                {
                    sym =true;
                    if((*it).F>parent.G+10)
                    {
                        open_.erase(it);
                        open_.insert(Node(x,y, parent.G+cost,10*(abs(end_x-x)+abs(end_y-y)) ,toIndex(parent.x,parent.y,width)));
                        break;
                    }
                
                }
                it++;
            }
        }
        if(sym==false)
            open_.insert(Node(x,y, parent.G+cost,10*(abs(end_x-x)+abs(end_y-y)) ,toIndex(parent.x,parent.y,width)));
        if(x==end_x&&y==end_y)
        {
            close_[toIndex(x,y,width)] = toIndex(parent.x,parent.y,width);
            return true;
        }    
        return false;
    }

CMakeLists.txt文件配置

include_directories(
 include    //------放开include
  ${catkin_INCLUDE_DIRS}
)
add_library(//每一个头文件配置一个add_library
  Astar    //类似可执行文件名,这里自己起,后面配置对应即可
  src/astar.cpp
  include/multi_robot/astar.h //其中multi_robot是功能包名,也可以使用${PROJECT_NAME},
)
add_dependencies(Astar ${${PROJECT_NAME}_EXPORTED_TARGETS} ${catkin_EXPORTED_TARGETS})//Astar就是前面的可执行文件名

target_link_libraries(Astar //Astar就是前面的可执行文件名
  ${catkin_LIBRARIES}
)

//在某个cpp文件中使用该头文件时 就和平时一样头文件包含即可

#include "multi_robot/astar.h"

在该文件配置时,和以往比,唯一区别:

target_link_libraries(sub_pose
  Astar   //---多一步添加头文件的可执行文件
  ${catkin_LIBRARIES}
)
  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ROS2 Web Bridge是一个开源的软件,旨在使ROS2(Robot Operating System 2)与Web端进行通信和交互。它提供了一种简单而强大的方式,通过WebSocket协议将ROS2系统中的数据传输到Web浏览器。 ROS2 Web Bridge允许Web开发人员使用常见的Web技术(例如JavaScript)直接与ROS2系统进行交互。它提供了一个轻量级的接口,可以订阅和发布ROS2主题,并在Web浏览器中实时显示传感器数据、控制机器人等。 此外,ROS2 Web Bridge还支持ROS2服务和动作。它允许Web应用程序在Web端调用ROS2服务,从而实现与ROS2节点的双向通信。通过一个用户友好的Web界面,用户可以发送控制命令给机器人,执行任务并获得实时反馈。 ROS2 Web Bridge的主要优点之一是其跨平台性。它基于WebSocket协议,因此可以在不同的操作系统和设备上使用,无论是在PC端还是移动设备上。 此外,ROS2 Web Bridge还支持认证和授权机制,以确保通信安全。这对于确保只有被授权的用户可以访问和控制ROS2系统非常重要。 总的来说,ROS2 Web Bridge为ROS2系统提供了一种简便而强大的方式,使Web开发人员能够与ROS2系统进行交互。它扩展了ROS2的功能,使得机器人开发更加灵活和可视化。 ### 回答2: ros2-web-bridge是一种用于在ROS 2和Web应用程序之间进行通信的桥接工具。ROS 2是机器人操作系统的第二代版本,而Web应用程序是通过Web浏览器访问的应用程序。 ros2-web-bridge有几个主要功能。首先,它允许ROS 2中的节点直接与通过Web浏览器访问的Web应用程序进行通信。这使得在Web界面上实时监控和控制ROS 2系统变得更加容易。例如,可以使用ros2-web-bridge将传感器数据从ROS 2节点发送到Web应用程序,以便在Web界面上实时显示传感器数据。同时,还可以将来自Web界面的用户输入发送到ROS 2节点,以便远程控制机器人或系统。 其次,ros2-web-bridge还提供了一些工具和API,用于将ROS 2中的消息和服务转换为Web格式。这使得可以轻松地在ROS 2和Web应用程序之间进行数据传输和交互。它支持使用ROS 2的套接字和JSON进行通信,并提供了将消息和服务转换为JSON格式以及反向转换的功能。这样,ROS 2节点可以与通过Web浏览器访问的Web应用程序进行无缝通信。 总而言之,ros2-web-bridge为ROS 2和Web应用程序之间的通信提供了一个便捷的桥梁。它简化了ROS 2系统与Web界面之间的集成,并提供了实时数据传输和远程控制的能力。这对于构建基于ROS 2的机器人或系统的开发者和使用者来说是非常方便的工具。 ### 回答3: ros2-web-bridge是一个用于将ROS 2和Web技术进行连接的工具。它提供了一个桥接器,使得可以通过Web浏览器与ROS 2通信。这个工具是建立在ROS 2和Web Socket之间的通信基础上的。 通过ros2-web-bridge,我们可以在Web浏览器中实时地订阅和发布ROS 2的消息。这使得我们可以通过Web界面来控制ROS 2的机器人,或者将ROS 2的数据可视化展示出来。这对于远程监控、远程操作和数据可视化都非常有用。 ros2-web-bridge使用ROS 2提供的接口来与ROS 2系统进行通信。它将ROS 2的消息转换为适用于Web Socket的格式,并在浏览器和ROS 2之间建立起适配的连接。通过这种方式,Web界面就能够与ROS 2系统进行实时的双向通信。 ROS 2中的消息传递方式是异步的,而Web浏览器通常使用同步的方式进行通信。ros2-web-bridge通过在ROS 2和Web Socket之间进行适配和转换,使得二者能够协同工作。这意味着ROS 2中的数据可以通过ros2-web-bridge传输到Web浏览器,并在该浏览器中进行处理和展示。 总的来说,ros2-web-bridge是一个功能强大的工具,它架起了ROS 2和Web技术之间的桥梁。它使得我们可以通过Web浏览器来与ROS 2进行通信,进而实现远程操作和数据可视化的目的。通过ros2-web-bridge,我们可以更加灵活和方便地利用ROS 2的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值