---
panlei
2019-12-16 0e28dd6942c8a7207146f6a6b542bc45f75462b0
algorithm/middleware/middleware.go
@@ -73,6 +73,7 @@
               //logger.Info("当前走的规则是--:", groupRule.Rules[j],sdkName,groupRule.Rules[j].SdkArgAlias, "---","")
               for _, areaMap := range sdkData.AreaMapList {
                  ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message)
                  logger.Info("前置连接符:",groupRule.Rules[j])
                  if groupRule.Rules[j].RuleWithPre == "⊇" {
                     assembleDta(args,groupRule.Rules[j-1],groupRule.Rules[j])
                     // 把当前小规则结果置空
@@ -99,41 +100,41 @@
      }
   }
   // 人脸
   //for j := 0; j < len(groupRule.Rules); j++ {
   //   if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && groupRule.Rules[j].SdkArgAlias != "time_rule"{
   //      for _, sdkData := range args.Sdkdata {
   //         // 根据规则的sdkId查出其对应的ipcId,用ipcId去找该比对的数据
   //         sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId)
   //         if err != nil {
   //            logger.Error("没查到sdk的信息---", err)
   //         }
   //         ipcId := sdk.IpcId
   //         sdkName := sdk.SdkName
   //         //logger.Info("规则的ipcId与sdkData的IpcId:", ipcId, "===", sdkData.IpcId)
   //         if ipcId == sdkData.IpcId {
   //            //logger.Info("当前走的规则是--:", sdkName, "---","")
   //            for _, areaMap := range sdkData.AreaMapList {
   //               ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message)
   //               if ruleResult.Result != "" {
   //                  //logger.Info("人脸比对规则结果:", ruleResult.Result)
   //                  // 如果结果为真,把这条规则中的区域置为有效
   //                  if strings.Contains(ruleResult.Result, "true") {
   //                     areaMap.IsEffective = true
   //                  }
   //                  // 如果此结果为真且当前过的是yolo算法,应记下此规则所对应的sdkName,另外,还要去重 (后加:把此条触碰的区域id也记录下来)
   //                  if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(sdkNames, sdkName) {
   //                     sdkNames = sdkName + " "
   //                  }
   //                  if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(polygonId, groupRule.Rules[j].PolygonId) {
   //                     polygonId += groupRule.Rules[j].PolygonId + ","
   //                  }
   //                  resultSplice = append(resultSplice, &ruleResult)
   //               }
   //            }
   //         }
   //      }
   //   }
   //}
   for j := 0; j < len(groupRule.Rules); j++ {
      if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a972" && groupRule.Rules[j].SdkArgAlias != "time_rule"{
         for _, sdkData := range args.Sdkdata {
            // 根据规则的sdkId查出其对应的ipcId,用ipcId去找该比对的数据
            sdk, err := cache.GetSdkById(groupRule.Rules[j].SdkId)
            if err != nil {
               logger.Error("没查到sdk的信息---", err)
            }
            ipcId := sdk.IpcId
            sdkName := sdk.SdkName
            //logger.Info("规则的ipcId与sdkData的IpcId:", ipcId, "===", sdkData.IpcId)
            if ipcId == sdkData.IpcId {
               //logger.Info("当前走的规则是--:", sdkName, "---","")
               for _, areaMap := range sdkData.AreaMapList {
                  ruleResult := CallSo(sdk.Id, groupRule.Rules[j], areaMap,lable,args,message)
                  if ruleResult.Result != "" {
                     //logger.Info("人脸比对规则结果:", ruleResult.Result)
                     // 如果结果为真,把这条规则中的区域置为有效
                     if strings.Contains(ruleResult.Result, "true") {
                        areaMap.IsEffective = true
                     }
                     // 如果此结果为真且当前过的是yolo算法,应记下此规则所对应的sdkName,另外,还要去重 (后加:把此条触碰的区域id也记录下来)
                     if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(sdkNames, sdkName) {
                        sdkNames = sdkName + " "
                     }
                     if strings.Contains(ruleResult.Result, "true") && ipcId == "02D54B61-0F16-C604-8567-FC4BE493C523" && !strings.Contains(polygonId, groupRule.Rules[j].PolygonId) {
                        polygonId += groupRule.Rules[j].PolygonId + ","
                     }
                     resultSplice = append(resultSplice, &ruleResult)
                  }
               }
            }
         }
      }
   }
   // 个体静止
   for j := 0; j < len(groupRule.Rules); j++ {
      if groupRule.Rules[j].SdkId == "812b674b-2375-4589-919a-5c1c3278a977" && groupRule.Rules[j].SdkArgAlias == "duration"{
@@ -376,7 +377,7 @@
      soName = "static.so"
   case "812b674b-2375-4589-919a-5c1c3278a978":
      soName = "plate.so"
   case "人体跟踪":
   case "520af340-f257-4fe2-ac3c-695c390e53dc":
      soName = "personTrack.so"
   }
   //soInfo,err := cache.GetSoInfoById(sdkId)
@@ -473,7 +474,7 @@
// 如果规则组中有包含符号,把规则组之后的规则对应的算法和区域提取的数据装配到前面去
func assembleDta(args *structure.SdkDatas,rule1,rule2 *protomsg.Rule) {
      // 拿到后面的那个区域的数据
      logger.Info("触发了包含事件,把后者的数据给到前者")
      logger.Info("触发了包含事件,把后者的数据给到前者",*rule1,*rule2)
      area := structure.AreaMap{}
      for _, sdkData := range args.Sdkdata {
         for _, areaMap := range sdkData.AreaMapList {