pluginlib-编写简单的插件

来源 http://wiki.ros.org/pluginlib/Tutorials/Writing%20and%20Using%20a%20Simple%20Plugin

代码解释参考https://www.ncnynl.com/archives/201702/1323.html

具体步骤如下

准备

进入工作空间

cd ~/pluginlib_ws/src/

创建pluginlib_tutorials_示例包

catkin_create_pkg pluginlib_tutorials_ roscpp pluginlib

1 创建插件库

1.1 创建基类

vim pluginlib_tutorials_/include/pluginlib_tutorials_/polygon_base.h

基类polygon_base.h代码:

#ifndef PLUGINLIB_TUTORIALS__POLYGON_BASE_H_
#define PLUGINLIB_TUTORIALS__POLYGON_BASE_H_

namespace polygon_base
{
  class RegularPolygon
  {
    public:
      virtual void initialize(double side_length) = 0;
      virtual double area() = 0;
      virtual ~RegularPolygon(){}

    protected:
      RegularPolygon(){}
  };
};
#endif

1.2 创建插件

 vim pluginlib_tutorials_/include/pluginlib_tutorials_/polygon_plugins.h
代码如下:

#ifndef PLUGINLIB_TUTORIALS__POLYGON_PLUGINS_H_
#define PLUGINLIB_TUTORIALS__POLYGON_PLUGINS_H_
#include <pluginlib_tutorials_/polygon_base.h>
#include <cmath>

namespace polygon_plugins
{
  class Triangle : public polygon_base::RegularPolygon
  {
    public:
      Triangle(){}

      void initialize(double side_length)
      {
        side_length_ = side_length;
      }

      double area()
      {
        return 0.5 * side_length_ * getHeight();
      }

      double getHeight()
      {
        return sqrt((side_length_ * side_length_) - ((side_length_ / 2) * (side_length_ / 2)));
      }

    private:
      double side_length_;
  };

  class Square : public polygon_base::RegularPolygon
  {
    public:
      Square(){}

      void initialize(double side_length)
      {
        side_length_ = side_length;
      }

      double area()
      {
        return side_length_ * side_length_;
      }

    private:
      double side_length_;

  };
};
#endif

1.3 注册插件

vim pluginlib_tutorials_/src/polygon_plugins.cpp

代码如下:

#include <pluginlib/class_list_macros.h>
#include <pluginlib_tutorials_/polygon_base.h>
#include <pluginlib_tutorials_/polygon_plugins.h>

PLUGINLIB_EXPORT_CLASS(polygon_plugins::Triangle, polygon_base::RegularPolygon)
PLUGINLIB_EXPORT_CLASS(polygon_plugins::Square, polygon_base::RegularPolygon)

构建插件库

在CMakeLists.txt文件中添加

include_directories(include)
add_library(polygon_plugins src/polygon_plugins.cpp)

编译

2 使插件可用于ROS工具链

创建一个XML文件,还需要再包清单中的建立特殊导出行,就可以为ROS工具链提供有关插件的所有必要信息

2.1 创建XML文件

vim pluginlib_tutorials_/polygon_plugins.xml

polygon_plugins.xml位于包的顶层,与CMakeLists.txt和package.xml在一起

代码如下:

<library path="lib/libpolygon_plugins">
  <class type="polygon_plugins::Triangle" base_class_type="polygon_base::RegularPolygon">
    <description>This is a triangle plugin.</description>
  </class>
  <class type="polygon_plugins::Square" base_class_type="polygon_base::RegularPolygon">
    <description>This is a square plugin.</description>
  </class>
</library>

2.2 导出插件

在package.xml中添加

<export>
  <pluginlib_tutorials_ plugin="${prefix}/polygon_plugins.xml" />
</export>

验证是否生效:

rospack plugins --attrib=plugin pluginlib_tutorials_

如果生效,可以看见polygon_plugins.xml文件的完整路径

2.3 使用插件

 vim pluginlib_tutorials_/src/polygon_loader.cpp

代码如下

#include <pluginlib/class_loader.h>
#include <pluginlib_tutorials_/polygon_base.h>

int main(int argc, char** argv)
{
  pluginlib::ClassLoader<polygon_base::RegularPolygon> poly_loader("pluginlib_tutorials_", "polygon_base::RegularPolygon");

  try
  {
    boost::shared_ptr<polygon_base::RegularPolygon> triangle = poly_loader.createInstance("polygon_plugins::Triangle");
    triangle->initialize(10.0);

    boost::shared_ptr<polygon_base::RegularPolygon> square = poly_loader.createInstance("polygon_plugins::Square");
    square->initialize(10.0);

    ROS_INFO("Triangle area: %.2f", triangle->area());
    ROS_INFO("Square area: %.2f", square->area());
  }
  catch(pluginlib::PluginlibException& ex)
  {
    ROS_ERROR("The plugin failed to load for some reason. Error: %s", ex.what());
  }

  return 0;
}

3 运行插件

在CMakeLists.txt文件中添加以下行

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

编译

运行

rosrun pluginlib_tutorials_ polygon_loader

[ INFO] [1534856640.660509344]: Triangle area: 43.30
[ INFO] [1534856640.660569938]: Square area: 100.00

完整工程见 https://github.com/YangFighting/ros_tutorial/tree/master/pluginlib_tutorials_

本文如有问题,请与我联系 yangzhang_y@163.com

在Ubuntu系统中安装`pluginlib`包通常涉及几个步骤,因为`pluginlib`并不是官方软件中心(apt)自带的库,它可能是某个特定应用或项目的依赖。以下是安装自定义第三方库如`pluginlib`的一般流程: 1. 首先,你需要确认`pluginlib`是从哪里来的,比如GitHub、GitLab或其他源码仓库。如果它是Python项目,可能需要的是`python-pluginlib`。 2. 如果`pluginlib`是一个C++库,你可能需要从其官方网站下载源码,或者在发行版的PPA (Personal Package Archive) 或者GitHub Actions发布页面找到预编译的.deb文件。 3. 对于C++库,打开终端并运行命令: ```bash sudo apt-get update ``` 然后安装必要的构建工具,如`build-essential`: ```bash sudo apt-get install build-essential cmake ``` 4. 到下载的`pluginlib`目录下,创建一个名为`build`的子目录,并导航到那里: ```bash mkdir pluginlib-build && cd pluginlib-build ``` 5. 运行`cmake ..`来生成Makefile,这里的`..`表示上一级目录即`pluginlib`目录。替换为实际的路径。 6. 使用`make`编译库: ```bash make ``` 7. 最后,使用`sudo make install`将编译后的库安装到系统中(可能需要管理员权限)。这会将库文件添加到`/usr/local/lib`目录下,并将头文件添加到包含路径中。 8. 如果需要,别忘了更新你的环境变量,使其能够识别新安装的库。 请注意,具体的安装步骤可能会根据`pluginlib`的具体情况有所不同。如果你能找到详细的安装指南或文档,那么按照那些指示操作会更准确。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值