问题描述
我正在尝试在c ++中实现ROS GotoGoal,这是代码
#include "ros/ros.h"
#include "geometry_msgs/Twist.h"
#include "geometry_msgs/Pose2D.h"
#include "turtlesim/Pose.h"
class Turtle {
public :
Turtle(int argc,char** argv){
ros::init(argc,argv,"mover");
ros::NodeHandle n;
pose = turtlesim::Pose();
pub = n.advertise<geometry_msgs::Twist>("/turtle1/cmd_vel",100);
sub = n.subscribe("/turtle1/pose",100,&Turtle::Update,this);
}
void Update(const turtlesim::Pose::ConstPtr& msg){
ROS_INFO("Pose recieved : x = %f y = %f\n",msg->x,msg->y );
pose = *msg;
}
void move2goal(){
turtlesim::Pose goalPose= turtlesim::Pose() ;
std::cout<<"Enter goal x : "<<" ";
std::cin>>goalPose.x ;
std::cout<<"Enter goal y : "<<" ";
std::cin>>goalPose.y ;
float d ;
std::cout<<"Enter distance tolerance d : "<<" ";
std::cin>>d ;
auto vel_msg = geometry_msgs::Twist() ;
ros::Rate loop_rate(2.0);
while(distance(goalPose)>=d && ros::ok()){
vel_msg.linear.x = linear_veLocity(goalPose,1.5);
vel_msg.linear.y =0 ;
vel_msg.linear.z = 0 ;
vel_msg.angular.x = 0 ;
vel_msg.angular.y= 0 ;
vel_msg.angular.z = angular_veLocity(goalPose,6) ;
pub.publish(vel_msg) ;
loop_rate.sleep() ;
ROS_INFO("current : %f %f\n",pose.x,pose.y) ;
}
vel_msg.angular.z=0 ;
vel_msg.linear.x =0 ;
pub.publish(vel_msg) ;
ros::spin();
}
ros::Publisher pub;
ros::Subscriber sub;
turtlesim::Pose pose;
int ch = 0;
};
int main(int argc,char** argv) {
Turtle turtle = Turtle(argc,argv);
turtle.move2goal();
return 0;
}
但是未调用 Update 回调函数,并且由于未更新姿势,乌龟绕圈运动。我尝试使用ROS_INFO调试问题,但没有任何效果。 我在这里做错了什么? 注意:由于stackoverflow的政策,一些功能的实现已从代码段中删除。
[输出] [1] [1]:https://i.stack.imgur.com/eL9Sr.png
解决方法
我认为您误解了睡眠的方式。与spin
不同,它实际上并不执行所有的ROS通信事件。这只是准确睡眠的一种便利。参见Difference between spin and rate.sleep in ROS。
幸运的是,修复非常简单,只需添加一个spinOnce
:
while( distance(goalPose) >= d && ros::ok()) {
// (..)
ros::spinOnce();
loop_rate.sleep();
}