Moveit!编程---magician机械臂

10 篇文章 11 订阅
5 篇文章 1 订阅

Moveit!编程接口(这里引用了古月老师讲的)

MoveIt!主要给用户提供了两种编程接口,一种Python的接口,另一种是C++的接口,这两种接口的使用非常类似,API基本上保持一致。编写流程:

主要代码:

首先,我们需要创建功能包:

catkin_creat_pkg magician_demo moveit_msgs moveit_ros_perception moveit_ros_planning_interface roscpp rospy trajectory_msgs magician_hardware dobot

正向运动学

C++
#include <ros/ros.h>
#include <moveit/move_group_interface/move_group_interface.h>
#include <iostream>
 
int main(int argc, char** argv)
{
    setlocale(LC_ALL,"");
	//初始化ROS节点
	ros::init(argc, argv, "magician_moveit_fk_demo");
 

	ros::AsyncSpinner spinner(1);
	spinner.start();
 
	//初始化需要使用move_group控制的机械臂中的arm_group
	moveit::planning_interface::MoveGroupInterface arm_magician("magician_arm");
 
	//设置机械臂运动的允许误差值(单位:弧度)
	arm_magician.setGoalJointTolerance(0.001);
	
	//设置允许的最大速度和加速度
	arm_magician.setMaxAccelerationScalingFactor(0.2);
	arm_magician.setMaxVelocityScalingFactor(0.2);
 
	//控制机械臂先回到初始化位置
	arm_magician.setNamedTarget("home");
	arm_magician.move();
    ROS_INFO("机械臂回到了初始位姿");
	sleep(1);
 
	//设置机械臂的目标位置,使用三轴的位置数据进行描述(单位:弧度)
	double targePose[3] = {0.52, 0.37, 0.47};
	std::vector<double> joint_group_position(3);
	joint_group_position[0] = targePose[0];
	joint_group_position[1] = targePose[1];
	joint_group_position[2] = targePose[2];

 
	//设置完成之后,控制机械臂完成运动
	arm_magician.setJointValueTarget(joint_group_position);
	arm_magician.move();
	sleep(1);
    ROS_INFO("机械臂进行正向运动学规划");
 
	//控制机械臂先回到初始化位置
	arm_magician.setNamedTarget("home");
	arm_magician.move();
    ROS_INFO("机械臂回到了初始位姿");
	sleep(1);
 
	//关闭并退出moveit
	ros::shutdown();
	
	return 0;
}
Python
import rospy, sys
import moveit_commander

class MoveItFkDemo:
    def __init__(self):
        # 初始化move_group的API
        moveit_commander.roscpp_initialize(sys.argv)

        # 初始化ROS节点
        rospy.init_node('moveit_fk_demo', anonymous=True)
 
        # 初始化需要使用move group控制的机械臂中的arm group
        arm = moveit_commander.MoveGroupCommander('magician_arm')
        
        # 设置机械臂运动的允许误差值
        arm.set_goal_joint_tolerance(0.001)

        # 设置允许的最大速度和加速度
        arm.set_max_acceleration_scaling_factor(0.5)
        arm.set_max_velocity_scaling_factor(0.5)
        
        # 控制机械臂先回到初始化位置
        arm.set_named_target('home')
        arm.go()
        rospy.sleep(1)
         
        # 设置机械臂的目标位置,使用六轴的位置数据进行描述(单位:弧度)
        joint_positions = [0.0, 1.052834, 0.454125]
        arm.set_joint_value_target(joint_positions)
                 
        # 控制机械臂完成运动
        arm.go()
        rospy.sleep(1)

        # 控制机械臂先回到初始化位置
        arm.set_named_target('home')
        arm.go()
        rospy.sleep(1)
        
        # 关闭并退出moveit
        moveit_commander.roscpp_shutdown()
        moveit_commander.os._exit(0)

if __name__ == "__main__":
    try:
        MoveItFkDemo()
    except rospy.ROSInterruptException:
        pass

逆向运动学:

C++
#include <string>
#include <ros/ros.h>
#include <moveit/move_group_interface/move_group_interface.h>

