Display road
This commit is contained in:
parent
c724e9e8af
commit
3bfed77e43
10
README.md
10
README.md
@ -9,7 +9,7 @@ Tool to display camera frame and metrics
|
|||||||
-mqtt-broker string
|
-mqtt-broker string
|
||||||
Broker Uri, use MQTT_BROKER env if arg not set (default "tcp://127.0.0.1:1883")
|
Broker Uri, use MQTT_BROKER env if arg not set (default "tcp://127.0.0.1:1883")
|
||||||
-mqtt-client-id string
|
-mqtt-client-id string
|
||||||
Mqtt client id, use MQTT_CLIENT_ID env if args not set (default "robocar-frame-display")
|
Mqtt client id, use MQTT_CLIENT_ID env if args not set (default "robocar-display")
|
||||||
-mqtt-password string
|
-mqtt-password string
|
||||||
Broker Password, MQTT_PASSWORD env if args not set
|
Broker Password, MQTT_PASSWORD env if args not set
|
||||||
-mqtt-qos int
|
-mqtt-qos int
|
||||||
@ -18,7 +18,15 @@ Tool to display camera frame and metrics
|
|||||||
Retain mqtt message, if not set, true if MQTT_RETAIN env variable is set
|
Retain mqtt message, if not set, true if MQTT_RETAIN env variable is set
|
||||||
-mqtt-topic-frame string
|
-mqtt-topic-frame string
|
||||||
Mqtt topic that contains frame to display, use MQTT_TOPIC_FRAME if args not set
|
Mqtt topic that contains frame to display, use MQTT_TOPIC_FRAME if args not set
|
||||||
|
-mqtt-topic-objects string
|
||||||
|
Mqtt topic that contains detected objects, use MQTT_TOPIC_OBJECTS if args not set
|
||||||
|
-mqtt-topic-road string
|
||||||
|
Mqtt topic that contains road description, use MQTT_TOPIC_ROAD if args not set
|
||||||
-mqtt-username string
|
-mqtt-username string
|
||||||
Broker Username, use MQTT_USERNAME env if arg not set
|
Broker Username, use MQTT_USERNAME env if arg not set
|
||||||
|
-with-objects
|
||||||
|
Display detected objects
|
||||||
|
-with-road
|
||||||
|
Display detected road
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -14,8 +14,8 @@ const (
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
var mqttBroker, username, password, clientId string
|
var mqttBroker, username, password, clientId string
|
||||||
var frameTopic, objectsTopic string
|
var frameTopic, objectsTopic, roadTopic string
|
||||||
var withObjects bool
|
var withObjects, withRoad bool
|
||||||
|
|
||||||
mqttQos := cli.InitIntFlag("MQTT_QOS", 0)
|
mqttQos := cli.InitIntFlag("MQTT_QOS", 0)
|
||||||
_, mqttRetain := os.LookupEnv("MQTT_RETAIN")
|
_, mqttRetain := os.LookupEnv("MQTT_RETAIN")
|
||||||
@ -23,9 +23,13 @@ func main() {
|
|||||||
cli.InitMqttFlags(DefaultClientId, &mqttBroker, &username, &password, &clientId, &mqttQos, &mqttRetain)
|
cli.InitMqttFlags(DefaultClientId, &mqttBroker, &username, &password, &clientId, &mqttQos, &mqttRetain)
|
||||||
|
|
||||||
flag.StringVar(&frameTopic, "mqtt-topic-frame", os.Getenv("MQTT_TOPIC_FRAME"), "Mqtt topic that contains frame to display, use MQTT_TOPIC_FRAME if args not set")
|
flag.StringVar(&frameTopic, "mqtt-topic-frame", os.Getenv("MQTT_TOPIC_FRAME"), "Mqtt topic that contains frame to display, use MQTT_TOPIC_FRAME if args not set")
|
||||||
|
|
||||||
flag.StringVar(&objectsTopic, "mqtt-topic-objects", os.Getenv("MQTT_TOPIC_OBJECTS"), "Mqtt topic that contains detected objects, use MQTT_TOPIC_OBJECTS if args not set")
|
flag.StringVar(&objectsTopic, "mqtt-topic-objects", os.Getenv("MQTT_TOPIC_OBJECTS"), "Mqtt topic that contains detected objects, use MQTT_TOPIC_OBJECTS if args not set")
|
||||||
flag.BoolVar(&withObjects, "with-objects", false, "Display detected objects")
|
flag.BoolVar(&withObjects, "with-objects", false, "Display detected objects")
|
||||||
|
|
||||||
|
flag.StringVar(&roadTopic, "mqtt-topic-road", os.Getenv("MQTT_TOPIC_ROAD"), "Mqtt topic that contains road description, use MQTT_TOPIC_ROAD if args not set")
|
||||||
|
flag.BoolVar(&withRoad, "with-road", false, "Display detected road")
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
if len(os.Args) <= 1 {
|
if len(os.Args) <= 1 {
|
||||||
flag.PrintDefaults()
|
flag.PrintDefaults()
|
||||||
@ -38,7 +42,9 @@ func main() {
|
|||||||
}
|
}
|
||||||
defer client.Disconnect(50)
|
defer client.Disconnect(50)
|
||||||
|
|
||||||
p := part.NewPart(client, frameTopic, objectsTopic, withObjects)
|
p := part.NewPart(client, frameTopic,
|
||||||
|
objectsTopic, roadTopic,
|
||||||
|
withObjects, withRoad )
|
||||||
defer p.Stop()
|
defer p.Stop()
|
||||||
|
|
||||||
cli.HandleExit(p)
|
cli.HandleExit(p)
|
||||||
|
62
part/part.go
62
part/part.go
@ -12,15 +12,18 @@ import (
|
|||||||
"image/color"
|
"image/color"
|
||||||
)
|
)
|
||||||
|
|
||||||
func NewPart(client mqtt.Client, frameTopic, objectsTopic string, withObjects bool) *FramePart {
|
func NewPart(client mqtt.Client, frameTopic, objectsTopic, roadTopic string, withObjects, withRoad bool) *FramePart {
|
||||||
return &FramePart{
|
return &FramePart{
|
||||||
client: client,
|
client: client,
|
||||||
frameTopic: frameTopic,
|
frameTopic: frameTopic,
|
||||||
objectsTopic: objectsTopic,
|
objectsTopic: objectsTopic,
|
||||||
|
roadTopic: roadTopic,
|
||||||
window: gocv.NewWindow(frameTopic),
|
window: gocv.NewWindow(frameTopic),
|
||||||
withObjects: withObjects,
|
withObjects: withObjects,
|
||||||
|
withRoad: withRoad,
|
||||||
imgChan: make(chan gocv.Mat),
|
imgChan: make(chan gocv.Mat),
|
||||||
objectsChan: make(chan events.ObjectsMessage),
|
objectsChan: make(chan events.ObjectsMessage),
|
||||||
|
roadChan: make(chan events.RoadMessage),
|
||||||
cancel: make(chan interface{}),
|
cancel: make(chan interface{}),
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -28,13 +31,15 @@ func NewPart(client mqtt.Client, frameTopic, objectsTopic string, withObjects bo
|
|||||||
|
|
||||||
type FramePart struct {
|
type FramePart struct {
|
||||||
client mqtt.Client
|
client mqtt.Client
|
||||||
frameTopic, objectsTopic string
|
frameTopic, objectsTopic, roadTopic string
|
||||||
|
|
||||||
window *gocv.Window
|
window *gocv.Window
|
||||||
withObjects bool
|
withObjects bool
|
||||||
|
withRoad bool
|
||||||
|
|
||||||
imgChan chan gocv.Mat
|
imgChan chan gocv.Mat
|
||||||
objectsChan chan events.ObjectsMessage
|
objectsChan chan events.ObjectsMessage
|
||||||
|
roadChan chan events.RoadMessage
|
||||||
cancel chan interface{}
|
cancel chan interface{}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,6 +50,8 @@ func (p *FramePart) Start() error {
|
|||||||
|
|
||||||
var img = gocv.NewMat()
|
var img = gocv.NewMat()
|
||||||
var objectsMsg events.ObjectsMessage
|
var objectsMsg events.ObjectsMessage
|
||||||
|
var roadMsg events.RoadMessage
|
||||||
|
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case newImg := <-p.imgChan:
|
case newImg := <-p.imgChan:
|
||||||
@ -52,11 +59,13 @@ func (p *FramePart) Start() error {
|
|||||||
img = newImg
|
img = newImg
|
||||||
case objects := <-p.objectsChan:
|
case objects := <-p.objectsChan:
|
||||||
objectsMsg = objects
|
objectsMsg = objects
|
||||||
|
case road := <-p.roadChan:
|
||||||
|
roadMsg = road
|
||||||
case <-p.cancel:
|
case <-p.cancel:
|
||||||
img.Close()
|
img.Close()
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
p.drawFrame(&img, &objectsMsg)
|
p.drawFrame(&img, &objectsMsg, &roadMsg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -65,7 +74,7 @@ func (p *FramePart) Stop() {
|
|||||||
|
|
||||||
close(p.cancel)
|
close(p.cancel)
|
||||||
|
|
||||||
StopService("frame-display", p.client, p.frameTopic)
|
StopService("frame-display", p.client, p.frameTopic, p.roadTopic)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *FramePart) onFrame(_ mqtt.Client, message mqtt.Message) {
|
func (p *FramePart) onFrame(_ mqtt.Client, message mqtt.Message) {
|
||||||
@ -86,15 +95,27 @@ func (p *FramePart) onFrame(_ mqtt.Client, message mqtt.Message) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (p *FramePart) onObjects(_ mqtt.Client, message mqtt.Message) {
|
func (p *FramePart) onObjects(_ mqtt.Client, message mqtt.Message) {
|
||||||
var objectsMsg events.ObjectsMessage
|
var msg events.ObjectsMessage
|
||||||
|
|
||||||
err := proto.Unmarshal(message.Payload(), &objectsMsg)
|
err := proto.Unmarshal(message.Payload(), &msg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Errorf("unable to unmarshal detected objects: %v", err)
|
log.Errorf("unable to unmarshal msg %T: %v", msg, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
p.objectsChan <- objectsMsg
|
p.objectsChan <- msg
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *FramePart) onRoad(_ mqtt.Client, message mqtt.Message) {
|
||||||
|
var msg events.RoadMessage
|
||||||
|
|
||||||
|
err := proto.Unmarshal(message.Payload(), &msg)
|
||||||
|
if err != nil {
|
||||||
|
log.Errorf("unable to unmarshal msg %T: %v", msg, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
p.roadChan <- msg
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *FramePart) registerCallbacks() error {
|
func (p *FramePart) registerCallbacks() error {
|
||||||
@ -110,14 +131,23 @@ func (p *FramePart) registerCallbacks() error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if p.withRoad {
|
||||||
|
err := service.RegisterCallback(p.client, p.roadTopic, p.onRoad)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *FramePart) drawFrame(img *gocv.Mat, objects *events.ObjectsMessage) {
|
func (p *FramePart) drawFrame(img *gocv.Mat, objects *events.ObjectsMessage, road *events.RoadMessage) {
|
||||||
|
|
||||||
if p.withObjects {
|
if p.withObjects {
|
||||||
p.drawObjects(img, objects)
|
p.drawObjects(img, objects)
|
||||||
}
|
}
|
||||||
|
if p.withRoad {
|
||||||
|
p.drawRoad(img, road)
|
||||||
|
}
|
||||||
|
|
||||||
p.window.IMShow(*img)
|
p.window.IMShow(*img)
|
||||||
p.window.WaitKey(1)
|
p.window.WaitKey(1)
|
||||||
@ -133,6 +163,20 @@ func (p *FramePart) drawObjects(img *gocv.Mat, objects *events.ObjectsMessage) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *FramePart) drawRoad(img *gocv.Mat, road *events.RoadMessage) {
|
||||||
|
cntr := make([]image.Point, 0, len(road.GetContour()))
|
||||||
|
for _, pt := range road.GetContour() {
|
||||||
|
cntr = append(cntr, image.Point{X: int(pt.GetX()), Y: int(pt.GetY())})
|
||||||
|
}
|
||||||
|
|
||||||
|
gocv.DrawContours(
|
||||||
|
img,
|
||||||
|
[][]image.Point{cntr},
|
||||||
|
0,
|
||||||
|
color.RGBA{R: 255, G: 0, B: 0, A: 128,},
|
||||||
|
-1)
|
||||||
|
}
|
||||||
|
|
||||||
func StopService(name string, client mqtt.Client, topics ...string) {
|
func StopService(name string, client mqtt.Client, topics ...string) {
|
||||||
log.Printf("Stop %s service", name)
|
log.Printf("Stop %s service", name)
|
||||||
token := client.Unsubscribe(topics...)
|
token := client.Unsubscribe(topics...)
|
||||||
|
Loading…
Reference in New Issue
Block a user