From 0182f34e33252183cf4c9717db798e89052441eb Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期二, 02 七月 2019 14:21:41 +0800
Subject: [PATCH] 根据摄像机真实配置的区域去画框并改动一些人脸部分的注释
---
util/simpleCV.go | 24 ++++++++++++++++++------
main.go | 4 ++--
2 files changed, 20 insertions(+), 8 deletions(-)
diff --git a/main.go b/main.go
index e82a43a..d6ee9a0 100644
--- a/main.go
+++ b/main.go
@@ -168,13 +168,13 @@
arg.KeepRight = false
arg.IsStatic = false
if len(sdkinfo.Sdkdata) > 1 {
- fmt.Println("----------------------------------------------------",m.Caddr)
faceParam := protomsg.ParamFacePos{}
err = proto.Unmarshal(sdkinfo.Sdkdata, &faceParam)
if err != nil {
fmt.Println("瑙f瀽FACE sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
continue
}
+ log.Println("------褰撳墠绠楁硶name",sdkinfo.SdkName,"--------------鐪嬬湅浜鸿劯妫�娴嬩腑鏈夊嚑涓洰鏍囷細",len(faceParam.Faces))
for _, info := range faceParam.Faces {
photoMap := ruleserver.PhotoMap{Rects: rectFormat(info.Pos.RcFace), Score: float64(info.Pos.Quality)*100, IsYolo:false,ThftRes:*(info.Result)}
arg.Photo = append(arg.Photo, photoMap)
@@ -202,13 +202,13 @@
arg.KeepRight = false
arg.IsStatic = false
if len(sdkinfo.Sdkdata) > 1 {
- fmt.Println("----------------------------------------------------",m.Caddr)
faceParam := protomsg.ParamFaceFeature{}
err = proto.Unmarshal(sdkinfo.Sdkdata, &faceParam)
if err != nil {
fmt.Println("瑙f瀽FACE sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
continue
}
+ log.Println("------褰撳墠绠楁硶name",sdkinfo.SdkName,"--------------鐪嬬湅浜鸿劯鎻愬彇涓湁鍑犱釜鐩爣锛�",len(faceParam.ExtComp))
for _, extComp := range faceParam.ExtComp {
baseinfos := protomsg.Binfos{}
err1 := proto.Unmarshal(extComp.Comp, &baseinfos)
diff --git a/util/simpleCV.go b/util/simpleCV.go
index 53b2d03..ee7465e 100644
--- a/util/simpleCV.go
+++ b/util/simpleCV.go
@@ -15,6 +15,8 @@
"mime/multipart"
"net/http"
"os"
+ "ruleprocess/cache"
+ "ruleprocess/ruleserver"
"time"
)
@@ -159,7 +161,7 @@
}
}
-func DrawPolygonOnImage(img protomsg.Image)(maps map[string]interface{}, err0 error){
+func DrawPolygonOnImage(cameraId string, img protomsg.Image) (maps map[string]interface{}, err0 error) {
// draw the rook
//ddd, err := RetrieveROM("/home/user/workspace/ruleprocess/util/105.jpg")
//if err != nil {
@@ -181,14 +183,24 @@
// },
//}
//gocv.FillPoly(&rook, points, green)
- gocv.Line(&rook, image.Pt(100, 100), image.Pt(100, 800), green, 2)
- gocv.Line(&rook, image.Pt(100, 800), image.Pt(800, 800), green, 2)
- gocv.Line(&rook, image.Pt(800, 800), image.Pt(800, 100), green, 2)
- gocv.Line(&rook, image.Pt(800, 100), image.Pt(100, 100), green, 2)
+ // 鏌ュ埌鎽勫儚鏈烘墍鏈夌殑鍖哄煙骞剁敾妗�
+ var cameraPolygons []protomsg.CameraPolygon
+ cameraPolygons = cache.GetPolygonsByCameraId(cameraId)
+ for _, polygon := range cameraPolygons {
+ points := ruleserver.Json2points(polygon.Polygon)
+ for index := 0; index < len(points); index++ {
+ if index == len(points)-1 { // 闂悎鍥惧舰
+ gocv.Line(&rook, image.Pt(int(points[index].X), int(points[index].Y)), image.Pt(int(points[0].X), int(points[0].Y)), green, 2)
+ } else {
+ gocv.Line(&rook, image.Pt(int(points[index].X), int(points[index].Y)), image.Pt(int(points[index+1].X), int(points[index+1].Y)), green, 2)
+ }
+
+ }
+ }
//return nil,nil
// 涓婁紶
- fdata,_ := gocv.IMEncode(".jpg",rook)
+ fdata, _ := gocv.IMEncode(".jpg", rook)
body := &bytes.Buffer{}
writer := multipart.NewWriter(body)
_, err1 := writer.CreateFormFile("file", "fasjuierf")
--
Gitblit v1.8.0