hybridgroup.gobot/examples/opencv_face_detect.go

56 lines
962 B
Go
Raw Normal View History

// +build example
//
// Do not build by default.
package main
import (
"path"
"runtime"
"sync/atomic"
"time"
2014-07-11 08:21:21 +08:00
"gobot.io/x/gobot"
"gobot.io/x/gobot/platforms/opencv"
"gocv.io/x/gocv"
)
var img atomic.Value
func main() {
_, currentfile, _, _ := runtime.Caller(0)
cascade := path.Join(path.Dir(currentfile), "haarcascade_frontalface_alt.xml")
window := opencv.NewWindowDriver()
camera := opencv.NewCameraDriver(1)
work := func() {
mat := gocv.NewMat()
img.Store(mat)
camera.On(opencv.Frame, func(data interface{}) {
i := data.(gocv.Mat)
img.Store(i)
})
gobot.Every(10*time.Millisecond, func() {
i := img.Load().(gocv.Mat)
if i.Empty() {
return
}
faces := opencv.DetectObjects(cascade, i)
opencv.DrawRectangles(i, faces, 0, 255, 0, 5)
window.ShowImage(i)
window.WaitKey(1)
2014-06-09 09:14:18 +08:00
})
}
2014-07-09 09:36:14 +08:00
robot := gobot.NewRobot("faceBot",
[]gobot.Connection{},
[]gobot.Device{window, camera},
work,
)
robot.Start()
}