From 847983cd82cff288e5b610d2bbcebbdb0398f1d6 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期六, 22 六月 2019 17:02:43 +0800
Subject: [PATCH] 补充不画区域时的情形

---
 ruleserver/ruleToformula.go |   42 ++++++++++++++++++++++++++++++++----------
 1 files changed, 32 insertions(+), 10 deletions(-)

diff --git a/ruleserver/ruleToformula.go b/ruleserver/ruleToformula.go
index ca5f321..e4be299 100644
--- a/ruleserver/ruleToformula.go
+++ b/ruleserver/ruleToformula.go
@@ -188,11 +188,17 @@
 // 灏嗗瓧绗︿覆鏍煎紡鐨勫潗鏍囧簭鍒楀寲涓篜oint鏍煎紡
 func Json2points(areaPoints string) []Point {
 	var pts []Point
-
-	err := json.Unmarshal([]byte(areaPoints), &pts)
-	if err != nil {
-		fmt.Println("json.Unmarshal閿欒", err)
-		panic("搴忓垪鍖栧潗鏍囧紓甯革紝绋嬪簭閫�鍑�")
+	if areaPoints == "" {
+		pts = append(pts,Point{0,0})
+		pts = append(pts,Point{0,540})
+		pts = append(pts,Point{960,540})
+		pts = append(pts,Point{960,0})
+	} else {
+		err := json.Unmarshal([]byte(areaPoints), &pts)
+		if err != nil {
+			fmt.Println("json.Unmarshal閿欒", err)
+			panic("搴忓垪鍖栧潗鏍囧紓甯革紝绋嬪簭閫�鍑�")
+		}
 	}
 	return pts
 }
@@ -300,14 +306,20 @@
 			filterRule(groupRule.Rules[j], &areaMap)
 		}
 		for j := 0; j < len(groupRule.Rules); j++ {
-			// 鍐嶈繃鍏朵粬鏁版嵁 杩欐鐩存帴寰楀埌缁撴灉锛堢湡鎴栧亣锛�
+			// 鍐嶈繃鍏朵粬鏁版嵁 杩欐鐩存帴寰楀埌缁撴灉锛堢湡鎴栧亣锛� 杩囩洰鏍囨暟閲�
 			flag := transferParameters(groupRule.Rules[j], &areaMap)
 			if flag != "" {
 				fmt.Println("寰楀嚭鐨勭粨鏋�", flag)
 				completeFormula = completeFormula + groupRule.Rules[j].RuleWithPre + "" + flag
 			}
 		}
-
+		if completeFormula == "" {
+			flag := splice1(&areaMap)
+			if flag != "" {
+				fmt.Println("寮鸿鎷煎噾涓�涓汉鏁版槸鍚﹀ぇ浜�0鐨勭粨鏋�", flag)
+				completeFormula = flag
+			}
+		}
 		for j := 0; j < len(groupRule.Rules); j++ {
 			// 杩欐杩囩殑鏄椂闂磋鍒欙紙鏃堕棿娈电瓑锛�
 			flag := timeRuleResult(groupRule.Rules[j], &areaMap)
@@ -316,10 +328,12 @@
 				completeFormula = completeFormula + groupRule.Rules[j].RuleWithPre + "" + flag
 			}
 		}
+
 		for j := 0; j < len(groupRule.Rules); j++ {
 			// 鏈�鍚庤繃鎸佺画鏃堕棿绛夋椂闂寸淮搴︾殑鏉′欢
 			duration(groupRule.Rules[j], &areaMap)
 		}
+
 	}
 	fmt.Println("鎷煎嚭鐨勬暟瀛﹀叕寮忎负:==== ", completeFormula)
 	if completeFormula != "" {
@@ -405,13 +419,12 @@
 					formula = strconv.FormatFloat(arg.size, 'f', -1, 64) + " " + rule.Operator + " " + rule.SdkArgValue // 寰楀埌瀛楃涓插叕寮�
 				}
 				expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡
-				result, _ := expression.Evaluate(nil)                      // 寰楀埌鏁板鍏紡鐨勭粨鏋�
+				result, _ := expression.Evaluate(nil)          // 寰楀埌鏁板鍏紡鐨勭粨鏋�
 				if result.(bool) {
 					am.filterData = append(am.filterData, arg) // 寰楀埌绗﹀悎鏉′欢鐨勮繃婊ゆ暟鎹�
 				}
 			}
 			am.targetNum = len(am.filterData) // 鎶婄鍚堟潯浠剁殑鐩爣鏁伴噺鏇存柊鍒皌argetNum瀛楁
-			//fmt.Println("绛涢�夊畬鍚庣殑鍐呭锛�", am)
 		}
 	}
 }
@@ -439,7 +452,14 @@
 		}
 	}
 }
-
+// 鍐椾綑鎷兼帴
+func splice1 (am *AreaMap) string {
+	args := am.targetNum
+	formula := strconv.Itoa(args) + " "  + ">" + "0"
+	expression, _ := govaluate.NewEvaluableExpression(formula) // 寰楀埌鏁板鍏紡
+	result, _ := expression.Evaluate(nil)                      // 寰楀埌鏁板鍏紡鐨勭粨鏋�
+	return strconv.FormatBool(result.(bool))
+}
 // 缁欐暟鎹簱鐨勮鍒欒〃杈惧紡浠e弬 args: 涓�鏉″瓙瑙勫垯锛屽尯鍩熸暟鎹�
 func transferParameters(rule *protomsg.Rule, am *AreaMap) string {
 	if rule.PolygonId == am.areaId { // 棣栧厛瑙勫垯鎵�瀵瑰簲鐨勫尯鍩焛d瑕佽窡鍖哄煙鏁版嵁鐨刬d瀵圭殑涓�
@@ -473,6 +493,8 @@
 			} else {
 				return "false"
 			}
+		} else {
+
 		}
 
 	}

--
Gitblit v1.8.0