liuxiaolong
2019-06-29 075988e5e4325c40413103f7b177f1ee30eaa6fe
service/FaceSdkService.go
@@ -67,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)
@@ -81,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")
@@ -89,7 +87,7 @@
      Width: width,
      Height: height,
      Timestamp: formatTimeStr,
      Data: imgB,
      Data: data,
      Id: timeUnix,
      Cid:s.Id,
   },nil
@@ -119,31 +117,24 @@
func (s *FaceSdkService) GetFaceFea(){
   var wg sync.WaitGroup
   wg.Add(1)
   ticker := time.NewTicker(time.Second * 2)
   ticker := time.NewTicker(time.Second * 3)
   go func(ticker *time.Ticker, s *FaceSdkService) {
      defer ticker.Stop()
      Exit:
      defer wg.Done()
      for {
         select {
         case <-ticker.C:
            fmt.Println("倒计时结束")
            wg.Done()
            break Exit
            return
         default:
            if feas,ok := resultMap[s.Id];ok {
               fmt.Println("faceFea got!!!")
            if feas,ok := resultMap.Get(s.Id);ok {
               s.Result = feas
               wg.Done()
               break Exit
            } else {
               //fmt.Println("尚未拿到fea")
               return
            }
         }
      }
   }(ticker, s)
   fmt.Println("wa.Wait")
   wg.Wait()
   fmt.Println("<-ch")
}
func readTestImgFile() protomsg.Image{
@@ -183,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() {
@@ -234,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
               }
            }
         }