int main(int argc, char **argv)
{
    ros::init(argc, argv, "moveit_fk_demo");
    ros::AsyncSpinner spinner(1);
    spinner.start();

    moveit::planning_interface::MoveGroupInterface arm("magician_arm");

    //获取终端link的名称
    std::string end_effector_link = arm.getEndEffectorLink();

    //设置目标位置所使用的参考坐标系
    std::string reference_frame = "magician_origin";
    arm.setPoseReferenceFrame(reference_frame);

    //当运动规划失败后,允许重新规划
    arm.allowReplanning(true);

    //设置位置(单位:米)和姿态(单位:弧度)的允许误差
    arm.setGoalPositionTolerance(0.001);
    arm.setGoalOrientationTolerance(0.01);

    //设置允许的最大速度和加速度
    arm.setMaxAccelerationScalingFactor(0.2);
    arm.setMaxVelocityScalingFactor(0.2);

    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);

    // 设置机器人终端的目标位置
    geometry_msgs::Pose target_pose;
    target_pose.orientation.x = 0.0;
    target_pose.orientation.y = 0.0;
    target_pose.orientation.z = 0.0;
    target_pose.orientation.w = 0.1;
 
    target_pose.position.x = 0.13731;
    target_pose.position.y = -0.12658;
    target_pose.position.z = -0.03313;
    
    // 设置机器臂当前的状态作为运动初始状态
    arm.setStartStateToCurrentState();

    arm.setPoseTarget(target_pose);

    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
    moveit::planning_interface::MoveGroupInterface::Plan plan;
    moveit::planning_interface::MoveItErrorCode success = arm.plan(plan);

    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   

    //让机械臂按照规划的轨迹开始运动。
    if(success)
      arm.execute(plan);
    sleep(1);

    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);

    ros::shutdown(); 

    return 0;
}
Python
import rospy, sys
import moveit_commander
from geometry_msgs.msg import PoseStamped, Pose


class MoveItIkDemo:
    def __init__(self):
        # 初始化move_group的API
        moveit_commander.roscpp_initialize(sys.argv)
        
        # 初始化ROS节点
        rospy.init_node('moveit_ik_demo')
                
        # 初始化需要使用move group控制的机械臂中的arm group
        arm = moveit_commander.MoveGroupCommander('magician_arm')
                
        # 获取终端link的名称
        end_effector_link = arm.get_end_effector_link()
                        
        # 设置目标位置所使用的参考坐标系
        reference_frame = 'magician_origin'
        arm.set_pose_reference_frame(reference_frame)
                
        # 当运动规划失败后,允许重新规划
        arm.allow_replanning(True)
        
        # 设置位置(单位:米)和姿态(单位:弧度)的允许误差
        arm.set_goal_position_tolerance(0.001)
        arm.set_goal_orientation_tolerance(0.01)
       
        # 设置允许的最大速度和加速度
        arm.set_max_acceleration_scaling_factor(0.5)
        arm.set_max_velocity_scaling_factor(0.5)

        # 控制机械臂先回到初始化位置
        arm.set_named_target('home')
        arm.go()
        rospy.sleep(1)
               
        # 设置机械臂工作空间中的目标位姿,位置使用x、y、z坐标描述,
        # 姿态使用四元数描述,基于base_link坐标系
        target_pose = PoseStamped()
        target_pose.header.frame_id = reference_frame
        target_pose.header.stamp = rospy.Time.now()

        target_pose.pose.orientation.x = 0.0
        target_pose.pose.orientation.y = 0.0
        target_pose.pose.orientation.z = 0.0
        target_pose.pose.orientation.w = 0.1
        target_pose.pose.position.x = 0.13731
        target_pose.pose.position.y = -0.12658
        target_pose.pose.position.z = -0.03313

        
        # 设置机器臂当前的状态作为运动初始状态
        arm.set_start_state_to_current_state()
        
        # 设置机械臂终端运动的目标位姿
        arm.set_pose_target(target_pose, end_effector_link)
        
        # 规划运动路径
        traj = arm.plan()
        
        # 按照规划的运动路径控制机械臂运动
        arm.execute(traj,wait=True)
        rospy.sleep(1)

        # 控制机械臂回到初始化位置
        arm.set_named_target('home')
        arm.go()

        # 关闭并退出moveit
        moveit_commander.roscpp_shutdown()
        moveit_commander.os._exit(0)

if __name__ == "__main__":
    MoveItIkDemo()

    
    

Moveit!编程实战

1、控制夹爪的张开与闭合
#include "ros/ros.h"
#include "ros/console.h"
#include "dobot/SetEndEffectorGripper.h"
 
// 1 张开 0闭合
dobot::SetEndEffectorGripper gripflag(int n)
{
    dobot::SetEndEffectorGripper srv;
    if (n == 1) // 张开
    {
        srv.request.enableCtrl = 1;
        srv.request.grip = 0;
        srv.request.isQueued = 1;
    }
    else if (n == 0) // 闭合
    {
        srv.request.enableCtrl = 1;
        srv.request.grip = 1;
        srv.request.isQueued = 1;
    }
    else
    {
        srv.request.enableCtrl = 0;
        srv.request.grip = 0;
        srv.request.isQueued = 0;
    }
    return srv;
}
 
