From 74d4fab8af3e8197e09ee2b32c07049ca0f7fda5 Mon Sep 17 00:00:00 2001
From: liuxiaolong <736321739@qq.com>
Date: 星期六, 29 六月 2019 14:00:17 +0800
Subject: [PATCH] fix swagger bug

---
 service/FaceSdkService.go |  109 +++++++++++++++++++++++++++++-------------------------
 1 files changed, 59 insertions(+), 50 deletions(-)

diff --git a/service/FaceSdkService.go b/service/FaceSdkService.go
index 64e5f6c..762ecbf 100644
--- a/service/FaceSdkService.go
+++ b/service/FaceSdkService.go
@@ -19,6 +19,7 @@
 type FaceSdkService struct {
 	File *multipart.File
 	Id string
+	Result []*protomsg.ResultFaceExtCom
 }
 
 const (
@@ -66,8 +67,6 @@
 		return nil,err
 	}
 
-	fmt.Println("imgB.len:",len(imgB))
-
 	picMat, err := gocv.IMDecode(imgB, gocv.IMReadColor)
 	if err !=nil {
 		fmt.Println("gocv.IMDecode err:",err)
@@ -80,7 +79,7 @@
 	}
 	height := int32(picMat.Rows())
 	width := int32(picMat.Cols())
-	//data := picMat.ToBytes()
+	data := picMat.ToBytes()
 	timeUnix := time.Now().Unix()
 	formatTimeStr := time.Unix(timeUnix, 0).Format("2006-01-02 15:04:05")
 
@@ -88,7 +87,7 @@
 		Width: width,
 		Height: height,
 		Timestamp: formatTimeStr,
-		Data: imgB,
+		Data: data,
 		Id: timeUnix,
 		Cid:s.Id,
 	},nil
@@ -115,38 +114,27 @@
 	}
 }
 
-func (s *FaceSdkService) GetFaceFea() (feas []*protomsg.ResultFaceExtCom,err error){
+func (s *FaceSdkService) GetFaceFea(){
 	var wg sync.WaitGroup
 	wg.Add(1)
-	ch := make(chan []*protomsg.ResultFaceExtCom,0)
-	go func() {
+	ticker := time.NewTicker(time.Second * 3)
+	go func(ticker *time.Ticker, s *FaceSdkService) {
+		defer ticker.Stop()
+		defer wg.Done()
+
 		for {
 			select {
-			case <-time.Tick(time.Second*5):
-				fmt.Println("鍊掕鏃剁粨鏉�")
-				ch <- nil
-				wg.Done()
+			case <-ticker.C:
 				return
 			default:
-				if feas,ok := resultMap[s.Id];ok {
-					fmt.Println("faceFea got!!!")
-					ch <- feas
+				if feas,ok := resultMap.Get(s.Id);ok {
+					s.Result = feas
 					return
-				} else {
-					fmt.Println("灏氭湭鎷垮埌fea")
 				}
 			}
 		}
-	}()
-	fmt.Println("wa.Wait")
+	}(ticker, s)
 	wg.Wait()
-	fmt.Println("<-ch")
-	msg := <- ch
-	if msg != nil {
-		return msg,nil
-	} else {
-		return msg,errors.New("no fea")
-	}
 }
 
 func readTestImgFile() protomsg.Image{
@@ -186,14 +174,30 @@
 	imgPushChan <- is
 }
 
-var resultMap map[string][]*protomsg.ResultFaceExtCom
+type FeaResult struct {
+	FeaM map[string][]*protomsg.ResultFaceExtCom
+	Lock sync.Mutex
+}
+
+func (f *FeaResult) Write(id string,faceResult []*protomsg.ResultFaceExtCom){
+	f.Lock.Lock()
+	defer f.Lock.Unlock()
+	f.FeaM[id] = faceResult
+}
+
+func (f *FeaResult) Get(id string) ([]*protomsg.ResultFaceExtCom,bool){
+	f.Lock.Lock()
+	defer f.Lock.Unlock()
+	coms,ok := f.FeaM[id]
+	return coms,ok
+}
+
+var resultMap =  FeaResult{}
 
 func InitService() {
 	fmt.Println("service init!")
 	imgPushChan = make(chan []byte)
-
-	resultMap = make(map[string][]*protomsg.ResultFaceExtCom,0)
-
+	resultMap.FeaM = make(map[string][]*protomsg.ResultFaceExtCom,0)
 	client_push = deliver.NewClient(deliver.PushPull, Url_Service_PUSH)
 	client_pull = deliver.NewClient(deliver.PushPull, Url_Service_PULL)
 	defer func() {
@@ -237,35 +241,40 @@
 				fmt.Println("Len(sdkInfos)=",len(sdkInfos))
 				for _,swt :=range sdkInfos{
 					if swt.Sdktype =="FaceDetect"{
-						fmt.Println("浜鸿劯妫�娴嬬粨鏋�")
-						var pfp protomsg.ParamFacePos
-						err := proto.Unmarshal(swt.Sdkdata, &pfp)
-						if err !=nil {
-							fmt.Println("faceDetect result unmarshal err:",err)
-						} else {
-							for _,face :=range pfp.Faces{
-								fmt.Println("FacePos:",face.Pos)
-								fmt.Println("ThftResult:",face.Result)
+						fmt.Println("浜鸿劯妫�娴嬬粨鏋滈暱搴︼細",len(swt.Sdkdata))
+						if len(swt.Sdkdata)>1{
+							var pfp protomsg.ParamFacePos
+							err := proto.Unmarshal(swt.Sdkdata, &pfp)
+							if err !=nil {
+								fmt.Println("faceDetect result unmarshal err:",err)
+							} else {
+								for _,face :=range pfp.Faces{
+									fmt.Println("FacePos:",face.Pos)
+									fmt.Println("ThftResult:",face.Result)
+								}
 							}
 						}
 					}
 					if swt.Sdktype == "FaceExtract"{
-						var pff protomsg.ParamFaceFeature
-						if err := proto.Unmarshal(swt.Sdkdata, &pff);err !=nil{
-							//fmt.Println("ParamFaceFeature unmarshal err:",err)
-						} else {
-							fmt.Println("鐩爣鏁帮細",len(pff.ExtComp))
-							if len(pff.ExtComp) >0 {
-								resultMap[rMsg.Cid] = pff.ExtComp
+						fmt.Println("浜鸿劯鎻愬彇缁撴灉闀垮害:",len(swt.Sdkdata))
+						if len(swt.Sdkdata) > 1{
+							var pff protomsg.ParamFaceFeature
+							if err := proto.Unmarshal(swt.Sdkdata, &pff);err !=nil{
+								//fmt.Println("ParamFaceFeature unmarshal err:",err)
+							} else {
+								fmt.Println("鐩爣鏁帮細",len(pff.ExtComp))
+								if len(pff.ExtComp) >0 {
+									resultMap.Write(perId,pff.ExtComp)
 
-								for _,fea :=range pff.ExtComp{
-									base64Fea := base64.StdEncoding.EncodeToString(fea.Feats)
-									fmt.Println("perId:",perId)
-									fmt.Println("faceFeature:",base64Fea)
+									for _,fea :=range pff.ExtComp{
+										base64Fea := base64.StdEncoding.EncodeToString(fea.Feats)
+										fmt.Println("perId:",perId)
+										fmt.Println("faceFeature:",base64Fea)
+									}
 								}
 							}
+							break
 						}
-						break
 					}
 				}
 			}

--
Gitblit v1.8.0