From f7cf5c4efc4024f4a998dffa1d4c11075c3f7f19 Mon Sep 17 00:00:00 2001
From: xyc <jc_xiong@hotmail.com>
Date: 星期二, 05 三月 2024 16:11:00 +0800
Subject: [PATCH] 修改RBD解析

---
 modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java |  353 ++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 197 insertions(+), 156 deletions(-)

diff --git a/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java b/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
index 4f9991b..f1089bf 100644
--- a/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
+++ b/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
@@ -2,11 +2,10 @@
 
 import cn.hutool.json.JSONArray;
 import cn.hutool.json.JSONObject;
-import com.alibaba.excel.util.DateUtils;
-import com.spire.pdf.tables.table.convert.Convert;
 import com.zt.common.service.BaseService;
 import com.zt.common.utils.JsonUtils2;
 import com.zt.common.utils.UUIDUtil;
+import com.zt.life.modules.taskReliability.dao.AlgorithmDao;
 import com.zt.life.modules.taskReliability.dao.ModelLineDao;
 import com.zt.life.modules.taskReliability.dao.ModelNodeDao;
 import com.zt.life.modules.taskReliability.dao.ModelRbdDao;
@@ -20,7 +19,6 @@
 import com.zt.common.db.query.QueryFilter;
 import org.springframework.transaction.annotation.Transactional;
 
-import javax.annotation.Resource;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -39,6 +37,8 @@
     private ModelNodeDao modelNodeDao;
     @Autowired
     private ModelRbdDao modelRbdDao;