int main(int argc, char **argv)
{
    setlocale(LC_ALL, "");
    ros::init(argc, argv, "DobotGripperClient");
    ros::NodeHandle n;
 
    ros::ServiceClient client;
 
    // 设置夹爪开闭服务
    client = n.serviceClient<dobot::SetEndEffectorGripper>("/DobotServer/SetEndEffectorGripper");
 
    // 闭合
    auto srv = gripflag(0);
    // 张开
    auto srv1 = gripflag(1);
 
    if (client.call(srv1))
    {
        if (srv.response.result == 0)
        {
            ROS_INFO("夹爪已张开");
        }
        else
        {
            ROS_INFO("夹爪已张开");
        }
    }
    else
    {
        ROS_ERROR("Failed to call SetEndEffectorGripper service");
        return -1;
    }
 
    // 等待一段时间
    ros::Duration(2.0).sleep();
 
    if (client.call(srv))
    {
        if (srv.response.result == 0)
        {
            ROS_INFO("夹爪已闭合");
        }
        else
        {
            ROS_INFO("夹爪未能闭合");
        }
    }
    else
    {
        ROS_ERROR("Failed to call SetEndEffectorGripper service");
        return -1;
    }
 
    // 等待一段时间
    ros::Duration(2.0).sleep();
    //关闭控制器
    auto close = gripflag(2);
    client.call(close);
 
 
    ROS_INFO("资源已释放");
    ros::shutdown();
 
    return 0;
}
2、控制机械臂在笛卡尔空间下画圆
#include <math.h>
#include <ros/ros.h>
#include <moveit/move_group_interface/move_group_interface.h>
#include <moveit/robot_trajectory/robot_trajectory.h>
 
int main(int argc, char **argv)
{
	ros::init(argc, argv, "magician_circle_demo");
	ros::AsyncSpinner spinner(1);
	spinner.start();
 
    moveit::planning_interface::MoveGroupInterface arm("magician_arm");
 
    //获取终端link的名称
    std::string end_effector_link = arm.getEndEffectorLink();
 
    //设置目标位置所使用的参考坐标系
    std::string reference_frame = "magician_origin";
    arm.setPoseReferenceFrame(reference_frame);
 
    //当运动规划失败后,允许重新规划
    arm.allowReplanning(true);
 
    //设置位置(单位:米)和姿态(单位:弧度)的允许误差
    arm.setGoalPositionTolerance(0.0002);
    arm.setGoalOrientationTolerance(0.0001);
 
    //设置允许的最大速度和加速度
    arm.setMaxAccelerationScalingFactor(0.5);
    arm.setMaxVelocityScalingFactor(0.5);
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
    // 设置机器人终端的目标位置
    geometry_msgs::Pose target_pose;
    target_pose.orientation.x = 0;
    target_pose.orientation.y = 0;
    target_pose.orientation.z = 0;
    target_pose.orientation.w = 1;
 
    target_pose.position.x = 0.17075;
    target_pose.position.y = 0.0;
    target_pose.position.z = -0.041;
 
    //arm.setPoseTarget(target_pose);
    //arm.move();
 
	std::vector<geometry_msgs::Pose> waypoints;
 
    //将初始位姿加入路点列表
	//waypoints.push_back(target_pose);
 
    double centerA = target_pose.position.x;
    double centerB = target_pose.position.y;
    double radius = 0.04;
 
    for(double th=0.0; th<6.28; th=th+0.001)
    {
		target_pose.position.x = centerA + radius * sin(th);
        target_pose.position.y = centerB + radius * cos(th);
        waypoints.push_back(target_pose);
    }
 
	// 笛卡尔空间下的路径规划
	moveit_msgs::RobotTrajectory trajectory;
	const double jump_threshold = 0.0;
	const double eef_step = 0.0002;
	double fraction = 0.0;
    int maxtries = 100;   //最大尝试规划次数
    int attempts = 0;     //已经尝试规划次数
 
    while(fraction < 1.0 && attempts < maxtries)
    {
        fraction = arm.computeCartesianPath(waypoints, eef_step, jump_threshold, trajectory);
        attempts++;
        
        if(attempts % 10 == 0)
            ROS_INFO("Still trying after %d attempts...", attempts);
    }
    
    if(fraction == 1)
    {   
        ROS_INFO("Path computed successfully. Moving the arm.");
 
	    // 生成机械臂的运动规划数据
	    moveit::planning_interface::MoveGroupInterface::Plan plan;
	    plan.trajectory_ = trajectory;
 
	    // 执行运动
	    arm.execute(plan);
        sleep(1);
    }
    else
    {
        ROS_INFO("Path planning failed with only %0.6f success after %d attempts.", fraction, maxtries);
    }
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
	ros::shutdown(); 
	return 0;
}
3、Magician机械臂在ROS环境下的码垛
#include <string>
#include <ros/ros.h>
#include <moveit/move_group_interface/move_group_interface.h>
#include <iostream>
#include "dobot/SetEndEffectorGripper.h"
 
