aboutsummaryrefslogtreecommitdiff
path: root/src/modules/navigator/loiter.cpp
diff options
context:
space:
mode:
authorAnton Babushkin <anton.babushkin@me.com>2014-06-29 14:09:22 +0200
committerAnton Babushkin <anton.babushkin@me.com>2014-06-29 14:09:22 +0200
commit0bf9c2a9b262a4c8569031f0f7e9ded432d2d4b3 (patch)
tree9dd567e57af5060452e6fdbfc913ab24b9b09941 /src/modules/navigator/loiter.cpp
parent12be974bd67676ef243d069593b179108976da22 (diff)
downloadpx4-firmware-0bf9c2a9b262a4c8569031f0f7e9ded432d2d4b3.tar.gz
px4-firmware-0bf9c2a9b262a4c8569031f0f7e9ded432d2d4b3.tar.bz2
px4-firmware-0bf9c2a9b262a4c8569031f0f7e9ded432d2d4b3.zip
navigator: API changes, reparing to move manual modes to navigator, WIP
Diffstat (limited to 'src/modules/navigator/loiter.cpp')
-rw-r--r--src/modules/navigator/loiter.cpp21
1 files changed, 14 insertions, 7 deletions
diff --git a/src/modules/navigator/loiter.cpp b/src/modules/navigator/loiter.cpp
index 5e7067b0e..f827e70c9 100644
--- a/src/modules/navigator/loiter.cpp
+++ b/src/modules/navigator/loiter.cpp
@@ -36,6 +36,7 @@
* Helper class to loiter
*
* @author Julian Oes <julian@oes.ch>
+ * @author Anton Babushkin <anton.babushkin@me.com>
*/
#include <string.h>
@@ -51,14 +52,13 @@
#include <uORB/topics/position_setpoint_triplet.h>
#include "loiter.h"
+#include "navigator.h"
Loiter::Loiter(Navigator *navigator, const char *name) :
MissionBlock(navigator, name)
{
/* load initial params */
updateParams();
- /* initial reset */
- on_inactive();
}
Loiter::~Loiter()
@@ -71,16 +71,23 @@ Loiter::on_inactive()
}
void
-Loiter::on_activation(struct position_setpoint_triplet_s *pos_sp_triplet)
+Loiter::on_activation()
{
- set_loiter_item(pos_sp_triplet);
+ /* set current mission item to loiter */
+ set_loiter_item(&_mission_item);
+
+ /* convert mission item to current setpoint */
+ struct position_setpoint_triplet_s *pos_sp_triplet = _navigator->get_position_setpoint_triplet();
pos_sp_triplet->previous.valid = false;
mission_item_to_position_setpoint(&_mission_item, &pos_sp_triplet->current);
pos_sp_triplet->next.valid = false;
+
+ _navigator->set_can_loiter_at_sp(pos_sp_triplet->current.type == SETPOINT_TYPE_LOITER);
+
+ _navigator->set_position_setpoint_triplet_updated();
}
-bool
-Loiter::on_active(struct position_setpoint_triplet_s *pos_sp_triplet)
+void
+Loiter::on_active()
{
- return false;
}