Skip to content

Commit

Permalink
Tools: ros2: Clean up copter takeoff
Browse files Browse the repository at this point in the history
* Finish timeout implementation missing variables
* Remove unused imports

Signed-off-by: Ryan Friedman <25047695+Ryanf55@users.noreply.github.com>
  • Loading branch information
Ryanf55 authored and tridge committed Jan 7, 2025
1 parent bb96db5 commit 01345e5
Showing 1 changed file with 7 additions and 13 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,27 +20,21 @@
Warning - This is NOT production code; it's a simple demo of capability.
"""

import math
import rclpy
import time
import errno

from rclpy.node import Node
from builtin_interfaces.msg import Time
from ardupilot_msgs.msg import GlobalPosition
from geographic_msgs.msg import GeoPoseStamped
from geopy import distance
from geopy import point
from ardupilot_msgs.srv import ArmMotors
from ardupilot_msgs.srv import ModeSwitch
from ardupilot_msgs.srv import Takeoff



COPTER_MODE_GUIDED = 4

TAKEOFF_ALT = 10.5


class CopterTakeoff(Node):
"""Copter takeoff using guided control."""

Expand All @@ -65,7 +59,7 @@ def __init__(self):
self._client_takeoff = self.create_client(Takeoff, self._takeoff_topic)
while not self._client_takeoff.wait_for_service(timeout_sec=1.0):
self.get_logger().info('takeoff service not available, waiting again...')

self.declare_parameter("geopose_topic", "/ap/geopose/filtered")
self._geopose_topic = self.get_parameter("geopose_topic").get_parameter_value().string_value
qos = rclpy.qos.QoSProfile(
Expand All @@ -84,7 +78,6 @@ def geopose_cb(self, msg: GeoPoseStamped):
# Store current state
self._cur_geopose = msg


def arm(self):
req = ArmMotors.Request()
req.arm = True
Expand Down Expand Up @@ -113,14 +106,14 @@ def switch_mode_with_timeout(self, desired_mode: int, timeout: rclpy.duration.Du
"""Try to switch mode. Returns true on success, or false if mode switch fails or times out."""
is_in_desired_mode = False
start = self.get_clock().now()
while not is_in_desired_mode:
while not is_in_desired_mode and self.get_clock().now() - start < timeout:
result = self.switch_mode(desired_mode)
# Handle successful switch or the case that the vehicle is already in expected mode
is_in_desired_mode = result.status or result.curr_mode == desired_mode
time.sleep(1)

return is_in_desired_mode

def takeoff(self, alt):
req = Takeoff.Request()
req.alt = alt
Expand All @@ -132,17 +125,18 @@ def takeoff_with_timeout(self, alt: int, timeout: rclpy.duration.Duration):
"""Try to takeoff. Returns true on success, or false if takeoff fails or times out."""
takeoff_success = False
start = self.get_clock().now()
while not takeoff_success:
while not takeoff_success and self.get_clock().now() - start < timeout:
result = self.takeoff(alt)
takeoff_success = result.status
time.sleep(1)

return takeoff_success

def get_cur_geopose(self):
"""Return latest geopose."""
return self._cur_geopose


def main(args=None):
"""Node entry point."""
rclpy.init(args=args)
Expand Down

0 comments on commit 01345e5

Please sign in to comment.