liuxiaolong
2019-06-28 2a447c237b95f5fb45cb5d74fe3ca71de06ba1b5
service/FaceSdkService.go
@@ -10,29 +10,31 @@
   "github.com/pkg/errors"
   "github.com/satori/go.uuid"
   "gocv.io/x/gocv"
   "io/ioutil"
   "mime/multipart"
   "sync"
   "time"
)
type FaceSdkService struct {
   File multipart.File
   File *multipart.File
   Id string
   Result []*protomsg.ResultFaceExtCom
}
const (
   Ipc_Push_Ext = "_2.ipc"
   Ipc_Pull_Ext = "_1.ipc"
   Ipc_Url_Pre = "ipc:///tmp///"
   Ipc_Push_Ext       = "_2.ipc"
   Ipc_Pull_Ext       = "_1.ipc"
   Ipc_Url_Pre        = "ipc:///tmp///"
   Virtual_FaceTaskId = "92496BDF-2BFA-98F2-62E8-96DD9866ABD2"
   Virtual_FaceSdkId = "virtual-faceextract-sdk-pull"
   Url_Service_PUSH = Ipc_Url_Pre + Virtual_FaceSdkId + Ipc_Push_Ext
   Url_Service_PULL = Ipc_Url_Pre + Virtual_FaceSdkId + Ipc_Pull_Ext
   Virtual_FaceSdkId  = "virtual-faceextract-sdk-pull"
   Url_Service_PUSH   = Ipc_Url_Pre + Virtual_FaceSdkId + Ipc_Push_Ext
   Url_Service_PULL   = Ipc_Url_Pre + Virtual_FaceSdkId + Ipc_Pull_Ext
)
func NewFaceSdkService(file multipart.File) FaceSdkService{
   return FaceSdkService{
      File:file,
      File:&file,
      Id:uuid.NewV4().String(),
   }
}
@@ -58,13 +60,18 @@
}
func (s *FaceSdkService) ReadFromUploadImg() (*protomsg.Image,error){
   defer s.File.Close()
   imgB := make([]byte,0)
   if _, err := s.File.Read(imgB);err !=nil{
   defer (*(s.File)).Close()
   imgB, err := ioutil.ReadAll(*(s.File))
   if err !=nil{
      fmt.Println("File.Read err:",err)
      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)
      return nil,err
   }
   defer picMat.Close()
@@ -74,7 +81,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")
@@ -82,25 +89,25 @@
      Width: width,
      Height: height,
      Timestamp: formatTimeStr,
      Data: data,
      Data: imgB,
      Id: timeUnix,
      Cid:s.Id,
   },nil
}
func ImgCompress(i *protomsg.Image) ([]byte,error){
   if b, err := proto.Marshal(i);err !=nil{
   if b, err := proto.Marshal(i); err != nil {
      fmt.Println("protoImage marshal err")
      return nil,err
   } else {
      bc := make([]byte,len(b))
      bc := make([]byte, len(b))
      ht := make([]int, 64<<10)
      n,err := lz4.CompressBlock(b, bc, ht)
      if err !=nil {
      n, err := lz4.CompressBlock(b, bc, ht)
      if err != nil {
         fmt.Println(err)
         return nil,err
      }
      if n >= len(b){
      if n >= len(b) {
         fmt.Println("image is not compressible")
         return nil,errors.New("compressed len is 0")
      }
@@ -109,33 +116,32 @@
   }
}
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() {
      Exit:
      for {
         select {
         case <-time.Tick(time.Second*10):
            ch <- nil
         case <-time.Tick(time.Second*2):
            fmt.Println("倒计时结束")
            wg.Done()
            return
            break Exit
         default:
            if feas,ok := resultMap[s.Id];ok {
               fmt.Println("faceFea got!!!")
               ch <- feas
               return
               s.Result = feas
               break Exit
            } else {
               fmt.Println("尚未拿到fea")
            }
         }
      }
   }()
   fmt.Println("wa.Wait")
   wg.Wait()
   msg := <- ch
   if msg != nil {
      return msg,nil
   } else {
      return msg,errors.New("no fea")
   }
   fmt.Println("<-ch")
}
func readTestImgFile() protomsg.Image{
@@ -160,13 +166,13 @@
   //gocv.IMWrite("xxx.jpg", wrMat)
   i = protomsg.Image{
      Width: width,
      Height: height,
      Width:     width,
      Height:    height,
      Timestamp: formatTimeStr,
      Data: data,
      Id: timeUnix,
      Data:      data,
      Id:        timeUnix,
   }
   i.Cid = uuid.NewV4().String()//数据唯一id
   i.Cid = uuid.NewV4().String() //数据唯一id
   fmt.Println("gocv read img completed")
   return i
}
@@ -177,11 +183,12 @@
var resultMap map[string][]*protomsg.ResultFaceExtCom
func InitService(){
func InitService() {
   fmt.Println("service init!")
   imgPushChan = make(chan []byte)
   resultMap = 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() {
@@ -193,14 +200,14 @@
   go thRecv()
}
func thSend(){
func thSend() {
   for {
      select {
      case d := <- imgPushChan:
      case d := <-imgPushChan:
         fmt.Println("imgPushChan in")
         err := client_push.Send(d)
         if err !=nil {
            fmt.Println("img Send err:",err)
         if err != nil {
            fmt.Println("img Send err:", err)
         }
      default:
         //fmt.Println("no img in")
@@ -208,19 +215,20 @@
   }
}
func thRecv(){
func thRecv() {
   for {
      resultBytes, err := client_pull.Recv()
      if err !=nil{
         fmt.Println("pull err:",err)
      if err != nil {
         //fmt.Println("pull err:", err)
         continue
      }
      rMsg := protomsg.SdkMessage{}
      if err := proto.Unmarshal(resultBytes, &rMsg);err ==nil{
         fmt.Println("received MSG:",rMsg.Cid)
      if err := proto.Unmarshal(resultBytes, &rMsg); err == nil {
         fmt.Println("received MSG:", rMsg.Cid)
         perId := rMsg.Cid //数据id
         if rMsg.Tasklab !=nil && rMsg.Tasklab.Taskid == Virtual_FaceTaskId {
         if rMsg.Tasklab != nil && rMsg.Tasklab.Taskid == Virtual_FaceTaskId {
            sdkInfos := rMsg.Tasklab.Sdkinfos
            fmt.Println("Len(sdkInfos)=",len(sdkInfos))
            for _,swt :=range sdkInfos{
               if swt.Sdktype =="FaceDetect"{
@@ -257,8 +265,8 @@
            }
         }
      } else {
         fmt.Println("recv msg Err:",err)
         fmt.Println("recv msg Err:", err)
      }
   }
}
}