From a2300d14405b2140728a64a50c6a1a8449310551 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期一, 01 七月 2019 16:39:55 +0800
Subject: [PATCH] ---测试

---
 main.go |  129 ++++++++++++++++--------------------------
 1 files changed, 50 insertions(+), 79 deletions(-)

diff --git a/main.go b/main.go
index 030d6de..109f41c 100644
--- a/main.go
+++ b/main.go
@@ -54,80 +54,6 @@
 	}
 }
 
-// 灏嗗閮ㄤ紶杩涙潵鐨剆dk鏁版嵁鍖呰В鎴� ArgsFromSdk
-//func paramFormat(msg []byte, arg *ruleserver.ArgsFromSdk) protomsg.SdkMessage {
-//	defer func() {
-//		if err := recover(); err != nil {
-//			fmt.Println("瑙e寘杩囩▼鐨勯敊璇�", err.(string))
-//		}
-//
-//	}()
-//	// 鍙嶅簭鍒楀寲鏁版嵁寰楀埌sdk鍏ュ弬
-//	m := protomsg.SdkMessage{}
-//	err := proto.Unmarshal(msg, &m)
-//	if err != nil {
-//		panic("瑙f瀽msg鏃跺嚭鐜伴敊璇�")
-//	}
-//	arg.CameraId = m.Cid
-//	arg.TaskId = m.Tasklab.Taskid
-//	bdata, err := util.UnCompress(m.Data)
-//	if err != nil {
-//		panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
-//	}
-//	i := protomsg.Image{}
-//	err = proto.Unmarshal(bdata, &i)
-//	arg.ImageWidth = int(i.Width)
-//	arg.ImageHeight = int(i.Height)
-//	// 鏆傛椂鍐欐锛宻dk杩樻病鏈夎繖淇╃畻娉�
-//	arg.KeepRight = false
-//	arg.IsStatic = false
-//	for _, sdkinfo := range m.Tasklab.Sdkinfos { // yolo绠楁硶
-//		if sdkinfo.Sdktype == "Yolo" {
-//			if len(sdkinfo.Sdkdata) > 1 {
-//				// 澶т簬1鎵嶆湁鏁版嵁
-//				fmt.Println("----------------------------------------------------",m.Caddr)
-//				yoloParam := protomsg.ParamYoloObj{}
-//				err = proto.Unmarshal(sdkinfo.Sdkdata, &yoloParam)
-//				if err != nil {
-//					fmt.Println("瑙f瀽YOLO sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
-//					continue
-//				}
-//				for _, info := range yoloParam.Infos {
-//					if info.Typ == 0 {
-//						photoMap := ruleserver.PhotoMap{Rects: rectFormat(info.RcObj), Score: float64(info.Prob)*100,IsYolo:true}
-//						arg.Photo = append(arg.Photo, photoMap)
-//					}
-//				}
-//			} else {
-//				continue
-//			}
-//
-//		}
-//		if sdkinfo.Sdktype == "FaceDetect" { // 浜鸿劯妫�娴�
-//			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
-//				}
-//				for _, info := range faceParam.Faces {
-//					photoMap := ruleserver.PhotoMap{Rects: rectFormat(info.Pos.RcFace), Score: float64(info.Pos.Quality), IsYolo:false,ThftRes:*(info.Result)}
-//					arg.Photo = append(arg.Photo, photoMap)
-//				}
-//			} else {
-//				continue
-//			}
-//		}
-//		//if sdkinfo.Sdktype == "FaceExtract" { // 浜鸿劯鎻愬彇
-//
-//		//}
-//
-//	}
-//	return m
-//}
-
 // 灏嗗閮ㄤ紶杩涙潵鐨剅ect锛坱op,bottom,left,right锛夎浆鍖栦负鑷繁鍐呴儴鐨剅ect(left top width height)
 func rectFormat(rcobj *protomsg.Rect) ruleserver.Rect {
 	rect := ruleserver.Rect{}
@@ -153,6 +79,14 @@
 		panic("瑙f瀽msg鏃跺嚭鐜伴敊璇�")
 	}
 	args.CameraId = m.Cid
+	// 鎶婂浘鐗囩殑浜岃繘鍒惰В鍘嬬缉杩涜鐢绘鍦ㄥ帇缂╁洖鍘�
+	bdata, err := util.UnCompress(m.Data)
+	if err != nil {
+		panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
+	}
+	i := protomsg.Image{}
+	err = proto.Unmarshal(bdata, &i)
+
 	for _, sdkinfo := range m.Tasklab.Sdkinfos { // yolo绠楁硶
 		if sdkinfo.Sdktype == "Yolo" {
 			arg := ruleserver.SdkData{}
@@ -186,7 +120,7 @@
 						arg.Photo = append(arg.Photo, photoMap)
 					}
 				}
-				args.Sdkdata = append(args.Sdkdata,arg)
+				args.Sdkdata = append(args.Sdkdata,&arg)
 			} else {
 				continue
 			}
@@ -221,14 +155,51 @@
 					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)
 				}
-				args.Sdkdata = append(args.Sdkdata,arg)
+				args.Sdkdata = append(args.Sdkdata,&arg)
 			} else {
 				continue
 			}
 		}
-		//if sdkinfo.Sdktype == "FaceExtract" { // 浜鸿劯鎻愬彇
-
-		//}
+		if sdkinfo.Sdktype == "FaceExtract" { // 浜鸿劯鎻愬彇
+			arg := ruleserver.SdkData{}
+			arg.TaskId = m.Tasklab.Taskid
+			arg.SdkId = sdkinfo.Sdkid
+			arg.SdkName = sdkinfo.SdkName
+			arg.IsYolo = false
+			bdata, err := util.UnCompress(m.Data)
+			if err != nil {
+				panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
+			}
+			i := protomsg.Image{}
+			err = proto.Unmarshal(bdata, &i)
+			arg.ImageWidth = int(i.Width)
+			arg.ImageHeight = int(i.Height)
+			// 鏆傛椂鍐欐锛宻dk杩樻病鏈夎繖淇╃畻娉�
+			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
+				}
+				for _, extComp := range faceParam.ExtComp {
+					baseinfos := protomsg.Binfos{}
+					err1 := proto.Unmarshal(extComp.Comp, &baseinfos)
+					if err1 != nil {
+						fmt.Println("瑙f瀽FACE sdk鏁版嵁鏃跺嚭鐜伴敊璇�", err)
+						continue
+					}
+					photoMap := ruleserver.PhotoMap{Rects: rectFormat(extComp.Pos.Pos.RcFace), Score: float64(extComp.Pos.Pos.Quality)*100, IsYolo:false,ThftRes:*(extComp.Pos.Result),Liker:baseinfos.Infos}
+					arg.Photo = append(arg.Photo, photoMap)
+				}
+				args.Sdkdata = append(args.Sdkdata,&arg)
+			} else {
+				continue
+			}
+		}
 
 	}
 	return m

--
Gitblit v1.8.0