Rover: add Auto_Stop state and use for Nav_Delay
This commit is contained in:
parent
1bb332382c
commit
6c3ce521c7
@ -283,7 +283,8 @@ protected:
|
|||||||
Auto_HeadingAndSpeed, // turn to a given heading
|
Auto_HeadingAndSpeed, // turn to a given heading
|
||||||
Auto_RTL, // perform RTL within auto mode
|
Auto_RTL, // perform RTL within auto mode
|
||||||
Auto_Loiter, // perform Loiter within auto mode
|
Auto_Loiter, // perform Loiter within auto mode
|
||||||
Auto_Guided // handover control to external navigation system from within auto mode
|
Auto_Guided, // handover control to external navigation system from within auto mode
|
||||||
|
Auto_Stop // stop the vehicle as quickly as possible
|
||||||
} _submode;
|
} _submode;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -291,6 +292,7 @@ private:
|
|||||||
bool check_trigger(void);
|
bool check_trigger(void);
|
||||||
bool start_loiter();
|
bool start_loiter();
|
||||||
void start_guided(const Location& target_loc);
|
void start_guided(const Location& target_loc);
|
||||||
|
void start_stop();
|
||||||
void send_guided_position_target();
|
void send_guided_position_target();
|
||||||
|
|
||||||
bool start_command(const AP_Mission::Mission_Command& cmd);
|
bool start_command(const AP_Mission::Mission_Command& cmd);
|
||||||
@ -351,7 +353,6 @@ private:
|
|||||||
// Delay the next navigation command
|
// Delay the next navigation command
|
||||||
uint32_t nav_delay_time_max_ms; // used for delaying the navigation commands
|
uint32_t nav_delay_time_max_ms; // used for delaying the navigation commands
|
||||||
uint32_t nav_delay_time_start_ms;
|
uint32_t nav_delay_time_start_ms;
|
||||||
AutoSubMode nav_delay_submode_backup; // back up sub_mode
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -97,6 +97,10 @@ void ModeAuto::update()
|
|||||||
rover.mode_guided.update();
|
rover.mode_guided.update();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case Auto_Stop:
|
||||||
|
stop_vehicle();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,6 +121,7 @@ float ModeAuto::get_distance_to_destination() const
|
|||||||
case Auto_WP:
|
case Auto_WP:
|
||||||
return _distance_to_destination;
|
return _distance_to_destination;
|
||||||
case Auto_HeadingAndSpeed:
|
case Auto_HeadingAndSpeed:
|
||||||
|
case Auto_Stop:
|
||||||
// no valid distance so return zero
|
// no valid distance so return zero
|
||||||
return 0.0f;
|
return 0.0f;
|
||||||
case Auto_RTL:
|
case Auto_RTL:
|
||||||
@ -142,6 +147,7 @@ bool ModeAuto::get_desired_location(Location& destination) const
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
case Auto_HeadingAndSpeed:
|
case Auto_HeadingAndSpeed:
|
||||||
|
case Auto_Stop:
|
||||||
// no desired location for this submode
|
// no desired location for this submode
|
||||||
return false;
|
return false;
|
||||||
case Auto_RTL:
|
case Auto_RTL:
|
||||||
@ -177,6 +183,7 @@ bool ModeAuto::reached_destination() const
|
|||||||
return g2.wp_nav.reached_destination();
|
return g2.wp_nav.reached_destination();
|
||||||
break;
|
break;
|
||||||
case Auto_HeadingAndSpeed:
|
case Auto_HeadingAndSpeed:
|
||||||
|
case Auto_Stop:
|
||||||
// always return true because this is the safer option to allow missions to continue
|
// always return true because this is the safer option to allow missions to continue
|
||||||
return true;
|
return true;
|
||||||
break;
|
break;
|
||||||
@ -295,6 +302,12 @@ void ModeAuto::start_guided(const Location& loc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// start stopping vehicle as quickly as possible
|
||||||
|
void ModeAuto::start_stop()
|
||||||
|
{
|
||||||
|
_submode = Auto_Stop;
|
||||||
|
}
|
||||||
|
|
||||||
// send latest position target to offboard navigation system
|
// send latest position target to offboard navigation system
|
||||||
void ModeAuto::send_guided_position_target()
|
void ModeAuto::send_guided_position_target()
|
||||||
{
|
{
|
||||||
@ -550,11 +563,14 @@ void ModeAuto::do_nav_delay(const AP_Mission::Mission_Command& cmd)
|
|||||||
{
|
{
|
||||||
nav_delay_time_start_ms = millis();
|
nav_delay_time_start_ms = millis();
|
||||||
|
|
||||||
// act like we're just doing a heading hold that we instantly achieve.
|
// boats loiter, cars and balancebots stop
|
||||||
// the behavior of this will put a boat into loiter, else stop
|
if (rover.is_boat()) {
|
||||||
nav_delay_submode_backup = _submode;
|
if (!start_loiter()) {
|
||||||
_submode = Auto_HeadingAndSpeed;
|
start_stop();
|
||||||
_reached_heading = true;
|
}
|
||||||
|
} else {
|
||||||
|
start_stop();
|
||||||
|
}
|
||||||
|
|
||||||
if (cmd.content.nav_delay.seconds > 0) {
|
if (cmd.content.nav_delay.seconds > 0) {
|
||||||
// relative delay
|
// relative delay
|
||||||
@ -563,7 +579,7 @@ void ModeAuto::do_nav_delay(const AP_Mission::Mission_Command& cmd)
|
|||||||
// absolute delay to utc time
|
// absolute delay to utc time
|
||||||
nav_delay_time_max_ms = AP::rtc().get_time_utc(cmd.content.nav_delay.hour_utc, cmd.content.nav_delay.min_utc, cmd.content.nav_delay.sec_utc, 0);
|
nav_delay_time_max_ms = AP::rtc().get_time_utc(cmd.content.nav_delay.hour_utc, cmd.content.nav_delay.min_utc, cmd.content.nav_delay.sec_utc, 0);
|
||||||
}
|
}
|
||||||
gcs().send_text(MAV_SEVERITY_INFO, "Delaying %u sec",nav_delay_time_max_ms/1000);
|
gcs().send_text(MAV_SEVERITY_INFO, "Delaying %u sec", nav_delay_time_max_ms/1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
// start guided within auto to allow external navigation system to control vehicle
|
// start guided within auto to allow external navigation system to control vehicle
|
||||||
@ -634,7 +650,6 @@ bool ModeAuto::verify_nav_delay(const AP_Mission::Mission_Command& cmd)
|
|||||||
{
|
{
|
||||||
if (millis() - nav_delay_time_start_ms > nav_delay_time_max_ms) {
|
if (millis() - nav_delay_time_start_ms > nav_delay_time_max_ms) {
|
||||||
nav_delay_time_max_ms = 0;
|
nav_delay_time_max_ms = 0;
|
||||||
_submode = nav_delay_submode_backup;
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user