reinstate gohome in sim and webcontrol
This commit is contained in:
parent
42d990676c
commit
845742767b
@ -46,12 +46,18 @@ function launch() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
gohomeT=100
|
gohomeT=100
|
||||||
function stop() {
|
function goinghome() {
|
||||||
BVMSTATE = "STOP"
|
BVMSTATE = "GOHOME"
|
||||||
if(gohomeT > 0) { # TODO: Make a real check if home is reached
|
if(gohomeT > 0) { # TODO: Make a real check if home is reached
|
||||||
gohome()
|
gohome()
|
||||||
gohomeT = gohomeT - 1
|
gohomeT = gohomeT - 1
|
||||||
}
|
neighbors.broadcast("cmd", 20)
|
||||||
|
} else
|
||||||
|
BVMSTATE = AUTO_LAUNCH_STATE
|
||||||
|
}
|
||||||
|
|
||||||
|
function stop() {
|
||||||
|
BVMSTATE = "STOP"
|
||||||
if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so LAND
|
if(V_TYPE == 0 or V_TYPE == 1) { # flying vehicle so LAND
|
||||||
neighbors.broadcast("cmd", 21)
|
neighbors.broadcast("cmd", 21)
|
||||||
uav_land()
|
uav_land()
|
||||||
@ -67,7 +73,7 @@ function stop() {
|
|||||||
|
|
||||||
function take_picture() {
|
function take_picture() {
|
||||||
BVMSTATE="PICTURE"
|
BVMSTATE="PICTURE"
|
||||||
uav_setgimbal(0.0, 0.0, -90.0, 20.0)
|
setgimbal(0.0, 0.0, -90.0, 20.0)
|
||||||
if(pic_time==PICTURE_WAIT/2) { # wait for the drone to stabilize
|
if(pic_time==PICTURE_WAIT/2) { # wait for the drone to stabilize
|
||||||
takepicture()
|
takepicture()
|
||||||
} else if(pic_time>=PICTURE_WAIT) { # wait for the picture
|
} else if(pic_time>=PICTURE_WAIT) { # wait for the picture
|
||||||
@ -180,18 +186,25 @@ function rc_cmd_listen() {
|
|||||||
} else if(flight.rc_cmd==21) {
|
} else if(flight.rc_cmd==21) {
|
||||||
log("cmd 21")
|
log("cmd 21")
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
BVMSTATE = "STOP"
|
AUTO_LAUNCH_STATE = "STOP"
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
neighbors.broadcast("cmd", 21)
|
neighbors.broadcast("cmd", 21)
|
||||||
|
} else if(flight.rc_cmd==20) {
|
||||||
|
log("cmd 20")
|
||||||
|
flight.rc_cmd=0
|
||||||
|
AUTO_LAUNCH_STATE = "IDLE"
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
|
neighbors.broadcast("cmd", 20)
|
||||||
} else if(flight.rc_cmd==16) {
|
} else if(flight.rc_cmd==16) {
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
BVMSTATE = "PATHPLAN"
|
BVMSTATE = "PATHPLAN"
|
||||||
} else if(flight.rc_cmd==400) {
|
} else if(flight.rc_cmd==400) {
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
uav_arm()
|
arm()
|
||||||
neighbors.broadcast("cmd", 400)
|
neighbors.broadcast("cmd", 400)
|
||||||
} else if (flight.rc_cmd==401){
|
} else if (flight.rc_cmd==401){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
uav_disarm()
|
disarm()
|
||||||
neighbors.broadcast("cmd", 401)
|
neighbors.broadcast("cmd", 401)
|
||||||
} else if (flight.rc_cmd==666){
|
} else if (flight.rc_cmd==666){
|
||||||
flight.rc_cmd=0
|
flight.rc_cmd=0
|
||||||
@ -230,12 +243,16 @@ function nei_cmd_listen() {
|
|||||||
if(BVMSTATE!="BARRIERWAIT") {
|
if(BVMSTATE!="BARRIERWAIT") {
|
||||||
if(value==22) {
|
if(value==22) {
|
||||||
BVMSTATE = "LAUNCH"
|
BVMSTATE = "LAUNCH"
|
||||||
|
}else if(value==20) {
|
||||||
|
AUTO_LAUNCH_STATE = "IDLE"
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
} else if(value==21) {
|
} else if(value==21) {
|
||||||
BVMSTATE = "STOP"
|
AUTO_LAUNCH_STATE = "STOP"
|
||||||
|
BVMSTATE = "GOHOME"
|
||||||
} else if(value==400 and BVMSTATE=="TURNEDOFF") {
|
} else if(value==400 and BVMSTATE=="TURNEDOFF") {
|
||||||
uav_arm()
|
arm()
|
||||||
} else if(value==401 and BVMSTATE=="TURNEDOFF"){
|
} else if(value==401 and BVMSTATE=="TURNEDOFF"){
|
||||||
uav_disarm()
|
disarm()
|
||||||
} else if(value==900){ # Shapes
|
} else if(value==900){ # Shapes
|
||||||
barrier_set(ROBOTS, "TASK_ALLOCATE", BVMSTATE, 900)
|
barrier_set(ROBOTS, "TASK_ALLOCATE", BVMSTATE, 900)
|
||||||
#barrier_ready(900)
|
#barrier_ready(900)
|
||||||
|
@ -20,7 +20,7 @@ mapgoal = {}
|
|||||||
function navigate() {
|
function navigate() {
|
||||||
BVMSTATE="NAVIGATE"
|
BVMSTATE="NAVIGATE"
|
||||||
if(V_TYPE == 0) { # TODO: place these in a generic function in conversion.bzz
|
if(V_TYPE == 0) { # TODO: place these in a generic function in conversion.bzz
|
||||||
uav_storegoal(goal_list[g_it].x, goal_list[g_it].y, pose.position.altitude)
|
storegoal(goal_list[g_it].x, goal_list[g_it].y, pose.position.altitude)
|
||||||
cur_goal = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0)
|
cur_goal = vec_from_gps(rc_goto.latitude, rc_goto.longitude, 0)
|
||||||
m_pos = math.vec2.scale(vec_from_gps(homegps.lat, homegps.long, 0),-1)
|
m_pos = math.vec2.scale(vec_from_gps(homegps.lat, homegps.long, 0),-1)
|
||||||
}
|
}
|
||||||
|
@ -53,6 +53,8 @@ function step() {
|
|||||||
statef=stop
|
statef=stop
|
||||||
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
else if(BVMSTATE=="LAUNCH") # ends on AUTO_LAUNCH_STATE
|
||||||
statef=launch
|
statef=launch
|
||||||
|
else if(BVMSTATE=="GOHOME") # ends on AUTO_LAUNCH_STATE
|
||||||
|
statef=goinghome
|
||||||
else if(BVMSTATE=="IDLE")
|
else if(BVMSTATE=="IDLE")
|
||||||
statef=idle
|
statef=idle
|
||||||
else if(BVMSTATE=="AGGREGATE")
|
else if(BVMSTATE=="AGGREGATE")
|
||||||
|
@ -13,19 +13,6 @@
|
|||||||
|
|
||||||
namespace buzzuav_closures
|
namespace buzzuav_closures
|
||||||
{
|
{
|
||||||
typedef enum {
|
|
||||||
COMMAND_NIL = 0, // Dummy command
|
|
||||||
COMMAND_TAKEOFF, // Take off
|
|
||||||
COMMAND_LAND,
|
|
||||||
COMMAND_GOHOME,
|
|
||||||
COMMAND_ARM,
|
|
||||||
COMMAND_DISARM,
|
|
||||||
COMMAND_GOTO,
|
|
||||||
COMMAND_MOVETO,
|
|
||||||
COMMAND_PICTURE,
|
|
||||||
COMMAND_GIMBAL,
|
|
||||||
} Custom_CommandCode;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* prextern int() function in Buzz
|
* prextern int() function in Buzz
|
||||||
* This function is used to print data from buzz
|
* This function is used to print data from buzz
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
<node name="rosbuzz_node" pkg="rosbuzz" type="rosbuzz_node" respawn="false" output="screen" >
|
<node name="rosbuzz_node" pkg="rosbuzz" type="rosbuzz_node" respawn="false" output="screen" >
|
||||||
<rosparam file="$(find rosbuzz)/launch/launch_config/topics.yaml"/>
|
<rosparam file="$(find rosbuzz)/launch/launch_config/topics.yaml"/>
|
||||||
<param name="bzzfile_name" value="$(find rosbuzz)/buzz_scripts/$(arg script).bzz" />
|
<param name="bzzfile_name" value="$(find rosbuzz)/buzz_scripts/$(arg script).bzz" />
|
||||||
<param name="debug" value="true" />
|
<param name="debug" value="false" />
|
||||||
<param name="rcclient" value="true" />
|
<param name="rcclient" value="true" />
|
||||||
<param name="rcservice_name" value="buzzcmd" />
|
<param name="rcservice_name" value="buzzcmd" />
|
||||||
<param name="in_payload" value="inMavlink"/>
|
<param name="in_payload" value="inMavlink"/>
|
||||||
|
@ -230,7 +230,7 @@ int buzzuav_moveto(buzzvm_t vm)
|
|||||||
// DEBUG
|
// DEBUG
|
||||||
// ROS_WARN("[%i] Buzz requested Move To: x: %.7f , y: %.7f, z: %.7f", (int)buzz_utility::get_robotid(), goto_pos[0],
|
// ROS_WARN("[%i] Buzz requested Move To: x: %.7f , y: %.7f, z: %.7f", (int)buzz_utility::get_robotid(), goto_pos[0],
|
||||||
// goto_pos[1], goto_pos[2]);
|
// goto_pos[1], goto_pos[2]);
|
||||||
buzz_cmd = COMMAND_MOVETO; // TODO: standard mavros?
|
buzz_cmd = mavros_msgs::CommandCode::NAV_SPLINE_WAYPOINT;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,7 +331,7 @@ int buzzuav_takepicture(buzzvm_t vm)
|
|||||||
/ Buzz closure to take a picture here.
|
/ Buzz closure to take a picture here.
|
||||||
/----------------------------------------*/
|
/----------------------------------------*/
|
||||||
{
|
{
|
||||||
buzz_cmd = COMMAND_PICTURE;
|
buzz_cmd = mavros_msgs::CommandCode::IMAGE_START_CAPTURE;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -355,7 +355,7 @@ int buzzuav_setgimbal(buzzvm_t vm)
|
|||||||
rc_gimbal[3] = buzzvm_stack_at(vm, 1)->f.value;
|
rc_gimbal[3] = buzzvm_stack_at(vm, 1)->f.value;
|
||||||
|
|
||||||
ROS_INFO("Set RC_GIMBAL ---- %f %f %f (%f)", rc_gimbal[0], rc_gimbal[1], rc_gimbal[2], rc_gimbal[3]);
|
ROS_INFO("Set RC_GIMBAL ---- %f %f %f (%f)", rc_gimbal[0], rc_gimbal[1], rc_gimbal[2], rc_gimbal[3]);
|
||||||
buzz_cmd = COMMAND_GIMBAL;
|
buzz_cmd = mavros_msgs::CommandCode::DO_MOUNT_CONTROL;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -402,7 +402,7 @@ int buzzuav_arm(buzzvm_t vm)
|
|||||||
{
|
{
|
||||||
cur_cmd = mavros_msgs::CommandCode::COMPONENT_ARM_DISARM;
|
cur_cmd = mavros_msgs::CommandCode::COMPONENT_ARM_DISARM;
|
||||||
printf(" Buzz requested Arm \n");
|
printf(" Buzz requested Arm \n");
|
||||||
buzz_cmd = COMMAND_ARM;
|
buzz_cmd = cur_cmd;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -413,7 +413,7 @@ int buzzuav_disarm(buzzvm_t vm)
|
|||||||
{
|
{
|
||||||
cur_cmd = mavros_msgs::CommandCode::COMPONENT_ARM_DISARM + 1;
|
cur_cmd = mavros_msgs::CommandCode::COMPONENT_ARM_DISARM + 1;
|
||||||
printf(" Buzz requested Disarm \n");
|
printf(" Buzz requested Disarm \n");
|
||||||
buzz_cmd = COMMAND_DISARM;
|
buzz_cmd = cur_cmd;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -429,7 +429,7 @@ int buzzuav_takeoff(buzzvm_t vm)
|
|||||||
height = goto_pos[2];
|
height = goto_pos[2];
|
||||||
cur_cmd = mavros_msgs::CommandCode::NAV_TAKEOFF;
|
cur_cmd = mavros_msgs::CommandCode::NAV_TAKEOFF;
|
||||||
printf(" Buzz requested Take off !!! \n");
|
printf(" Buzz requested Take off !!! \n");
|
||||||
buzz_cmd = COMMAND_TAKEOFF;
|
buzz_cmd = cur_cmd;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -440,7 +440,7 @@ int buzzuav_land(buzzvm_t vm)
|
|||||||
{
|
{
|
||||||
cur_cmd = mavros_msgs::CommandCode::NAV_LAND;
|
cur_cmd = mavros_msgs::CommandCode::NAV_LAND;
|
||||||
printf(" Buzz requested Land !!! \n");
|
printf(" Buzz requested Land !!! \n");
|
||||||
buzz_cmd = COMMAND_LAND;
|
buzz_cmd = cur_cmd;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -451,7 +451,7 @@ int buzzuav_gohome(buzzvm_t vm)
|
|||||||
{
|
{
|
||||||
cur_cmd = mavros_msgs::CommandCode::NAV_RETURN_TO_LAUNCH;
|
cur_cmd = mavros_msgs::CommandCode::NAV_RETURN_TO_LAUNCH;
|
||||||
printf(" Buzz requested gohome !!! \n");
|
printf(" Buzz requested gohome !!! \n");
|
||||||
buzz_cmd = COMMAND_GOHOME;
|
buzz_cmd = cur_cmd;
|
||||||
return buzzvm_ret0(vm);
|
return buzzvm_ret0(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -622,7 +622,7 @@ script
|
|||||||
float* gimbal;
|
float* gimbal;
|
||||||
switch (buzzuav_closures::bzz_cmd())
|
switch (buzzuav_closures::bzz_cmd())
|
||||||
{
|
{
|
||||||
case buzzuav_closures::COMMAND_TAKEOFF:
|
case mavros_msgs::CommandCode::NAV_TAKEOFF:
|
||||||
goto_pos = buzzuav_closures::getgoto();
|
goto_pos = buzzuav_closures::getgoto();
|
||||||
cmd_srv.request.param7 = goto_pos[2];
|
cmd_srv.request.param7 = goto_pos[2];
|
||||||
cmd_srv.request.command = buzzuav_closures::getcmd();
|
cmd_srv.request.command = buzzuav_closures::getcmd();
|
||||||
@ -645,7 +645,7 @@ script
|
|||||||
ROS_ERROR("Failed to call service from flight controller");
|
ROS_ERROR("Failed to call service from flight controller");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_LAND:
|
case mavros_msgs::CommandCode::NAV_LAND:
|
||||||
cmd_srv.request.command = buzzuav_closures::getcmd();
|
cmd_srv.request.command = buzzuav_closures::getcmd();
|
||||||
if (current_mode != "LAND")
|
if (current_mode != "LAND")
|
||||||
{
|
{
|
||||||
@ -664,10 +664,7 @@ script
|
|||||||
armstate = 0;
|
armstate = 0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_GOHOME: // TODO: NOT FULLY IMPLEMENTED/TESTED !!!
|
case mavros_msgs::CommandCode::NAV_RETURN_TO_LAUNCH: // TODO: NOT FULLY TESTED HITL/FIELD !!!
|
||||||
cmd_srv.request.param5 = home.latitude;
|
|
||||||
cmd_srv.request.param6 = home.longitude;
|
|
||||||
cmd_srv.request.param7 = home.altitude;
|
|
||||||
cmd_srv.request.command = buzzuav_closures::getcmd();
|
cmd_srv.request.command = buzzuav_closures::getcmd();
|
||||||
if (mav_client.call(cmd_srv))
|
if (mav_client.call(cmd_srv))
|
||||||
{
|
{
|
||||||
@ -677,28 +674,7 @@ script
|
|||||||
ROS_ERROR("Failed to call service from flight controller");
|
ROS_ERROR("Failed to call service from flight controller");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_GOTO: // TODO: NOT FULLY IMPLEMENTED/TESTED !!!
|
case mavros_msgs::CommandCode::COMPONENT_ARM_DISARM:
|
||||||
goto_pos = buzzuav_closures::getgoto();
|
|
||||||
cmd_srv.request.param5 = goto_pos[0];
|
|
||||||
cmd_srv.request.param6 = goto_pos[1];
|
|
||||||
cmd_srv.request.param7 = goto_pos[2];
|
|
||||||
cmd_srv.request.command = buzzuav_closures::getcmd();
|
|
||||||
if (mav_client.call(cmd_srv))
|
|
||||||
{
|
|
||||||
ROS_INFO("Reply: %ld", (long int)cmd_srv.response.success);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
ROS_ERROR("Failed to call service from flight controller");
|
|
||||||
cmd_srv.request.command = mavros_msgs::CommandCode::MISSION_START;
|
|
||||||
if (mav_client.call(cmd_srv))
|
|
||||||
{
|
|
||||||
ROS_INFO("Reply: %ld", (long int)cmd_srv.response.success);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
ROS_ERROR("Failed to call service from flight controller");
|
|
||||||
break;
|
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_ARM:
|
|
||||||
if (!armstate)
|
if (!armstate)
|
||||||
{
|
{
|
||||||
SetMode("LOITER", 0);
|
SetMode("LOITER", 0);
|
||||||
@ -707,7 +683,7 @@ script
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_DISARM:
|
case mavros_msgs::CommandCode::COMPONENT_ARM_DISARM+1:
|
||||||
if (armstate)
|
if (armstate)
|
||||||
{
|
{
|
||||||
armstate = 0;
|
armstate = 0;
|
||||||
@ -716,12 +692,12 @@ script
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_MOVETO:
|
case mavros_msgs::CommandCode::NAV_SPLINE_WAYPOINT:
|
||||||
goto_pos = buzzuav_closures::getgoto();
|
goto_pos = buzzuav_closures::getgoto();
|
||||||
roscontroller::SetLocalPosition(goto_pos[0], goto_pos[1], goto_pos[2], goto_pos[3]);
|
roscontroller::SetLocalPosition(goto_pos[0], goto_pos[1], goto_pos[2], goto_pos[3]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_GIMBAL:
|
case mavros_msgs::CommandCode::DO_MOUNT_CONTROL:
|
||||||
gimbal = buzzuav_closures::getgimbal();
|
gimbal = buzzuav_closures::getgimbal();
|
||||||
cmd_srv.request.param1 = gimbal[0];
|
cmd_srv.request.param1 = gimbal[0];
|
||||||
cmd_srv.request.param2 = gimbal[1];
|
cmd_srv.request.param2 = gimbal[1];
|
||||||
@ -736,7 +712,7 @@ script
|
|||||||
ROS_ERROR("Failed to call service from flight controller");
|
ROS_ERROR("Failed to call service from flight controller");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case buzzuav_closures::COMMAND_PICTURE:
|
case mavros_msgs::CommandCode::IMAGE_START_CAPTURE:
|
||||||
ROS_INFO("TAKING A PICTURE HERE!! --------------");
|
ROS_INFO("TAKING A PICTURE HERE!! --------------");
|
||||||
mavros_msgs::CommandBool capture_command;
|
mavros_msgs::CommandBool capture_command;
|
||||||
if (capture_srv.call(capture_command))
|
if (capture_srv.call(capture_command))
|
||||||
|
Loading…
Reference in New Issue
Block a user