Загрузка данных


#!/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)

def image_callback(data):
    try:
        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(hsv, axis=(0, 1))
        hue = avg_hsv[0]
        sat = avg_hsv[1]
        val = avg_hsv[2]
        
        if sat > 40 and val > 40:
            if hue < 8 or hue > 170:
                set_effect(effect='fill', r=255, g=0, b=0)
            elif 8 <= hue < 25:
                set_effect(effect='fill', r=255, g=165, b=0)
            elif 25 <= hue < 35:
                set_effect(effect='fill', r=255, g=255, b=0)
            elif 35 <= hue < 85:
                set_effect(effect='fill', r=0, g=255, b=0)
            elif 85 <= hue < 125:
                set_effect(effect='fill', r=0, g=191, b=255)
            elif 125 <= hue < 140:
                set_effect(effect='fill', r=0, g=0, b=255)
            elif 140 <= hue < 170:
                set_effect(effect='fill', r=128, g=0, b=128)
    except Exception:
        pass

image_sub = rospy.Subscriber('/main_camera/image_raw', Image, image_callback)

def fly_body(x, y, z=0.0, speed=0.4, delay=6.0):
    navigate(x=x, y=y, z=z, speed=speed, frame_id='body', auto_arm=True)
    rospy.sleep(delay)

try:
    # 1. Взлет строго на месте
    set_effect(effect='fill', r=255, g=255, b=255)
    navigate(x=0.0, y=0.0, z=1.0, speed=0.4, frame_id='body', auto_arm=True)
    rospy.sleep(6.0)

    # 2. К блоку 38 через маркер 44 (Сначала по X, потом по Y)
    fly_body(x=1.0, y=0.0, delay=5.0)  
    fly_body(x=0.0, y=2.0, delay=6.0) 

    # 3. Полет по правой стороне к блоку 12 (По диагонали)
    fly_body(x=0.0, y=3.0, delay=6.0) 
    fly_body(x=2.0, y=0.0, delay=6.0)  
    fly_body(x=2.0, y=-1.0, delay=6.0)  

    # 4. К блоку 17 через точку 11 (Сначала по X, потом по Y)
    fly_body(x=-1.0, y=0.0, delay=5.0) 
    fly_body(x=-1.0, y=0.0, delay=5.0) 
    fly_body(x=0.0, y=1.0, delay=5.0) 

    # 5. К блоку 8 через точку 9 (Сначала по X, потом по Y)
    fly_body(x=-1.0, y=0.0, delay=5.0) 
    fly_body(x=0.0, y=-1.0, delay=5.0)  
    fly_body(x=1.0, y=0.0, delay=5.0)  

    # 6. Полет по левой стороне к блоку 38 (По диагонали)
    fly_body(x=1.0, y=-1.0, delay=6.0)  
    fly_body(x=-1.5, y=0.0, delay=6.0) 
    fly_body(x=-2.0, y=0.0, delay=6.0) 
    fly_body(x=-1.5, y=3.0, delay=7.0) 

    # 7. Финиш на маркер 42
    fly_body(x=-1.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