本文整理汇总了C++中actionlib::SimpleActionClient::sendGoal方法的典型用法代码示例。如果您正苦于以下问题:C++ SimpleActionClient::sendGoal方法的具体用法?C++ SimpleActionClient::sendGoal怎么用?C++ SimpleActionClient::sendGoal使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类actionlib::SimpleActionClient
的用法示例。
在下文中一共展示了SimpleActionClient::sendGoal方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: rt_arm_request_tool_pose_wrt_torso
int ArmMotionCommander::rt_arm_request_tool_pose_wrt_torso(void) {
// debug: compare this to output of:
//rosrun tf tf_echo torso yale_gripper_frame
ROS_INFO("requesting right-arm tool pose");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_GET_TOOL_POSE;
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(2.0));
if (!finished_before_timeout_) {
ROS_WARN("did not respond within timeout");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("move did not return success; code = %d",cart_result_.return_code);
return (int) cart_result_.return_code;
}
tool_pose_stamped_ = cart_result_.current_pose_gripper_right;
ROS_INFO("move returned success; right arm tool pose: ");
ROS_INFO("origin w/rt torso = %f, %f, %f ",tool_pose_stamped_.pose.position.x,
tool_pose_stamped_.pose.position.y,tool_pose_stamped_.pose.position.z);
ROS_INFO("quaternion x,y,z,w: %f, %f, %f, %f",tool_pose_stamped_.pose.orientation.x,
tool_pose_stamped_.pose.orientation.y,tool_pose_stamped_.pose.orientation.z,
tool_pose_stamped_.pose.orientation.w);
return (int) cart_result_.return_code;
}
示例2: rt_arm_plan_jspace_path_current_to_qgoal
int ArmMotionCommander::rt_arm_plan_jspace_path_current_to_qgoal(Eigen::VectorXd q_des_vec) {
ROS_INFO("requesting a joint-space motion plan");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_PLAN_JSPACE_PATH_CURRENT_TO_QGOAL;
cart_goal_.q_goal_right.resize(7);
for (int i=0;i<7;i++) cart_goal_.q_goal_right[i] = q_des_vec[i]; //specify the goal js pose
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(2.0));
ROS_INFO("return code: %d",cart_result_.return_code);
if (!finished_before_timeout_) {
ROS_WARN("giving up waiting on result");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
ROS_INFO("finished before timeout");
if (cart_result_.return_code==cwru_action::cwru_baxter_cart_moveResult::RT_ARM_PATH_NOT_VALID) {
ROS_WARN("right arm plan not valid");
return (int) cart_result_.return_code;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("unknown return code... not SUCCESS");
return (int) cart_result_.return_code;
}
//here if success return code
ROS_INFO("returned SUCCESS from planning request");
computed_arrival_time_= cart_result_.computed_arrival_time; //action_client.get_computed_arrival_time();
ROS_INFO("computed move time: %f",computed_arrival_time_);
return (int) cart_result_.return_code;
}
示例3: rt_arm_plan_path_current_to_goal_pose
int ArmMotionCommander::rt_arm_plan_path_current_to_goal_pose(geometry_msgs::PoseStamped des_pose) {
ROS_INFO("requesting a cartesian-space motion plan");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_PLAN_PATH_CURRENT_TO_GOAL_POSE;
cart_goal_.des_pose_gripper_right = des_pose;
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(2.0));
ROS_INFO("return code: %d",cart_result_.return_code);
if (!finished_before_timeout_) {
ROS_WARN("giving up waiting on result");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
ROS_INFO("finished before timeout");
if (cart_result_.return_code==cwru_action::cwru_baxter_cart_moveResult::RT_ARM_PATH_NOT_VALID) {
ROS_WARN("right arm plan not valid");
return (int) cart_result_.return_code;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("unknown return code... not SUCCESS");
return (int) cart_result_.return_code;
}
//here if success return code
ROS_INFO("returned SUCCESS from planning request");
computed_arrival_time_= cart_result_.computed_arrival_time; //action_client.get_computed_arrival_time();
ROS_INFO("computed move time: %f",computed_arrival_time_);
return (int) cart_result_.return_code;
}
示例4: rt_arm_plan_path_current_to_goal_dp_xyz
int ArmMotionCommander::rt_arm_plan_path_current_to_goal_dp_xyz(Eigen::Vector3d dp_displacement) {
ROS_INFO("requesting a cartesian-space motion plan along vector");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_PLAN_PATH_CURRENT_TO_GOAL_DP_XYZ;
//must fill in desired vector displacement
cart_goal_.arm_dp_right.resize(3);
for (int i=0;i<3;i++) cart_goal_.arm_dp_right[i] = dp_displacement[i];
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(2.0));
ROS_INFO("return code: %d",cart_result_.return_code);
if (!finished_before_timeout_) {
ROS_WARN("giving up waiting on result");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
ROS_INFO("finished before timeout");
if (cart_result_.return_code==cwru_action::cwru_baxter_cart_moveResult::RT_ARM_PATH_NOT_VALID) {
ROS_WARN("right arm plan not valid");
return (int) cart_result_.return_code;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("unknown return code... not SUCCESS");
return (int) cart_result_.return_code;
}
//here if success return code
ROS_INFO("returned SUCCESS from planning request");
computed_arrival_time_= cart_result_.computed_arrival_time; //action_client.get_computed_arrival_time();
ROS_INFO("computed move time: %f",computed_arrival_time_);
return (int) cart_result_.return_code;
}
示例5: BlockManipulationAction
BlockManipulationAction() :
block_detection_action_("block_detection", true),
interactive_manipulation_action_("interactive_manipulation", true),
pick_and_place_action_("pick_and_place", true),
reset_arm_action_("reset_arm", true)
{
// Load parameters
nh_.param<std::string>("/block_manipulation_action_demo/arm_link", arm_link, "/base_link");
nh_.param<double>("/block_manipulation_action_demo/gripper_open", gripper_open, 0.042);
nh_.param<double>("/block_manipulation_action_demo/gripper_closed", gripper_closed, 0.024);
nh_.param<double>("/block_manipulation_action_demo/z_up", z_up, 0.12);
nh_.param<double>("/block_manipulation_action_demo/table_height", z_down, 0.01);
nh_.param<double>("/block_manipulation_action_demo/block_size", block_size, 0.03);
nh_.param<bool>("once", once, false);
ROS_INFO("Block size %f", block_size);
ROS_INFO("Table height %f", z_down);
// Initialize goals
block_detection_goal_.frame = arm_link;
block_detection_goal_.table_height = z_down;
block_detection_goal_.block_size = block_size;
pick_and_place_goal_.frame = arm_link;
pick_and_place_goal_.z_up = z_up;
pick_and_place_goal_.gripper_open = gripper_open;
pick_and_place_goal_.gripper_closed = gripper_closed;
pick_and_place_goal_.topic = pick_and_place_topic;
interactive_manipulation_goal_.block_size = block_size;
interactive_manipulation_goal_.frame = arm_link;
ROS_INFO("Finished initializing, waiting for servers...");
block_detection_action_.waitForServer();
ROS_INFO("Found block detection server.");
interactive_manipulation_action_.waitForServer();
ROS_INFO("Found interactive manipulation.");
pick_and_place_action_.waitForServer();
ROS_INFO("Found pick and place server.");
ROS_INFO("Found servers.");
reset_arm_action_.sendGoal(simple_arm_actions::ResetArmGoal());
ROS_INFO("Reseted arm action.");
detectBlocks();
}
示例6: pickAndPlace
void pickAndPlace(const actionlib::SimpleClientGoalState& state, const InteractiveBlockManipulationResultConstPtr& result)
{
ROS_INFO("Got interactive marker callback. Picking and placing.");
if (state == actionlib::SimpleClientGoalState::SUCCEEDED)
ROS_INFO("Succeeded!");
else
{
ROS_INFO("Did not succeed! %s", state.toString().c_str());
ros::shutdown();
}
pick_and_place_action_.sendGoal(pick_and_place_goal_, boost::bind( &BlockManipulationAction::finish, this, _1, _2));
}
示例7: send_test_goal
void ArmMotionCommander::send_test_goal(void) {
ROS_INFO("sending a test goal");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::ARM_TEST_MODE;
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(2.0));
//bool finished_before_timeout = action_client.waitForResult(); // wait forever...
if (!finished_before_timeout_) {
ROS_WARN("giving up waiting on result");
} else {
ROS_INFO("finished before timeout");
ROS_INFO("return code: %d",cart_result_.return_code);
}
}
示例8: addBlocks
void addBlocks(const actionlib::SimpleClientGoalState& state, const BlockDetectionResultConstPtr& result)
{
ROS_INFO("Got block detection callback. Adding blocks.");
geometry_msgs::Pose block;
if (state == actionlib::SimpleClientGoalState::SUCCEEDED)
ROS_INFO("Succeeded!");
else
{
ROS_INFO("Did not succeed! %s", state.toString().c_str());
ros::shutdown();
}
interactive_manipulation_action_.sendGoal(interactive_manipulation_goal_, boost::bind( &BlockManipulationAction::pickAndPlace, this, _1, _2));
}
示例9: finish
void finish(const actionlib::SimpleClientGoalState& state, const PickAndPlaceResultConstPtr& result)
{
ROS_INFO("Got pick and place callback. Finished!");
if (state == actionlib::SimpleClientGoalState::SUCCEEDED)
ROS_INFO("Succeeded!");
else
ROS_INFO("Did not succeed! %s", state.toString().c_str());
reset_arm_action_.sendGoal(simple_arm_actions::ResetArmGoal());
if (once)
ros::shutdown();
else
detectBlocks();
}
示例10: rt_arm_execute_planned_path
int ArmMotionCommander::rt_arm_execute_planned_path(void) {
ROS_INFO("requesting execution of planned path");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_EXECUTE_PLANNED_PATH;
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(computed_arrival_time_+2.0));
if (!finished_before_timeout_) {
ROS_WARN("did not complete move in expected time");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("move did not return success; code = %d",cart_result_.return_code);
return (int) cart_result_.return_code;
}
ROS_INFO("move returned success");
return (int) cart_result_.return_code;
}
示例11: execute_planned_move
void ArmMotionInterface::execute_planned_move(void) {
if (!path_is_valid_) {
cart_result_.return_code = cartesian_planner::cart_moveResult::PATH_NOT_VALID;
ROS_WARN("attempted to execute invalid path!");
cart_move_as_.setAborted(cart_result_); // tell the client we have given up on this goal; send the result message as well
return;
}
// convert path to a trajectory:
//baxter_traj_streamer_.stuff_trajectory(optimal_path_, des_trajectory_); //convert from vector of poses to trajectory message
js_goal_.trajectory = des_trajectory_;
//computed_arrival_time_ = des_trajectory_.points.back().time_from_start.toSec();
ROS_INFO("sending action request to traj streamer node");
ROS_INFO("computed arrival time is %f", computed_arrival_time_);
busy_working_on_a_request_ = true;
g_js_doneCb_flag = 0;
traj_streamer_action_client_.sendGoal(js_goal_, boost::bind(&ArmMotionInterface::js_doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
ROS_INFO("waiting on trajectory streamer...");
while (g_js_doneCb_flag == 0) {
ROS_INFO("...");
ros::Duration(1.0).sleep();
ros::spinOnce();
}
//finished_before_timeout_ = traj_streamer_action_client_.waitForResult(ros::Duration(computed_arrival_time_ + 2.0));
/*
if (!finished_before_timeout_) {
ROS_WARN("EXECUTE_PLANNED_PATH: giving up waiting on result");
cart_result_.return_code = cartesian_planner::cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
cart_move_as_.setSucceeded(cart_result_); //could say "aborted"
} else {
* */
ROS_INFO("finished before timeout");
cart_result_.return_code = cartesian_planner::cart_moveResult::SUCCESS;
cart_move_as_.setSucceeded(cart_result_);
//}
path_is_valid_ = false; // reset--require new path before next move
busy_working_on_a_request_ = false;
//save the last point commanded, for future reference
std::vector <double> last_pt;
last_pt = des_trajectory_.points.back().positions;
int njnts = last_pt.size();
for (int i = 0; i < njnts; i++) {
last_arm_jnt_cmd_[i] = last_pt[i];
}
}
示例12: turn
void turn() {
turtlebot_actions::TurtlebotMoveGoal goal;
goal.forward_distance = 0;
goal.turn_distance = M_PI;
action_client.waitForServer();
action_client.sendGoal(goal);
//wait for the action to return
bool finished_before_timeout = action_client.waitForResult(
ros::Duration(30.0));
if (finished_before_timeout) {
actionlib::SimpleClientGoalState state = action_client.getState();
ROS_INFO("Action finished: %s", state.toString().c_str());
} else
ROS_INFO("Action did not finish before the time out.");
}
示例13: rt_arm_request_q_data
//send goal command to request right-arm joint angles; these will be stored in internal variable
int ArmMotionCommander::rt_arm_request_q_data(void) {
ROS_INFO("requesting right-arm joint angles");
cart_goal_.command_code = cwru_action::cwru_baxter_cart_moveGoal::RT_ARM_GET_Q_DATA;
cart_move_action_client_.sendGoal(cart_goal_, boost::bind(&ArmMotionCommander::doneCb_, this, _1, _2)); // we could also name additional callback functions here, if desired
finished_before_timeout_ = cart_move_action_client_.waitForResult(ros::Duration(computed_arrival_time_+2.0));
if (!finished_before_timeout_) {
ROS_WARN("did not respond within timeout");
return (int) cwru_action::cwru_baxter_cart_moveResult::NOT_FINISHED_BEFORE_TIMEOUT;
}
if (cart_result_.return_code!=cwru_action::cwru_baxter_cart_moveResult::SUCCESS) {
ROS_WARN("move did not return success; code = %d",cart_result_.return_code);
return (int) cart_result_.return_code;
}
q_vec_ = cart_result_.q_arm_right;
ROS_INFO("move returned success; right arm angles: ");
ROS_INFO("%f; %f; %f; %f; %f; %f; %f",q_vec_[0],q_vec_[1],q_vec_[2],q_vec_[3],q_vec_[4],q_vec_[5],q_vec_[6]);
return (int) cart_result_.return_code;
}
示例14: moveGoalCB
// move platform server receives a new goal
void moveGoalCB()
{
set_terminal_state_ = true;
move_goal_.nav_goal = as_.acceptNewGoal()->nav_goal;
ROS_INFO_STREAM_NAMED(logger_name_, "Received Goal #" <<move_goal_.nav_goal.header.seq);
if (as_.isPreemptRequested() ||!ros::ok())
{
ROS_WARN_STREAM_NAMED(logger_name_, "Preempt Requested on goal #" << move_goal_.nav_goal.header.seq);
if (planning_)
ac_planner_.cancelGoalsAtAndBeforeTime(ros::Time::now());
if (controlling_)
ac_control_.cancelGoalsAtAndBeforeTime(ros::Time::now());
move_result_.result_state = 0;
move_result_.error_string = "Preempt Requested!!!";
as_.setPreempted(move_result_);
return;
}
// Convert move goal to plan goal
pose_goal_.pose_goal = move_goal_.nav_goal;
if (planner_state_sub.getNumPublishers()==0)
{
ROS_WARN_STREAM_NAMED(logger_name_, "Goal #" << move_goal_.nav_goal.header.seq << " not sent - planner is down");
planning_ = false;
move_result_.result_state = 0;
move_result_.error_string = "Planner is down";
as_.setAborted(move_result_);
}
else
{
ac_planner_.sendGoal(pose_goal_, boost::bind(&MovePlatformAction::planningDoneCB, this, _1, _2),
actionlib::SimpleActionClient<oea_planner::planAction>::SimpleActiveCallback(),
actionlib::SimpleActionClient<oea_planner::planAction>::SimpleFeedbackCallback());
planning_ = true;
ROS_DEBUG_STREAM_NAMED(logger_name_, "Goal #" << move_goal_.nav_goal.header.seq << " sent to planner");
}
return;
}
示例15: planningDoneCB
void planningDoneCB(const actionlib::SimpleClientGoalState& state, const oea_planner::planResultConstPtr &result)
{
planning_ = false;
ROS_DEBUG_STREAM_NAMED(logger_name_, "Plan Action finished: " << state.toString());
move_result_.result_state = result->result_state;
if (move_result_.result_state) //if plan OK
{
planned_path_goal_.plan_goal = result->planned_path; // goal for the controller is result of the planner
if (ctrl_state_sub.getNumPublishers()==0)
{
ROS_WARN_STREAM_NAMED(logger_name_, "Goal #" << move_goal_.nav_goal.header.seq << " not sent - Controller is down");
controlling_ = false;
move_result_.result_state = 0;
move_result_.error_string = "Controller is down!!!";
as_.setAborted(move_result_);
}
else
{
ac_control_.sendGoal(planned_path_goal_, boost::bind(&MovePlatformAction::ControlDoneCB, this, _1, _2),
actionlib::SimpleActionClient<oea_controller::controlPlatformAction>::SimpleActiveCallback(),
actionlib::SimpleActionClient<oea_controller::controlPlatformAction>::SimpleFeedbackCallback()); //boost::bind(&MovePlatformAction::ControlFeedbackCB, this,_1));
controlling_ = true;
ROS_DEBUG_STREAM_NAMED(logger_name_,"Goal #" << move_goal_.nav_goal.header.seq << " sent to Controller");
}
}
else //if plan NOT OK
{
ac_control_.cancelGoalsAtAndBeforeTime(ros::Time::now());
move_result_.error_string = "Planning Failed: " + result->error_string;
ROS_WARN_STREAM_NAMED(logger_name_, "Aborting because " << move_result_.error_string);
as_.setAborted(move_result_);
}
return;
}