Загрузка данных
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import rospy
import cv2
import numpy as np
from sensor_msgs.msg import Image
from cv_bridge import CvBridge
from clover import srv
from std_srvs.srv import Trigger
rospy.init_node('clover_cv_mission')
bridge = CvBridge()
navigate = rospy.ServiceProxy('navigate', srv.Navigate)
land = rospy.ServiceProxy('land', Trigger)
set_effect = rospy.ServiceProxy('led/set_effect', srv.SetLEDEffect)
current_color = "white"
def image_callback(data):
global current_color
try:
# Конвертируем ROS-картинку с камеры в формат OpenCV
cv_image = bridge.imgmsg_to_cv2(data, "bgr8")
h, w, _ = cv_image.shape
# Вырезаем только центральный квадрат кадра, куда смотрит дрон
roi = cv_image[int(h/3):int(2*h/3), int(w/3):int(2*w/3)]
hsv = cv2.cvtColor(roi, cv2.COLOR_BGR2HSV)
# Рассчитываем средний цвет в центре кадра
avg_hsv = np.mean(roi, axis=(0, 1))
hue = avg_hsv[0]
sat = avg_hsv[1]
val = avg_hsv[2]
# Детектор цветов по диапазонам HSV в Gazebo
if sat > 50 and val > 50:
if hue < 10 or hue > 170:
current_color = "red"
set_effect(effect='fill', r=255, g=0, b=0)
elif 10 <= hue < 25:
current_color = "orange"
set_effect(effect='fill', r=255, g=165, b=0)
elif 25 <= hue < 35:
current_color = "yellow"
set_effect(effect='fill', r=255, g=255, b=0)
elif 35 <= hue < 85:
current_color = "green"
set_effect(effect='fill', r=0, g=255, b=0)
elif 85 <= hue < 125:
current_color = "blue"
set_effect(effect='fill', r=0, g=0, b=255)
elif 125 <= hue < 145:
current_color = "purple"
set_effect(effect='fill', r=128, g=0, b=128)
elif 145 <= hue < 170:
current_color = "pink"
set_effect(effect='fill', r=255, g=0, b=255)
except Exception as e:
pass
# Подписываемся на топик нижней камеры Клевера
image_sub = rospy.Subscriber('/main_camera/image_raw', Image, image_callback)
def fly_absolute(x, y, z=1.0, speed=0.4, delay=7.0):
navigate(x=x, y=y, z=z, speed=speed, frame_id='map', auto_arm=True)
rospy.sleep(delay)
try:
# 1. Взлет (Белая индикация на старте)
set_effect(effect='fill', r=255, g=255, b=255)
navigate(x=-3.0, y=-3.0, z=1.0, speed=0.4, frame_id='map', auto_arm=True)
rospy.sleep(6.0)
# 2. К блоку 38 через маркер 44
fly_absolute(x=-3.0, y=-1.0, delay=5.0)
fly_absolute(x=-2.0, y=-1.0, delay=5.0)
# 3. Полет по правой стороне к блоку 12
fly_absolute(x=-3.0, y=3.0, delay=6.0)
fly_absolute(x=-2.0, y=3.0, delay=5.0)
fly_absolute(x=0.0, y=3.0, delay=5.0)
fly_absolute(x=2.0, y=3.0, delay=5.0)
fly_absolute(x=2.0, y=2.0, delay=5.0)
# 4. К блоку 17 через точку 11
fly_absolute(x=2.0, y=1.0, delay=5.0)
fly_absolute(x=1.0, y=1.0, delay=5.0)
# 5. К блоку 8 через точку 9
fly_absolute(x=1.0, y=-1.0, delay=5.0)
fly_absolute(x=2.0, y=-1.0, delay=5.0)
fly_absolute(x=2.0, y=-2.0, delay=5.0)
# 6. Полет по левой стороне обратно к блоку 38
fly_absolute(x=3.0, y=-3.0, delay=6.0)
fly_absolute(x=2.0, y=-3.0, delay=5.0)
fly_absolute(x=0.0, y=-3.0, delay=5.0)
fly_absolute(x=-1.0, y=-3.0, delay=5.0)
fly_absolute(x=-2.0, y=-1.0, delay=5.0)
# 7. Возврат на маркер 42 и посадка
fly_absolute(x=-3.0, y=-3.0, delay=6.0)
land()
rospy.sleep(5.0)
set_effect(effect='fill', r=0, g=0, b=0)
except rospy.ROSInterruptException:
pass