From fce697021526285f7e06387ea8f282d11ed25155 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期六, 29 六月 2019 16:57:23 +0800
Subject: [PATCH] 把区域数据变为指针拷贝

---
 ruleserver/ruleToformula.go |   16 ++++----
 main.go                     |   74 -------------------------------------
 2 files changed, 8 insertions(+), 82 deletions(-)

diff --git a/main.go b/main.go
index 030d6de..6dec348 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{}
diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go
index 7475b07..2b2138a 100644
--- a/ruleserver/ruleToformula.go
+++ b/ruleserver/ruleToformula.go
@@ -112,7 +112,7 @@
 	IsStatic    bool       // 鏄惁闈欐
 	ImageWidth  int        // 鎽勫儚鏈烘媿鎽勭殑鍥惧儚瀹� 鍍忕礌
 	ImageHeight int        // 鎽勫儚鏈烘媿鎽勭殑鍥惧儚楂� 鍍忕礌
-	AreaMapList []AreaMap  // 鏈瑂dk鎻愬彇鐨勬暟鎹寜鐓у尯鍩熷垝鍒嗗悗鐨勬暟鎹泦鍚�
+	AreaMapList []*AreaMap  // 鏈瑂dk鎻愬彇鐨勬暟鎹寜鐓у尯鍩熷垝鍒嗗悗鐨勬暟鎹泦鍚�
 }
 
 // 浠庣畻娉曟ā鍧楀効鎷挎潵鐨勫涓�甯у浘鍍忓悇涓畻娉曟彁鍙栫殑鏁版嵁闆嗗悎
@@ -182,8 +182,8 @@
 	for _, polygon := range cameraPolygons {
 		areaMap := AreaMap{cameraId: cameraId, areaId: polygon.Id, areaJson: polygon.Polygon, triggerLine: polygon.TriggerLine, directionLine: polygon.DirectionLine}
 		// 涓烘瘡涓憚鍍忔満鍖哄煙濉厖鏁版嵁
-		areaMap.CountAreaObjs(arg)
-		arg.AreaMapList = append(arg.AreaMapList, areaMap)
+		(&areaMap).CountAreaObjs(arg)
+		arg.AreaMapList = append(arg.AreaMapList, &areaMap)
 	}
 }
 
@@ -234,7 +234,7 @@
 				log.Println("鍏ヤ镜鐨勭畻娉曟暟鎹�",sdkData)
 			}
 			for _, areaMap := range sdkData.AreaMapList {
-				ruleResult := filterRule(groupRule.Rules[j], &areaMap)
+				ruleResult := filterRule(groupRule.Rules[j], areaMap)
 				if ruleResult.Result != "" {
 					log.Println("鏉′欢瑙勫垯缁撴灉锛�", ruleResult.Result)
 					resultSplice = append(resultSplice, &ruleResult)
@@ -247,7 +247,7 @@
 	for _, sdkData := range args.Sdkdata {
 		for _, areaMap := range sdkData.AreaMapList {
 			for j := 0; j < len(groupRule.Rules); j++ {
-				putFaceToResult(groupRule.Rules[j], &areaMap, faces)
+				putFaceToResult(groupRule.Rules[j], areaMap, faces)
 			}
 		}
 	}
@@ -256,7 +256,7 @@
 	for j := 0; j < len(groupRule.Rules); j++ {
 		for _, sdkData := range args.Sdkdata {
 			for _, areaMap := range sdkData.AreaMapList {
-				ruleResult := transferParameters(groupRule.Rules[j], &areaMap)
+				ruleResult := transferParameters(groupRule.Rules[j], areaMap)
 				if ruleResult.Result != "" {
 					log.Println("鏁伴噺瑙勫垯缁撴灉锛�", ruleResult.Result)
 					resultSplice = append(resultSplice, &ruleResult)
@@ -268,7 +268,7 @@
 	for j := 0; j < len(groupRule.Rules); j++ {
 		for _, sdkData := range args.Sdkdata {
 			for _, areaMap := range sdkData.AreaMapList {
-				ruleResult := timeRuleResult(groupRule.Rules[j], &areaMap)
+				ruleResult := timeRuleResult(groupRule.Rules[j], areaMap)
 				if ruleResult.Result != "" {
 					log.Println("鏃堕棿瑙勫垯缁撴灉锛�", ruleResult.Result)
 					resultSplice = append(resultSplice, &ruleResult)
@@ -280,7 +280,7 @@
 	for j := 0; j < len(groupRule.Rules); j++ {
 		for _, sdkData := range args.Sdkdata {
 			for _, areaMap := range sdkData.AreaMapList {
-				duration(groupRule.Rules[j], &areaMap)
+				duration(groupRule.Rules[j], areaMap)
 			}
 		}
 	}

--
Gitblit v1.8.0