1
0
mirror of https://github.com/hybridgroup/gobot.git synced 2025-04-27 13:48:56 +08:00

87 lines
2.0 KiB
Go
Raw Normal View History

package main
import (
"fmt"
cv "github.com/hybridgroup/go-opencv/opencv"
"github.com/hybridgroup/gobot"
"github.com/hybridgroup/gobot-ardrone"
"github.com/hybridgroup/gobot-opencv"
"math"
"path"
"runtime"
)
func main() {
_, currentfile, _, _ := runtime.Caller(0)
cascade := path.Join(path.Dir(currentfile), "haarcascade_frontalface_alt.xml")
opencv := new(gobotOpencv.Opencv)
opencv.Name = "opencv"
window := gobotOpencv.NewWindow(opencv)
window.Name = "window"
camera := gobotOpencv.NewCamera(opencv)
camera.Name = "camera"
camera.Source = "tcp://192.168.1.1:5555"
ardroneAdaptor := new(gobotArdrone.ArdroneAdaptor)
ardroneAdaptor.Name = "Drone"
drone := gobotArdrone.NewArdrone(ardroneAdaptor)
drone.Name = "Drone"
work := func() {
detect := false
drone.TakeOff()
var image *cv.IplImage
gobot.On(camera.Events["Frame"], func(data interface{}) {
image = data.(*cv.IplImage)
if detect == false {
window.ShowImage(image)
}
})
gobot.On(drone.Events["Flying"], func(data interface{}) {
gobot.After("1s", func() { drone.Up(0.2) })
gobot.After("2s", func() { drone.Hover() })
gobot.After("5s", func() {
detect = true
gobot.Every("0.3s", func() {
drone.Hover()
i := image
faces := gobotOpencv.DetectFaces(cascade, i)
biggest := 0
var face *cv.Rect
for _, f := range faces {
if f.Width() > biggest {
biggest = f.Width()
face = f
}
}
if face != nil {
gobotOpencv.DrawRectangles(i, []*cv.Rect{face})
center_x := float64(image.Width()) * 0.5
turn := -(float64(face.X()) - center_x) / center_x
fmt.Println("turning:", turn)
if turn < 0 {
drone.Clockwise(math.Abs(turn * 0.4))
} else {
drone.CounterClockwise(math.Abs(turn * 0.4))
}
}
window.ShowImage(i)
})
gobot.After("20s", func() { drone.Land() })
})
})
}
robot := gobot.Robot{
Connections: []gobot.Connection{opencv, ardroneAdaptor},
Devices: []gobot.Device{window, camera, drone},
Work: work,
}
robot.Start()
}