unitree_ros/unitree_gazebo/plugin/draw_force_plugin.cc

86 lines
3.4 KiB
C++

/************************************************************************
Copyright (c) 2018-2019, Unitree Robotics.Co.Ltd. All rights reserved.
Use of this source code is governed by the MPL-2.0 license, see LICENSE.
************************************************************************/
#include <ignition/math/Color.hh>
#include <gazebo/common/Events.hh>
#include <gazebo/msgs/msgs.hh>
#include <gazebo/transport/Node.hh>
#include <gazebo/common/Plugin.hh>
#include <ros/ros.h>
#include "gazebo/rendering/DynamicLines.hh"
#include "gazebo/rendering/RenderTypes.hh"
#include "gazebo/rendering/Visual.hh"
#include "gazebo/rendering/Scene.hh"
#include <ros/ros.h>
#include <boost/bind.hpp>
#include <geometry_msgs/WrenchStamped.h>
namespace gazebo
{
class UnitreeDrawForcePlugin : public VisualPlugin
{
public:
UnitreeDrawForcePlugin():line(NULL){}
~UnitreeDrawForcePlugin(){
this->visual->DeleteDynamicLine(this->line);
}
void Load(rendering::VisualPtr _parent, sdf::ElementPtr _sdf )
{
this->visual = _parent;
this->visual_namespace = "visual/";
if (!_sdf->HasElement("topicName")){
ROS_INFO("Force draw plugin missing <topicName>, defaults to /default_force_draw");
this->topic_name = "/default_force_draw";
} else{
this->topic_name = _sdf->Get<std::string>("topicName");
}
if (!ros::isInitialized()){
int argc = 0;
char** argv = NULL;
ros::init(argc,argv,"gazebo_visual",ros::init_options::NoSigintHandler|ros::init_options::AnonymousName);
}
this->line = this->visual->CreateDynamicLine(rendering::RENDERING_LINE_STRIP);
this->line->AddPoint(ignition::math::Vector3d(0, 0, 0), common::Color(0, 1, 0, 1.0));
this->line->AddPoint(ignition::math::Vector3d(1, 1, 1), common::Color(0, 1, 0, 1.0));
this->line->setMaterial("Gazebo/Purple");
this->line->setVisibilityFlags(GZ_VISIBILITY_GUI);
this->visual->SetVisible(true);
this->rosnode = new ros::NodeHandle(this->visual_namespace);
this->force_sub = this->rosnode->subscribe(this->topic_name+"/"+"the_force", 30, &UnitreeDrawForcePlugin::GetForceCallback, this);
this->update_connection = event::Events::ConnectPreRender(boost::bind(&UnitreeDrawForcePlugin::OnUpdate, this));
ROS_INFO("Load %s Draw Force plugin.", this->topic_name.c_str());
}
void OnUpdate()
{
this->line->SetPoint(1, ignition::math::Vector3d(Fx, Fy, Fz));
}
void GetForceCallback(const geometry_msgs::WrenchStamped & msg)
{
Fx = msg.wrench.force.x/20.0;
Fy = msg.wrench.force.y/20.0;
Fz = msg.wrench.force.z/20.0;
// Fx = msg.wrench.force.x;
// Fy = msg.wrench.force.y;
// Fz = msg.wrench.force.z;
}
private:
ros::NodeHandle* rosnode;
std::string topic_name;
rendering::VisualPtr visual;
rendering::DynamicLines *line;
std::string visual_namespace;
ros::Subscriber force_sub;
double Fx=0, Fy=0, Fz=0;
event::ConnectionPtr update_connection;
};
GZ_REGISTER_VISUAL_PLUGIN(UnitreeDrawForcePlugin)
}