liuxiaolong
2019-06-29 bc86eeeefb27f73c28c44cd63624ef3c8ac2448c
service/FaceSdkService.go
@@ -19,6 +19,7 @@
type FaceSdkService struct {
   File *multipart.File
   Id string
   Result []*protomsg.ResultFaceExtCom
}
const (
@@ -115,33 +116,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*10):
            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
            }
         }
      }
   }()
   }(ticker, s)
   wg.Wait()
   msg := <- ch
   if msg != nil {
      return msg,nil
   } else {
      return msg,errors.New("no fea")
   }
}
func readTestImgFile() protomsg.Image{
@@ -181,14 +176,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() {
@@ -251,7 +262,7 @@
                  } else {
                     fmt.Println("目标数:",len(pff.ExtComp))
                     if len(pff.ExtComp) >0 {
                        resultMap[rMsg.Cid] = pff.ExtComp
                        resultMap.Write(perId,pff.ExtComp)
                        for _,fea :=range pff.ExtComp{
                           base64Fea := base64.StdEncoding.EncodeToString(fea.Feats)