+    @Autowired
+    private AlgorithmDao algorithmDao;
 
     /**
      * 鍒嗛〉鏌ヨ
@@ -50,8 +50,8 @@
         return baseDao.getList(queryFilter.getQueryParams());
     }
 
-    public ModelRbd getDiagram() {
-        return modelRbdDao.getDiagram(1L);
+    public ModelRbd getDiagram(Long modelId) {
+        return modelRbdDao.getDiagram(modelId);
     }
 
     /**
@@ -71,13 +71,10 @@
 
         // 鍒犻櫎鏃㈡湁鏁版嵁
         modelRbdDao.deleteByModelId(modelId);
-        modelNodeDao.deleteByModelId(modelId);
-        modelLineDao.deleteByModelId(modelId);
 
         // 鎻掑叆鏁版嵁
         modelRbd.setId(UUIDUtil.generateId());
         modelRbdDao.insert(modelRbd);
-        analyzeRbdAndSave(modelId, modelRbd.getContent());
     }
 
     @Transactional(rollbackFor = Exception.class)
@@ -88,204 +85,248 @@
 
         // 鍒犻櫎鏃㈡湁鏁版嵁
         modelRbdDao.deleteByModelId(modelId);
-        modelNodeDao.deleteByModelId(modelId);
-        modelLineDao.deleteByModelId(modelId);
 
         // 鎻掑叆鏁版嵁
         modelRbd.setId(UUIDUtil.generateId());
         modelRbdDao.insert(modelRbd);
-        analyzeRbdAndSave(modelId, modelRbd.getContent());
     }
 
-    public void analyzeRbdAndSave(Long modelId, String content) {
+    @Transactional(rollbackFor = Exception.class)
+    public void analyze(ModelRbd modelRbd) {
+        if (modelRbd==null) return;
+        if (modelRbd.getModelId()==null) return;
+        Long modelId = modelRbd.getModelId();
+
+        analyzeRbdAndSave(modelId, modelRbd.getContent(), true);
+    }
+
+    public void analyzeRbdAndSave(Long modelId, String content, boolean saveFlag) {
         String diagramJsonStr = content;
 //        String diagramJsonStr = "{\"cells\":[{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"26d1a5a6-0be8-4890-86a0-a33d429e6673\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"f2286e46-84c7-4702-8670-d7cda22c34e5\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"2ab8b7f8-7fe2-490f-89c5-4250d4a62a78\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"700c05a5-f151-4b28-8135-705ccf013522\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"feef2a57-3c72-4d69-92a6-c828c736b61a\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"80d3bd61-1ed3-493a-b4e8-d4576e6fbfda\"},\"target\":{\"cell\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"49e36d6f-6a94-4edc-9894-6dd825091706\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"ed8c1bfa-c0a6-4e9b-8697-862aef109bcf\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"70c6b5fb-1b48-4a2f-bacd-be0284134818\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"6a134969-623b-428e-9b0c-436bae2d6608\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"51de5faf-1766-4dd1-abd0-eec2e867a322\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"port\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#A2B1C3\"}},\"id\":\"161f78dc-1f44-4e43-9ced-e39d345aac78\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"port\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}},{\"position\":{\"x\":-350,\"y\":-280},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":1,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-350,\"y\":-180},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":2,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-620,\"y\":-200},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"start\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/start.88f586e1.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"data\":{\"dataId\":\"\",\"nodeType\":\"start\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"2ad6a8d5-d86d-49e6-908a-d317b61997c1\"},{\"group\":\"right\",\"id\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},{\"group\":\"bottom\",\"id\":\"7048578f-94d9-4f75-b653-eb5f43ff55db\"},{\"group\":\"left\",\"id\":\"e7bb1134-4b4c-401d-89ea-e77ae24cbd03\"}]},\"zIndex\":3,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-153,\"y\":-240},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"switchRight\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/switchRight.74768797.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"data\":{\"dataId\":\"\",\"nodeType\":\"switchRight\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"adceedb7-f842-4d1e-be3a-8b3cb0a7e3ce\"},{\"group\":\"right\",\"id\":\"80d3bd61-1ed3-493a-b4e8-d4576e6fbfda\"},{\"group\":\"bottom\",\"id\":\"8fa84779-80b2-4c91-8366-7dd4fa0d93ff\"},{\"group\":\"left\",\"id\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}]},\"zIndex\":4},{\"position\":{\"x\":-21,\"y\":-240},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":5,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":170,\"y\":-100},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"end\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/end.814a7041.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"data\":{\"dataId\":\"\",\"nodeType\":\"end\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"223c9b3a-6baa-4bb8-99ba-c3300db9a942\"},{\"group\":\"right\",\"id\":\"2806bc8a-4e11-4657-9af9-089907985671\"},{\"group\":\"bottom\",\"id\":\"c56eed35-95fa-4e3c-adba-9847ef705e1c\"},{\"group\":\"left\",\"id\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}]},\"zIndex\":6},{\"position\":{\"x\":-350,\"y\":-54},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":7},{\"position\":{\"x\":-330,\"y\":40},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":8},{\"position\":{\"x\":-153,\"y\":-20},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":9,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]}]}";
 
         JSONObject diagramJson = new JSONObject(diagramJsonStr);
         JSONArray diagramJsonArray = diagramJson.getJSONArray("cells");
+        if (diagramJsonArray == null) return;
+
         List<ModelLine> modelLineList = new ArrayList<>();
         List<ModelNode> modelNodeList = new ArrayList<>();
-
-        if (diagramJsonArray != null) {
-            for (int i = 0; i < diagramJsonArray.size(); i++) {
-                JSONObject jsonObject = diagramJsonArray.getJSONObject(i);
-                String shape = jsonObject.get("shape").toString();
-                if (shape.equals("edge")) {
-                    ModelLine modelLine = new ModelLine();
-                    modelLine.setId(UUIDUtil.generateId());
-                    modelLine.setPicId(jsonObject.get("id").toString());
-                    modelLine.setModelId(modelId);
-                    modelLine.setBeginCell(JsonUtils2.getJsonValueByPath(jsonObject, "source/cell".split("/")).toString());
-                    modelLine.setEndCell(JsonUtils2.getJsonValueByPath(jsonObject, "target/cell".split("/")).toString());
-                    //modelLineDao.insert(modelLine);
-                    modelLineList.add(modelLine);
-                } else if (shape.equals("image")){
-                    ModelNode modelNode = new ModelNode();
-                    modelNode.setId(UUIDUtil.generateId());
-                    modelNode.setPicId(jsonObject.get("id").toString());
-                    modelNode.setModelId(modelId);
-                    modelNode.setNodeType(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeType".split("/")).toString());
-                    if ("node".equals(modelNode.getNodeType())) {
-                        modelNode.setDataId(Long.valueOf(JsonUtils2.getJsonValueByPath(jsonObject, "data/dataId".split("/")).toString()));
-                        modelNode.setNodeTypeExt(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeTypeExt".split("/")).toString());
-                    }
-                    modelNodeList.add(modelNode);
-                    //modelNodeDao.insert(modelNode);
+        // 1. 瑙f瀽鍑鸿妭鐐逛笌杈�
+        for (int i = 0; i < diagramJsonArray.size(); i++) {
+            JSONObject jsonObject = diagramJsonArray.getJSONObject(i);
+            String shape = jsonObject.get("shape").toString();
+            if (shape.equals("edge")) {
+                ModelLine modelLine = new ModelLine();
+                modelLine.setId(UUIDUtil.generateId());
+                modelLine.setPicId(jsonObject.get("id").toString());
+                modelLine.setModelId(modelId);
+                modelLine.setBeginCell(JsonUtils2.getJsonValueByPath(jsonObject, "source/cell".split("/")).toString());
+                modelLine.setEndCell(JsonUtils2.getJsonValueByPath(jsonObject, "target/cell".split("/")).toString());
+                modelLineList.add(modelLine);
+            } else if (shape.equals("image")){
+                ModelNode modelNode = new ModelNode();
+                modelNode.setId(UUIDUtil.generateId());
+                modelNode.setPicId(jsonObject.get("id").toString());
+                modelNode.setModelId(modelId);
+                modelNode.setNodeType(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeType".split("/")).toString());
+                if ("node".equals(modelNode.getNodeType())) {
+                    modelNode.setDataId(Long.valueOf(JsonUtils2.getJsonValueByPath(jsonObject, "data/dataId".split("/")).toString()));
+                    modelNode.setNodeTypeExt(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeTypeExt".split("/")).toString());
                 }
+                modelNodeList.add(modelNode);
             }
         }
 
-        for (ModelLine line : modelLineList) {
-            String beginCell = line.getBeginCell();
-            String endCell = line.getEndCell();
-            List<ModelNode> modelNodeList2 = modelNodeList.stream().filter(item->item.getPicId().equals(beginCell)).collect(Collectors.toList());
-//            if (modelNodeList2.size()>0){
-//                line.setBeginNode(modelNodeList2.get(0).getDataId());
-//            }
-            List<ModelNode> modelNodeList3 = modelNodeList.stream().filter(item->item.getPicId().equals(endCell)).collect(Collectors.toList());
-//            if (modelNodeList3.size()>0){
-//                line.setEndNode(modelNodeList3.get(0).getDataId());
-//            }
-        }
-
-        for (ModelNode modelNode : modelNodeList) {
+        // 2. 瀵逛簬鏈夊鏍瑰叆鍙g嚎鐨勪骇鍝佽妭鐐癸紝灏嗗叾涓婄殑琛ㄥ喅銆佹梺鑱斻�佸苟鑱斿叧绯诲墺绂绘垚杩愮畻绗﹁妭鐐癸紝娣诲姞鍒拌浜у搧鑺傜偣鐨勫墠闈紝骞舵坊鍔犵浉搴旂殑杈�
+        List<ModelNode> nodesToAdd = new ArrayList<>();
+        List<ModelLine> linesToAdd = new ArrayList<>();
+        for (ModelNode modelNode: modelNodeList) {
             String picId = modelNode.getPicId();
             List<ModelLine> lineList = modelLineList.stream().filter(item->item.getEndCell().equals(picId)).collect(Collectors.toList());
             if (lineList.size()>1){
-                if ("node".contains(modelNode.getNodeType())){
-                    String nodeTypeExt = modelNode.getNodeTypeExt();
+                if ("node,end".contains(modelNode.getNodeType())){
+                    String nodeTypeExt = "";
+                    if ("node".equals(modelNode.getNodeType())) {
+                        nodeTypeExt = modelNode.getNodeTypeExt();
+                    } else if ("end".equals(modelNode.getNodeType())) {
+                        nodeTypeExt = "parallel";
+                    }
                     if (StringUtils.isNotBlank(nodeTypeExt)){
                         ModelNode modelNodeNew =  new ModelNode();
-                        Long dataId = UUIDUtil.generateId();
-                        modelNodeNew.setId(dataId);
-                        modelNodeNew.setPicId(dataId.toString());
+                        Long nodeNewId = UUIDUtil.generateId();
+                        modelNodeNew.setId(nodeNewId);
+                        modelNodeNew.setPicId(nodeNewId.toString());
                         modelNodeNew.setModelId(modelId);
                         modelNodeNew.setNodeType(nodeTypeExt);
-                        modelNodeList.add(modelNode);
+                        nodesToAdd.add(modelNodeNew);
 
                         ModelLine modelLineNew = new ModelLine();
-                        Long picId2 = UUIDUtil.generateId();
-                        modelLineNew.setId(picId2);
-                        modelLineNew.setPicId(picId2.toString());
+                        Long lineNewId = UUIDUtil.generateId();
+                        modelLineNew.setId(lineNewId);
+                        modelLineNew.setPicId(lineNewId.toString());
                         modelLineNew.setModelId(modelId);
-                        modelLineNew.setBeginCell(dataId.toString());
+                        modelLineNew.setBeginCell(nodeNewId.toString());
                         modelLineNew.setEndCell(modelNode.getPicId());
-//                        modelLineNew.setBeginNode(null);
-//                        modelLineNew.setEndNode(modelNode.getDataId());
-                        modelLineList.add(modelLineNew);
+                        linesToAdd.add(modelLineNew);
 
                         for(ModelLine nodelLine: lineList){
-                            nodelLine.setEndCell(dataId.toString());
-                            //nodelLine.setEndNode(dataId);
+                            nodelLine.setEndCell(nodeNewId.toString());
                         }
                     }
                 }
             }
         }
+        modelNodeList.addAll(nodesToAdd);
+        modelLineList.addAll(linesToAdd);
 
+        // 3. 灏嗘渶鍩烘湰鐨勪覆銆佸苟銆佹梺鑱斻�佽〃鍐虫浛鎹负铏氳妭鐐癸紝涓嶆柇绠�鍖栧浘褰紝鐩磋嚦鏃犳硶绠�鍖栦负姝�
         List<Algorithm> algoList = new ArrayList<>();
         boolean hasLeastOne = false;
         int stepNo = 0;
-        while (true) {
-            List<ModelNode> modelNodeList3 = modelNodeList.stream().filter(item -> "parallelRight,  switchRight,  voteRight, end".contains(item.getNodeType())).collect(Collectors.toList());
+        do {
+            List<ModelNode> opNodeList = modelNodeList.stream().filter(item ->
+                    "parallel,switch,vote,end".contains(item.getNodeType())).collect(Collectors.toList());
+            if (opNodeList.size() <= 0) break;
 
-            if (modelNodeList3.size() > 0) {
-                hasLeastOne = false;
-                for (ModelNode modelNode:modelNodeList3) {
-                    // 鍙宠竟杩愮畻绗﹀惊鐜�
-                    List<ModelLine> lineList3 = modelLineList.stream().filter(item -> item.getEndCell().equals(modelNode.getPicId())).collect(Collectors.toList());
-                    List<List<ModelNode>> listPath = new ArrayList<>();
-                    Long lastNode = null;
-                    boolean thisNodeSucc= true;
-                    for (ModelLine modelLine:lineList3) {
+            hasLeastOne = false; // 鑷冲皯鑳界畝鍖�1涓浘褰�
+            for (ModelNode opNode: opNodeList) {
+                // 鍙宠竟杩愮畻绗﹀惊鐜�
+                List<ModelLine> lineToOpNodeList = modelLineList.stream().filter(item ->
+                        item.getEndCell().equals(opNode.getPicId())).collect(Collectors.toList());
+                List<List<ModelNode>> listPath = new ArrayList<>();
+                ModelNode lastNode = null;
+                boolean thisNodeSucc= true;
+                for (ModelLine modelLine: lineToOpNodeList) {
                     // 鍙宠竟杩愮畻绗︾殑閫愪釜璺緞寰幆
-                        List<ModelNode> result = new ArrayList<>();
-                        handleOneLine(modelLineList, modelNodeList, modelLine, result);
-                        Long myId = result.get(result.size()-1).getId();
-                        listPath.add(result);
-                        if (lastNode == null) {
-                            lastNode = myId;
-                        } else {
-                            if (!lastNode.equals(myId)){
-                                thisNodeSucc = false;
-                                break;
-                            }
+                    List<ModelNode> result = new ArrayList<>();
+                    handleOneLine(modelLineList, modelNodeList, modelLine, result);
+                    listPath.add(result);
+                    ModelNode curLastNode = result.get(result.size()-1);
+                    if (lastNode == null) {
+                        lastNode = curLastNode;
+                    } else {
+                        if (!lastNode.getId().equals(curLastNode.getId())){
+                            thisNodeSucc = false;
+                            break;
                         }
                     }
-                    if (thisNodeSucc) {
-                        //褰㈡垚铏氳妭鐐圭畻娉�
-                        hasLeastOne = true;
-                        String computerList = "";
-                        for (List<ModelNode> path : listPath) {
-                            path.remove(path.get(path.size()-1));
-                            Algorithm algo = new Algorithm();
-                            Long id = UUIDUtil.generateId();
-                            computerList = computerList.equals("")?id.toString():computerList+","+id.toString();
-                            algo.setId(id);
-                            algo.setModelId(modelId);
-                            algo.setComputerId(id);
-                            algo.setModelType("series");
-                            algo.setAlgorithmType("series");
-                            algo.setStep(stepNo);
-                            stepNo++;
-                            algo.setComputerList(StringUtils.join(path.stream().map(ModelNode::getId).collect(Collectors.toSet()), ","));
-
-                            for (ModelNode node : path) {
-                                List<ModelLine> lineList4 = modelLineList.stream().filter(item -> item.getEndCell().equals(node.getPicId()) || item.getBeginCell().equals(node.getPicId())).collect(Collectors.toList());
-                                modelLineList.removeAll(lineList4);
-                                modelNodeList.remove(node);
-                            }
-                        }
-                        Algorithm algo = new Algorithm();
-                        Long id = UUIDUtil.generateId();
-                        algo.setId(id);
-                        algo.setModelId(modelId);
-                        algo.setComputerId(id);
-                        algo.setModelType(modelNode.getNodeType());
-                        algo.setAlgorithmType(modelNode.getNodeType());
-                        algo.setStep(stepNo);
-                        stepNo++;
-                        algo.setComputerList(StringUtils.join(computerList));
-                        //褰㈡垚铏氳妭鐐�
-
-                        modelNode.setId(id);
-                        modelNode.setPicId(id.toString());
-                        modelNode.setDataId(id);
-                        modelNode.setNodeType("vNode");
-
-                        ModelLine modelLineNew = new ModelLine();
-                        Long picId2 = UUIDUtil.generateId();
-                        modelLineNew.setId(picId2);
-                        modelLineNew.setPicId(picId2.toString());
-                        modelLineNew.setModelId(modelId);
-                        modelLineNew.setBeginCell(lastNode.toString());
-                        modelLineNew.setEndCell(modelNode.getPicId());
-//                        modelLineNew.setBeginNode(lastNode);
-//                        modelLineNew.setEndNode(modelNode.getDataId());
-                        modelLineList.add(modelLineNew);
-                    }
                 }
-                if (!hasLeastOne){
-                    // 涓�涓兘娌$畝鍖栨垚鍔�
-                    break;
+                if (thisNodeSucc) {
+                    //褰㈡垚铏氳妭鐐圭畻娉�
+                    stepNo = replaceToVNode(modelId, modelNodeList, modelLineList, opNode, listPath, lastNode, algoList, stepNo);
+                    hasLeastOne = true;
                 }
-            }else{
-                break;
+            } // end for
+        } while (hasLeastOne);
+
+        if (saveFlag) saveModel(modelId, modelNodeList, modelLineList, algoList);
+    }
+
+    private void handleOneLine(List<ModelLine> modelLineList,
+                               List<ModelNode> modelNodeList,
+                               ModelLine modelLine,
+                               List<ModelNode> result) {
+        ModelNode modelNode = modelNodeList.stream().filter(item ->
+                item.getPicId().equals(modelLine.getBeginCell())).collect(Collectors.toList()).get(0);
+        result.add(modelNode);
+        if ("start".equals(modelNode.getNodeType())) {
+            return;
+        }
+        List<ModelLine> lines =modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(modelNode.getPicId())).collect(Collectors.toList());
+        List<ModelLine> lines2 =modelLineList.stream().filter(item ->
+                item.getEndCell().equals(modelNode.getPicId())).collect(Collectors.toList());
+        if (lines.size()>1 || lines2.size()>1) {
+            return;
+        } else {
+            handleOneLine(modelLineList, modelNodeList, lines2.get(0), result);
+        }
+    }
+
+    private int replaceToVNode(Long modelId,
+                                List<ModelNode> modelNodeList,
+                                List<ModelLine> modelLineList,
+                                ModelNode opNode,
+                                List<List<ModelNode>> listPath,
+                                ModelNode lastNode,
+                                List<Algorithm> algoList,
+                                int stepNo) {
+        String computerList = "";
+        for (List<ModelNode> path : listPath) {
+            path.remove(path.get(path.size()-1));
+            Long id = null;
+            if (path.size()==0) {
+                return stepNo;
+            } else if (path.size()==1) {
+                id = path.get(path.size()-1).getId();
+            } else {
+                id = UUIDUtil.generateId();
+                Algorithm algo = new Algorithm();
+                algo.setId(id);
+                algo.setModelId(modelId);
+                algo.setComputerId(id);
+                algo.setModelType("series");
+                algo.setAlgorithmType("series");
+                algo.setComputerList(StringUtils.join(path.stream().map(ModelNode::getId).collect(Collectors.toSet()), ","));
+                algo.setStep(stepNo);
+                stepNo++;
+                algoList.add(algo);
+            }
+            computerList = computerList.equals("") ? id.toString() : computerList + "," + id.toString();
+            for (ModelNode node : path) {
+                List<ModelLine> lineList4 = modelLineList.stream().filter(item ->
+                        item.getEndCell().equals(node.getPicId()) || item.getBeginCell().equals(node.getPicId())).collect(Collectors.toList());
+                modelLineList.removeAll(lineList4);
+                modelNodeList.remove(node);
             }
         }
+        Algorithm algo = new Algorithm();
+        Long id = UUIDUtil.generateId();
+        algo.setId(id);
+        algo.setModelId(modelId);
+        algo.setComputerId(id);
+        algo.setModelType(opNode.getNodeType());
+        algo.setAlgorithmType(opNode.getNodeType());
+        algo.setComputerList(computerList);
+        algo.setStep(stepNo);
+        stepNo++;
+        algoList.add(algo);
 
+        //灏嗗師杩愮畻鑺傜偣鏀规垚铏氳妭鐐�
+        opNode.setId(id);
+//        opNode.setPicId(id.toString());
+        opNode.setNodeType("vnode");
+
+        ModelLine modelLineNew = new ModelLine();
+        Long picId2 = UUIDUtil.generateId();
+        modelLineNew.setId(picId2);
+        modelLineNew.setPicId(picId2.toString());
+        modelLineNew.setModelId(modelId);
+        modelLineNew.setBeginCell(lastNode.getPicId());
+        modelLineNew.setEndCell(opNode.getPicId());
+        modelLineList.add(modelLineNew);
+
+        return stepNo;
     }
-    public void handleOneLine(List<ModelLine> modelLineList, List<ModelNode> modelNodeList, ModelLine modelLine,List<ModelNode> result){
-        ModelNode modelNode =modelNodeList.stream().filter(item->item.getPicId().equals(modelLine.getBeginCell())).collect(Collectors.toList()).get(0);
-        List<ModelLine> lines =modelLineList.stream().filter(item->item.getBeginCell().equals(modelNode.getPicId())).collect(Collectors.toList());
-        List<ModelLine> lines2 =modelLineList.stream().filter(item->item.getEndCell().equals(modelNode.getPicId())).collect(Collectors.toList());
-        result.add(modelNode);
-        if (lines.size()>1 || lines2.size()>1){
-            return;
-        }else{
-            handleOneLine(modelLineList, modelNodeList, lines2.get(0),result);
-        }
 
+    private void saveModel(Long modelId,
+                           List<ModelNode> modelNodeList,
+                           List<ModelLine> modelLineList,
+                           List<Algorithm> algoList) {
+        // 鍒犻櫎鏃㈡湁鏁版嵁
+        modelNodeDao.deleteByModelId(modelId);
+        modelLineDao.deleteByModelId(modelId);
+        algorithmDao.deleteByModelId(modelId);
+
+        // 鎻掑叆鏁版嵁
+        for (ModelNode modelNode : modelNodeList) {
+            modelNodeDao.insert(modelNode);
+        }
+        for (ModelLine modelLine : modelLineList) {
+            modelLineDao.insert(modelLine);
+        }
+        for (Algorithm algorithm : algoList) {
+            algorithmDao.insert(algorithm);
+        }
     }
 
 }

--
Gitblit v1.9.1