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