// 1 张开 0闭合
dobot::SetEndEffectorGripper gripflag(int n)
{
    dobot::SetEndEffectorGripper srv;
    if (n == 1) // 张开
    {
        srv.request.enableCtrl = 1;
        srv.request.grip = 0;
        srv.request.isQueued = 1;
    }
    else if (n == 0) // 闭合
    {
        srv.request.enableCtrl = 1;
        srv.request.grip = 1;
        srv.request.isQueued = 1;
    }
    else
    {
        srv.request.enableCtrl = 0;
        srv.request.grip = 0;
        srv.request.isQueued = 0;
    }
    return srv;
}
 
void close(ros::ServiceClient& client)
{
    auto close = gripflag(2);
    client.call(close);
 
}
 
void gripper(ros::ServiceClient& client,dobot::SetEndEffectorGripper& srv){
 
    std::string info[]={"闭合","张开"};
 
 if (client.call(srv))
    {
        if (srv.response.result == 1)
        {
            ROS_INFO(std::string("夹爪"+ info[srv.request.grip]).c_str());
        }
        else
        {
            ROS_INFO(std::string("夹爪"+info[1-srv.request.grip]).c_str());
        }
    }
    else
    {
        ROS_ERROR("Failed to call SetEndEffectorGripper service");
        return;
    }
 
}
 
geometry_msgs::Pose points(float x,float y,float z){
    geometry_msgs::Pose target_pose;
    target_pose.orientation.x = 0.0;
    target_pose.orientation.y = 0.0;
    target_pose.orientation.z = 0.0;
    target_pose.orientation.w = 0.1;
 
    target_pose.position.x = x;
    target_pose.position.y = y;
    target_pose.position.z = z;
 
    return target_pose;
}
 
 
int main(int argc, char **argv)
{
    setlocale(LC_ALL, "");
    ros::init(argc, argv, "magician_palletizing");
    ros::AsyncSpinner spinner(1);
    spinner.start();
 
    ros::NodeHandle n;
 
    ros::ServiceClient client;
    // 设置夹爪开闭服务
    client = n.serviceClient<dobot::SetEndEffectorGripper>("/DobotServer/SetEndEffectorGripper");
    // 闭合
    auto srv = gripflag(0);
    // 张开
    auto srv1 = gripflag(1);
 
    moveit::planning_interface::MoveGroupInterface arm("magician_arm");
 
    //获取终端link的名称
    std::string end_effector_link = arm.getEndEffectorLink();
 
    //设置目标位置所使用的参考坐标系
    std::string reference_frame = "magician_origin";
    arm.setPoseReferenceFrame(reference_frame);
 
    //当运动规划失败后,允许重新规划
    arm.allowReplanning(true);
 
    //设置位置(单位:米)和姿态(单位:弧度)的允许误差
    arm.setGoalPositionTolerance(0.0002);
    arm.setGoalOrientationTolerance(0.001);
 
    //设置允许的最大速度和加速度
    arm.setMaxAccelerationScalingFactor(0.8);
    arm.setMaxVelocityScalingFactor(0.8);
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
    //张开
    gripper(client,srv1);
 
    // 设置机器人终端的目标位置
    // geometry_msgs::Pose target_pose;
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = -0.12658;
    // target_pose.position.z = -0.01313;
 
     // 设置机器人终端的目标位置
    auto point0 = points(0.13731,-0.12658,0.01);
 
    // 设置机器臂当前的状态作为运动初始状态
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point0);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
    moveit::planning_interface::MoveGroupInterface::Plan plan;
    moveit::planning_interface::MoveItErrorCode success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = -0.12658;
    // target_pose.position.z = -0.03313;
    
    auto point1 = points(0.13731,-0.12658,-0.01313);
 
 
    // 设置机器臂当前的状态作为运动初始状态
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point1);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    // 等待一段时间
    ros::Duration(1.0).sleep();
    // 闭合
    gripper(client,srv);
 
    ros::Duration(1.0).sleep();
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = 0.13265;
    // target_pose.position.z = -0.03313;
 
    auto point2 = points(0.13731,0.13265,-0.03813);
 
 
    // 设置机器臂当前的状态作为运动初始状态
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point2);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
    //张开
    gripper(client,srv1);
 
    ros::Duration(1.0).sleep();
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = 0.13265;
    // target_pose.position.z = -0.01313;
 
    auto point3 = points(0.13731,0.13265,0);
 
 
    // 设置机器臂当前的状态作为运动初始状态
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point3);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	  success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
    
    //闭合
    gripper(client,srv);
    ros::Duration(1.0).sleep();
