#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Clover Gazebo. navigate_target for horizontal moves.
Z-axis rules (important):
body takeoff: z=1.0 once
navigate_target z=1: stacks (+1 m each step) - BAD
navigate_target z=0: invalid setpoints - BAD
navigate_target z=nan: keep current altitude - OK
"""
import math
import rospy
from clover import srv
from clover.srv import SetLEDEffect
from std_srvs.srv import Trigger
Z = 1.0
SPD = 0.4
NAN = float('nan')
rospy.init_node('clover_autonomous_mission')
navigate = rospy.ServiceProxy('navigate', srv.Navigate)
land = rospy.ServiceProxy('land', Trigger)
set_effect = rospy.ServiceProxy('led/set_effect', SetLEDEffect)
def led(r, g, b):
try:
set_effect(effect='fill', r=r, g=g, b=b)
except rospy.ServiceException:
pass
rospy.sleep(1.0)
def step(dx, dy, t=6.0):
navigate(x=dx, y=dy, z=NAN, speed=SPD, frame_id='navigate_target')
rospy.sleep(t)
try:
led(255, 255, 255)
navigate(x=0, y=0, z=Z, speed=0.4, frame_id='body', auto_arm=True)
rospy.sleep(7.0)
step(2.0, 0.0, 5.0)
led(255, 0, 255)
step(1.0, 1.0, 6.0)
rospy.sleep(3.0)
led(255, 165, 0)
step(1.0, 0.75, 5.0)
step(1.0, 0.75, 5.0)
led(0, 255, 255)
step(0.5, 1.5, 6.0)
led(128, 0, 255)
step(-0.5, 1.0, 7.0)
step(-1.0, 0.0, 5.0)
led(255, 0, 0)
step(-1.0, -1.0, 6.0)
step(-1.0, 1.0, 5.0)
led(255, 255, 0)
step(-1.0, 0.0, 5.0)
led(0, 255, 0)
step(-1.0, -1.5, 6.0)
led(0, 0, 139)
step(1.5, -0.5, 6.0)
led(255, 0, 255)
step(1.5, -2.0, 7.0)
step(-3.0, -1.0, 7.0)
land()
rospy.sleep(3.0)
led(0, 0, 0)
except rospy.ROSInterruptException:
pass
except KeyboardInterrupt:
try:
land()
led(0, 0, 0)
except rospy.ServiceException:
pass