--
panlei
2019-11-15 89128f9294bac86dee6b97fce0846040f7f86d6c
ruleserver/ruleToformula.go
@@ -102,17 +102,17 @@
   result := false
   sdkNames := ""
   polygonId := ""
   targets := []*structure.Arg{} // 符合条件的目标
   //targets11 := []*structure.Arg{} // 符合条件的目标
   // 把一帧数据和一组规则发给算法部分,得出判断结果
   result,sdkNames,polygonId = CallMiddleware(args,*groupRule,&label,message)
   for _, sdkData := range args.Sdkdata {
      for _, areaMap := range sdkData.AreaMapList {
         targets = append(targets,areaMap.AlarmObj...)
         for _,obj := range areaMap.AlarmObj {
            logger.Info("个体静止的目标",obj.Id,obj.Location,obj.CacheData)
         }
      }
   }
   //for _, sdkData := range args.Sdkdata {
   //   for _, areaMap := range sdkData.AreaMapList {
   //      targets11 = append(targets11,areaMap.AlarmObj...)
   //      for _,obj := range areaMap.AlarmObj {
   //         logger.Info("个体静止的目标",obj.Id, obj.Location, obj.CacheData.Cid, len(obj.CacheData.Data))
   //      }
   //   }
   //}
   //logger.Info("符合条件的目标数据:",targets)
   if result {
      // 最后过持续时间等时间维度的条件   把时间规则位置调整到这个位置是为了缓存数据         !!!!!ps: 对画面中单个目标做定时器的不用再过画面定时器
@@ -175,16 +175,16 @@
         }
         logger.Debug("------locations的内容:", yolos)
         // 处理目标定时数据
         //targets := []*structure.Arg{}
         //for _, sdkData := range args.Sdkdata {
         //   if sdkData.IpcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && sdkNames != "" { // 把yolo数据的各个目标的坐标输出方便后面画框
         //      for _, areaMap := range sdkData.AreaMapList {
         //         if areaMap.IsEffective {
         //            yolos = append(yolos, putTargetsToResult(areaMap)...)
         //         }
         //      }
         //   }
         //}
         targets := []*structure.Arg{}
         for _, sdkData := range args.Sdkdata {
            if sdkData.IpcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && sdkNames != "" { // 把yolo数据的各个目标的坐标输出方便后面画框
               for _, areaMap := range sdkData.AreaMapList {
                  if areaMap.IsEffective {
                     targets = append(targets, putTargetsToResult(areaMap)...)
                  }
               }
            }
         }
         var islink bool
         if groupRule.SetType == "linkTask" {
            islink = true
@@ -202,11 +202,11 @@
            //logger.Info("-------------------face结果标签", len(args.RuleResult["face"].([]FaceResult)))
            labelTypes = append(labelTypes,1)
         }
         //if len(targets) > 0 {
         //   args.RuleResult["target"] = append(args.RuleResult["target"].([]structure.Result), structure.Result{taskId, sdkNames, groupRule.GroupId, groupRule.DefenceState, groupRule.AlarmLevel, groupRule.GroupText, targets, polygonId, islink,label})
         //   //logger.Info("-------------------目标持续结果标签", len(args.RuleResult["face"].([]FaceResult)))
         //   //labelTypes = append(labelTypes,2)
         //}
         if len(targets) > 0 {
            args.RuleResult["target"] = append(args.RuleResult["target"].([]structure.Result), structure.Result{taskId, sdkNames, groupRule.GroupId, groupRule.DefenceState, groupRule.AlarmLevel, groupRule.GroupText, targets, polygonId, islink,label})
            logger.Info("-------------------目标持续结果标签", len(args.RuleResult["target"].([]structure.Result)))
            //labelTypes = append(labelTypes,2)
         }
         // 给持续时间的第一张赋予缓存数据(遍历复制)
         if cacheId != "" { // 有这帧数据的缓存
            tempMap := make(map[string]interface{})
@@ -238,6 +238,7 @@
      // 结果为假时也要走,有杀死定时器的操作
      TimerAlarm(&label, groupRule.GroupId, result)
      //fmt.Println(timeFlag)
      logger.Info("不符合规则")
      return false,[]int{}
   }
}