//
    //控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
    //张开
    gripper(client,srv1);
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = -0.15265;
    // target_pose.position.z = -0.01313;
 
    auto point4 = points(0.12731,-0.16265,-0.01313);
    
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point4);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
 
     // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = -0.15265;
    // target_pose.position.z = -0.03313;
 
    auto point5 = points(0.12731,-0.16265,-0.04313);
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point5);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(0.5).sleep();
    //闭合
    gripper(client,srv);
 
    ros::Duration(1.0).sleep();
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = -0.15265;
    // target_pose.position.z = -0.01313;
 
    auto point6 = points(0.13731,-0.15265,-0.01313);
 
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point6);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
    ros::Duration(1.0).sleep();
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = 0.15265;
    // target_pose.position.z = -0.03313;
 
    auto point7 = points(0.11731,0.11265,-0.04013);
 
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point7);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(0.5).sleep();
   //张开 
    gripper(client,srv1);
 
    ros::Duration(1.0).sleep();
 
    // 设置机器人终端的目标位置
    // target_pose.orientation.x = 0.0;
    // target_pose.orientation.y = 0.0;
    // target_pose.orientation.z = 0.0;
    // target_pose.orientation.w = 0.1;
 
    // target_pose.position.x = 0.13731;
    // target_pose.position.y = 0.15265;
    // target_pose.position.z = -0.01313;
 
    auto point8 = points(0.11731,0.11265,-0.01313);
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point8);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
//
    auto point9 = points(0.13731,-0.12658,-0.01313);
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point9);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	  success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
 
    auto point10 = points(0.13731,-0.12658,-0.04313);
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point10);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
    //闭合
    gripper(client,srv);
 
    ros::Duration(1.0).sleep();
 
    auto point11 = points(0.13731,0.13265,0.01313);
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point11);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
 
    auto point12 = points(0.13731,0.13265,-0.01813);
 
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point12);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
    //张开
    gripper(client,srv1);
 
    ros::Duration(1.0).sleep();
 
    auto point13 = points(0.13731,0.13265,0.00313);
 
 
    arm.setStartStateToCurrentState();
 
    arm.setPoseTarget(point13);
 
    // 进行运动规划,计算机器人移动到目标的运动轨迹,此时只是计算出轨迹,并不会控制机械臂运动
	success = arm.plan(plan);
 
    ROS_INFO("Plan (pose goal) %s",success?"":"FAILED");   
 
    //让机械臂按照规划的轨迹开始运动。
    if(success){
      arm.execute(plan);
    sleep(1);
    }
 
    ros::Duration(1.0).sleep();
 
    // 控制机械臂先回到初始化位置
    arm.setNamedTarget("home");
    arm.move();
    sleep(1);
 
    ros::Duration(1.0).sleep();
 
 
 
 
    //关闭控制器
    close(client);
    ros::shutdown(); 
 
    return 0;
}
4、控制气泵
#include <string>
#include <ros/ros.h>
#include <moveit/move_group_interface/move_group_interface.h>
#include <iostream>
#include "magician_hardware/SetEndEffectorSuctionCup.h"
 
int main(int argc, char **argv)
{
    ros::init(argc, argv, "control_suction_cup_demo");
    ros::AsyncSpinner spinner(1);
    spinner.start();
 
    ros::NodeHandle n;
 
ros::ServiceClient client;
	client = n.serviceClient<magician_hardware::SetEndEffectorSuctionCup>("/DobotServer/SetEndEffectorSuctionCup");
	//设置气泵吸取suck1
	magician_hardware::SetEndEffectorSuctionCup suck1;
	suck1.request.enableCtrl = 1;
	suck1.request.suck =1;
	suck1.request.isQueued = true;
	//设置气泵关闭suck2
	magician_hardware::SetEndEffectorSuctionCup suck2;
	suck2.request.enableCtrl = 0;
	suck2.request.suck =0;
	suck2.request.isQueued = true;



	//开启气泵吸气---关闭夹爪
	client.call(suck1);
 
 
	//关闭气泵
	client.call(suck2);

    ros::shutdown();

    return 0;
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

没入&浅出

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值