日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

解决activiti中由模板转换的流程图连线名称缺失问题

發布時間:2025/4/5 编程问答 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 解决activiti中由模板转换的流程图连线名称缺失问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2019獨角獸企業重金招聘Python工程師標準>>>

版本聲明:Activiti 5.22.0 通常,由模板發布流程的代碼大致如下:

private Deployment convertModelToProcess(String modelId) throws IOException, UnsupportedEncodingException {Deployment deployment = null;try {Model modelData = repositoryService.getModel(modelId);ObjectNode modelNode = (ObjectNode) new ObjectMapper().readTree(repositoryService.getModelEditorSource(modelData.getId()));byte[] bpmnBytes = null;BpmnModel model = new BpmnJsonConverter().convertToBpmnModel(modelNode);bpmnBytes = new BpmnXMLConverter().convertToXML(model);String processName = modelData.getName() + ".bpmn20.xml";deployment = repositoryService.createDeployment().name(modelData.getName()).addString(processName, new String(bpmnBytes, "UTF-8")).deploy();} catch (Exception e1) {throw new BizException("流程定義文件存在錯誤,請修改后重新部署!");} return deployment;}

但在此版本的activiti中存在一個bug:由模板轉換的流程定義,其流程圖會丟失連線名稱。 解決辦法:重寫BpmnJsonConverter類:

import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map;import org.activiti.bpmn.model.Activity; import org.activiti.bpmn.model.Artifact; import org.activiti.bpmn.model.BaseElement; import org.activiti.bpmn.model.BoundaryEvent; import org.activiti.bpmn.model.BpmnModel; import org.activiti.bpmn.model.Event; import org.activiti.bpmn.model.EventDefinition; import org.activiti.bpmn.model.ExtensionElement; import org.activiti.bpmn.model.FlowElement; import org.activiti.bpmn.model.FlowElementsContainer; import org.activiti.bpmn.model.FlowNode; import org.activiti.bpmn.model.Gateway; import org.activiti.bpmn.model.GraphicInfo; import org.activiti.bpmn.model.Lane; import org.activiti.bpmn.model.Message; import org.activiti.bpmn.model.MessageEventDefinition; import org.activiti.bpmn.model.MessageFlow; import org.activiti.bpmn.model.Pool; import org.activiti.bpmn.model.Process; import org.activiti.bpmn.model.SequenceFlow; import org.activiti.bpmn.model.Signal; import org.activiti.bpmn.model.SignalEventDefinition; import org.activiti.bpmn.model.SubProcess; import org.activiti.bpmn.model.ValuedDataObject; import org.activiti.editor.constants.EditorJsonConstants; import org.activiti.editor.constants.StencilConstants; import org.activiti.editor.language.json.converter.ActivityProcessor; import org.activiti.editor.language.json.converter.AssociationJsonConverter; import org.activiti.editor.language.json.converter.BaseBpmnJsonConverter; import org.activiti.editor.language.json.converter.BoundaryEventJsonConverter; import org.activiti.editor.language.json.converter.BpmnJsonConverter; import org.activiti.editor.language.json.converter.BpmnJsonConverterUtil; import org.activiti.editor.language.json.converter.BusinessRuleTaskJsonConverter; import org.activiti.editor.language.json.converter.CallActivityJsonConverter; import org.activiti.editor.language.json.converter.CamelTaskJsonConverter; import org.activiti.editor.language.json.converter.CatchEventJsonConverter; import org.activiti.editor.language.json.converter.DataStoreJsonConverter; import org.activiti.editor.language.json.converter.EndEventJsonConverter; import org.activiti.editor.language.json.converter.EventGatewayJsonConverter; import org.activiti.editor.language.json.converter.EventSubProcessJsonConverter; import org.activiti.editor.language.json.converter.ExclusiveGatewayJsonConverter; import org.activiti.editor.language.json.converter.InclusiveGatewayJsonConverter; import org.activiti.editor.language.json.converter.MailTaskJsonConverter; import org.activiti.editor.language.json.converter.ManualTaskJsonConverter; import org.activiti.editor.language.json.converter.MessageFlowJsonConverter; import org.activiti.editor.language.json.converter.MuleTaskJsonConverter; import org.activiti.editor.language.json.converter.ParallelGatewayJsonConverter; import org.activiti.editor.language.json.converter.ReceiveTaskJsonConverter; import org.activiti.editor.language.json.converter.ScriptTaskJsonConverter; import org.activiti.editor.language.json.converter.SendTaskJsonConverter; import org.activiti.editor.language.json.converter.SequenceFlowJsonConverter; import org.activiti.editor.language.json.converter.ServiceTaskJsonConverter; import org.activiti.editor.language.json.converter.StartEventJsonConverter; import org.activiti.editor.language.json.converter.SubProcessJsonConverter; import org.activiti.editor.language.json.converter.TextAnnotationJsonConverter; import org.activiti.editor.language.json.converter.ThrowEventJsonConverter; import org.activiti.editor.language.json.converter.UserTaskJsonConverter; import org.activiti.editor.language.json.converter.util.JsonConverterUtil; import org.apache.commons.collections.CollectionUtils; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.node.ArrayNode; import com.fasterxml.jackson.databind.node.ObjectNode;import math.geom2d.Point2D; import math.geom2d.conic.Circle2D; import math.geom2d.curve.AbstractContinuousCurve2D; import math.geom2d.line.Line2D; import math.geom2d.polygon.Polyline2D;/*** @author Tijs Rademakers*/ public class CustomBpmnJsonConverter implements EditorJsonConstants,StencilConstants, ActivityProcessor {protected static final Logger LOGGER = LoggerFactory.getLogger(BpmnJsonConverter.class);protected static Map<Class<? extends BaseElement>, Class<? extends BaseBpmnJsonConverter>> convertersToJsonMap = new HashMap<Class<? extends BaseElement>, Class<? extends BaseBpmnJsonConverter>>();protected static Map<String, Class<? extends BaseBpmnJsonConverter>> convertersToBpmnMap = new HashMap<String, Class<? extends BaseBpmnJsonConverter>>();public static final String MODELER_NAMESPACE = "http://activiti.com/modeler";protected static final DateFormat defaultFormat = new SimpleDateFormat("yyyyMMddHHmmss");protected static final DateFormat entFormat = new SimpleDateFormat("yyyyMMddHHmmssSSS");static {// start and end eventsStartEventJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);EndEventJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// connectorsSequenceFlowJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);MessageFlowJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);AssociationJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// task typesBusinessRuleTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);MailTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);ManualTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);ReceiveTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);ScriptTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);ServiceTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);UserTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);CallActivityJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);CamelTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);MuleTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);SendTaskJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// gatewaysExclusiveGatewayJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);InclusiveGatewayJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);ParallelGatewayJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);EventGatewayJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// scope constructsSubProcessJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);EventSubProcessJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// catch eventsCatchEventJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// throw eventsThrowEventJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// boundary eventsBoundaryEventJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);// artifactsTextAnnotationJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);DataStoreJsonConverter.fillTypes(convertersToBpmnMap,convertersToJsonMap);}private static final List<String> DI_CIRCLES = new ArrayList<String>();private static final List<String> DI_RECTANGLES = new ArrayList<String>();private static final List<String> DI_GATEWAY = new ArrayList<String>();static {DI_CIRCLES.add(STENCIL_EVENT_START_ERROR);DI_CIRCLES.add(STENCIL_EVENT_START_MESSAGE);DI_CIRCLES.add(STENCIL_EVENT_START_NONE);DI_CIRCLES.add(STENCIL_EVENT_START_TIMER);DI_CIRCLES.add(STENCIL_EVENT_START_SIGNAL);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_ERROR);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_SIGNAL);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_TIMER);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_MESSAGE);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_CANCEL);DI_CIRCLES.add(STENCIL_EVENT_BOUNDARY_COMPENSATION);DI_CIRCLES.add(STENCIL_EVENT_CATCH_MESSAGE);DI_CIRCLES.add(STENCIL_EVENT_CATCH_SIGNAL);DI_CIRCLES.add(STENCIL_EVENT_CATCH_TIMER);DI_CIRCLES.add(STENCIL_EVENT_THROW_NONE);DI_CIRCLES.add(STENCIL_EVENT_THROW_SIGNAL);DI_CIRCLES.add(STENCIL_EVENT_END_NONE);DI_CIRCLES.add(STENCIL_EVENT_END_ERROR);DI_CIRCLES.add(STENCIL_EVENT_END_CANCEL);DI_CIRCLES.add(STENCIL_EVENT_END_TERMINATE);DI_RECTANGLES.add(STENCIL_CALL_ACTIVITY);DI_RECTANGLES.add(STENCIL_SUB_PROCESS);DI_RECTANGLES.add(STENCIL_EVENT_SUB_PROCESS);DI_RECTANGLES.add(STENCIL_TASK_BUSINESS_RULE);DI_RECTANGLES.add(STENCIL_TASK_MAIL);DI_RECTANGLES.add(STENCIL_TASK_MANUAL);DI_RECTANGLES.add(STENCIL_TASK_RECEIVE);DI_RECTANGLES.add(STENCIL_TASK_SCRIPT);DI_RECTANGLES.add(STENCIL_TASK_SEND);DI_RECTANGLES.add(STENCIL_TASK_SERVICE);DI_RECTANGLES.add(STENCIL_TASK_USER);DI_RECTANGLES.add(STENCIL_TASK_CAMEL);DI_RECTANGLES.add(STENCIL_TASK_MULE);DI_RECTANGLES.add(STENCIL_TEXT_ANNOTATION);DI_GATEWAY.add(STENCIL_GATEWAY_EVENT);DI_GATEWAY.add(STENCIL_GATEWAY_EXCLUSIVE);DI_GATEWAY.add(STENCIL_GATEWAY_INCLUSIVE);DI_GATEWAY.add(STENCIL_GATEWAY_PARALLEL);}protected ObjectMapper objectMapper = new ObjectMapper();public ObjectNode convertToJson(BpmnModel model) {ObjectNode modelNode = objectMapper.createObjectNode();double maxX = 0.0;double maxY = 0.0;for (GraphicInfo flowInfo : model.getLocationMap().values()) {if ((flowInfo.getX() + flowInfo.getWidth()) > maxX) {maxX = flowInfo.getX() + flowInfo.getWidth();}if ((flowInfo.getY() + flowInfo.getHeight()) > maxY) {maxY = flowInfo.getY() + flowInfo.getHeight();}}maxX += 50;maxY += 50;if (maxX < 1485) {maxX = 1485;}if (maxY < 700) {maxY = 700;}modelNode.put("bounds",BpmnJsonConverterUtil.createBoundsNode(maxX, maxY, 0, 0));modelNode.put("resourceId", "canvas");ObjectNode stencilNode = objectMapper.createObjectNode();stencilNode.put("id", "BPMNDiagram");modelNode.put("stencil", stencilNode);ObjectNode stencilsetNode = objectMapper.createObjectNode();stencilsetNode.put("namespace", "http://b3mn.org/stencilset/bpmn2.0#");stencilsetNode.put("url", "../editor/stencilsets/bpmn2.0/bpmn2.0.json");modelNode.put("stencilset", stencilsetNode);ArrayNode shapesArrayNode = objectMapper.createArrayNode();Process mainProcess = null;if (model.getPools().size() > 0) {mainProcess = model.getProcess(model.getPools().get(0).getId());} else {mainProcess = model.getMainProcess();}ObjectNode propertiesNode = objectMapper.createObjectNode();if (StringUtils.isNotEmpty(mainProcess.getId())) {propertiesNode.put(PROPERTY_PROCESS_ID, mainProcess.getId());}if (StringUtils.isNotEmpty(mainProcess.getName())) {propertiesNode.put(PROPERTY_NAME, mainProcess.getName());}if (StringUtils.isNotEmpty(mainProcess.getDocumentation())) {propertiesNode.put(PROPERTY_DOCUMENTATION,mainProcess.getDocumentation());}if (mainProcess.isExecutable() == false) {propertiesNode.put(PROPERTY_PROCESS_EXECUTABLE, "No");}if (StringUtils.isNoneEmpty(model.getTargetNamespace())) {propertiesNode.put(PROPERTY_PROCESS_NAMESPACE,model.getTargetNamespace());}BpmnJsonConverterUtil.convertMessagesToJson(model.getMessages(),propertiesNode);BpmnJsonConverterUtil.convertListenersToJson(mainProcess.getExecutionListeners(), true, propertiesNode);BpmnJsonConverterUtil.convertEventListenersToJson(mainProcess.getEventListeners(), propertiesNode);BpmnJsonConverterUtil.convertSignalDefinitionsToJson(model,propertiesNode);BpmnJsonConverterUtil.convertMessagesToJson(model, propertiesNode);if (CollectionUtils.isNotEmpty(mainProcess.getDataObjects())) {BpmnJsonConverterUtil.convertDataPropertiesToJson(mainProcess.getDataObjects(), propertiesNode);}modelNode.put(EDITOR_SHAPE_PROPERTIES, propertiesNode);boolean poolHasDI = false;if (model.getPools().size() > 0) {for (Pool pool : model.getPools()) {GraphicInfo graphicInfo = model.getGraphicInfo(pool.getId());if (graphicInfo != null) {poolHasDI = true;break;}}}if ((model.getPools().size() > 0) && poolHasDI) {for (Pool pool : model.getPools()) {GraphicInfo graphicInfo = model.getGraphicInfo(pool.getId());if (graphicInfo == null) {continue;}ObjectNode poolNode = BpmnJsonConverterUtil.createChildShape(pool.getId(), STENCIL_POOL, graphicInfo.getX()+ graphicInfo.getWidth(), graphicInfo.getY()+ graphicInfo.getHeight(), graphicInfo.getX(),graphicInfo.getY());shapesArrayNode.add(poolNode);ObjectNode poolPropertiesNode = objectMapper.createObjectNode();poolPropertiesNode.put(PROPERTY_OVERRIDE_ID, pool.getId());poolPropertiesNode.put(PROPERTY_PROCESS_ID,pool.getProcessRef());if (pool.isExecutable() == false) {poolPropertiesNode.put(PROPERTY_PROCESS_EXECUTABLE,PROPERTY_VALUE_NO);}if (StringUtils.isNotEmpty(pool.getName())) {poolPropertiesNode.put(PROPERTY_NAME, pool.getName());}poolNode.put(EDITOR_SHAPE_PROPERTIES, poolPropertiesNode);ArrayNode laneShapesArrayNode = objectMapper.createArrayNode();poolNode.put(EDITOR_CHILD_SHAPES, laneShapesArrayNode);ArrayNode outgoingArrayNode = objectMapper.createArrayNode();poolNode.put("outgoing", outgoingArrayNode);Process process = model.getProcess(pool.getId());if (process != null) {Map<String, ArrayNode> laneMap = new HashMap<String, ArrayNode>();for (Lane lane : process.getLanes()) {GraphicInfo laneGraphicInfo = model.getGraphicInfo(lane.getId());if (laneGraphicInfo == null) {continue;}ObjectNode laneNode = BpmnJsonConverterUtil.createChildShape(lane.getId(), STENCIL_LANE,laneGraphicInfo.getX()+ laneGraphicInfo.getWidth(),laneGraphicInfo.getY()+ laneGraphicInfo.getHeight(),laneGraphicInfo.getX(),laneGraphicInfo.getY());laneShapesArrayNode.add(laneNode);ObjectNode lanePropertiesNode = objectMapper.createObjectNode();lanePropertiesNode.put(PROPERTY_OVERRIDE_ID,lane.getId());if (StringUtils.isNotEmpty(lane.getName())) {lanePropertiesNode.put(PROPERTY_NAME,lane.getName());}laneNode.put(EDITOR_SHAPE_PROPERTIES,lanePropertiesNode);ArrayNode elementShapesArrayNode = objectMapper.createArrayNode();laneNode.put(EDITOR_CHILD_SHAPES,elementShapesArrayNode);laneNode.put("outgoing", objectMapper.createArrayNode());laneMap.put(lane.getId(), elementShapesArrayNode);}for (FlowElement flowElement : process.getFlowElements()) {Lane laneForElement = null;GraphicInfo laneGraphicInfo = null;FlowElement lookForElement = null;if (flowElement instanceof SequenceFlow) {SequenceFlow sequenceFlow = (SequenceFlow) flowElement;lookForElement = model.getFlowElement(sequenceFlow.getSourceRef());} else {lookForElement = flowElement;}for (Lane lane : process.getLanes()) {if (lane.getFlowReferences().contains(lookForElement.getId())) {laneGraphicInfo = model.getGraphicInfo(lane.getId());if (laneGraphicInfo != null) {laneForElement = lane;}break;}}if (flowElement instanceof SequenceFlow|| (laneForElement != null)) {processFlowElement(flowElement, process, model,laneMap.get(laneForElement.getId()),laneGraphicInfo.getX(),laneGraphicInfo.getY());}}processArtifacts(process, model, shapesArrayNode, 0.0, 0.0);}for (MessageFlow messageFlow : model.getMessageFlows().values()) {if (messageFlow.getSourceRef().equals(pool.getId())) {outgoingArrayNode.add(BpmnJsonConverterUtil.createResourceNode(messageFlow.getId()));}}}processMessageFlows(model, shapesArrayNode);} else {processFlowElements(model.getMainProcess(), model, shapesArrayNode,0.0, 0.0);processMessageFlows(model, shapesArrayNode);}modelNode.put(EDITOR_CHILD_SHAPES, shapesArrayNode);return modelNode;}public void processFlowElements(FlowElementsContainer container,BpmnModel model, ArrayNode shapesArrayNode, double subProcessX,double subProcessY) {for (FlowElement flowElement : container.getFlowElements()) {processFlowElement(flowElement, container, model, shapesArrayNode,subProcessX, subProcessY);}processArtifacts(container, model, shapesArrayNode, subProcessX,subProcessY);}protected void processFlowElement(FlowElement flowElement,FlowElementsContainer container, BpmnModel model,ArrayNode shapesArrayNode, double containerX, double containerY) {Class<? extends BaseBpmnJsonConverter> converter = convertersToJsonMap.get(flowElement.getClass());if (converter != null) {try {converter.newInstance().convertToJson(flowElement, this, model,container, shapesArrayNode, containerX, containerY);} catch (Exception e) {LOGGER.error("Error converting {}", flowElement, e);}}}protected void processArtifacts(FlowElementsContainer container,BpmnModel model, ArrayNode shapesArrayNode, double containerX,double containerY) {for (Artifact artifact : container.getArtifacts()) {Class<? extends BaseBpmnJsonConverter> converter = convertersToJsonMap.get(artifact.getClass());if (converter != null) {try {converter.newInstance().convertToJson(artifact, this,model, container, shapesArrayNode, containerX,containerY);} catch (Exception e) {LOGGER.error("Error converting {}", artifact, e);}}}}protected void processMessageFlows(BpmnModel model,ArrayNode shapesArrayNode) {for (MessageFlow messageFlow : model.getMessageFlows().values()) {MessageFlowJsonConverter jsonConverter = new MessageFlowJsonConverter();jsonConverter.convertToJson(messageFlow, this, model, null,shapesArrayNode, 0.0, 0.0);}}public BpmnModel convertToBpmnModel(JsonNode modelNode) {BpmnModel bpmnModel = new BpmnModel();bpmnModel.setTargetNamespace("http://activiti.org/test");Map<String, JsonNode> shapeMap = new HashMap<String, JsonNode>();Map<String, JsonNode> sourceRefMap = new HashMap<String, JsonNode>();Map<String, JsonNode> edgeMap = new HashMap<String, JsonNode>();Map<String, List<JsonNode>> sourceAndTargetMap = new HashMap<String, List<JsonNode>>();readShapeDI(modelNode, 0, 0, shapeMap, sourceRefMap, bpmnModel);filterAllEdges(modelNode, edgeMap, sourceAndTargetMap, shapeMap,sourceRefMap);readEdgeDI(edgeMap, sourceAndTargetMap, bpmnModel);ArrayNode shapesArrayNode = (ArrayNode) modelNode.get(EDITOR_CHILD_SHAPES);if ((shapesArrayNode == null) || (shapesArrayNode.size() == 0)) {return bpmnModel;}boolean nonEmptyPoolFound = false;Map<String, Lane> elementInLaneMap = new HashMap<String, Lane>();// first create the pool structurefor (JsonNode shapeNode : shapesArrayNode) {String stencilId = BpmnJsonConverterUtil.getStencilId(shapeNode);if (STENCIL_POOL.equals(stencilId)) {Pool pool = new Pool();pool.setId(BpmnJsonConverterUtil.getElementId(shapeNode));pool.setName(JsonConverterUtil.getPropertyValueAsString(PROPERTY_NAME, shapeNode));pool.setProcessRef(JsonConverterUtil.getPropertyValueAsString(PROPERTY_PROCESS_ID, shapeNode));pool.setExecutable(JsonConverterUtil.getPropertyValueAsBoolean(PROPERTY_PROCESS_EXECUTABLE, shapeNode, true));bpmnModel.getPools().add(pool);Process process = new Process();process.setId(pool.getProcessRef());process.setName(pool.getName());process.setExecutable(pool.isExecutable());bpmnModel.addProcess(process);ArrayNode laneArrayNode = (ArrayNode) shapeNode.get(EDITOR_CHILD_SHAPES);for (JsonNode laneNode : laneArrayNode) {// should be a lane, but just check to be certainString laneStencilId = BpmnJsonConverterUtil.getStencilId(laneNode);if (STENCIL_LANE.equals(laneStencilId)) {nonEmptyPoolFound = true;Lane lane = new Lane();lane.setId(BpmnJsonConverterUtil.getElementId(laneNode));lane.setName(JsonConverterUtil.getPropertyValueAsString(PROPERTY_NAME,laneNode));lane.setParentProcess(process);process.getLanes().add(lane);processJsonElements(laneNode.get(EDITOR_CHILD_SHAPES),modelNode, lane, shapeMap, bpmnModel);if (CollectionUtils.isNotEmpty(lane.getFlowReferences())) {for (String elementRef : lane.getFlowReferences()) {elementInLaneMap.put(elementRef, lane);}}}}}}// Signal Definitions exist on the root levelJsonNode signalDefinitionNode = BpmnJsonConverterUtil.getProperty(PROPERTY_SIGNAL_DEFINITIONS, modelNode);signalDefinitionNode = BpmnJsonConverterUtil.validateIfNodeIsTextual(signalDefinitionNode);signalDefinitionNode = BpmnJsonConverterUtil.validateIfNodeIsTextual(signalDefinitionNode); // no idea why this needs to be done twice ..if (signalDefinitionNode != null) {if (signalDefinitionNode instanceof ArrayNode) {ArrayNode signalDefinitionArrayNode = (ArrayNode) signalDefinitionNode;Iterator<JsonNode> signalDefinitionIterator = signalDefinitionArrayNode.iterator();while (signalDefinitionIterator.hasNext()) {JsonNode signalDefinitionJsonNode = signalDefinitionIterator.next();String signalId = signalDefinitionJsonNode.get(PROPERTY_SIGNAL_DEFINITION_ID).asText();String signalName = signalDefinitionJsonNode.get(PROPERTY_SIGNAL_DEFINITION_NAME).asText();String signalScope = signalDefinitionJsonNode.get(PROPERTY_SIGNAL_DEFINITION_SCOPE).asText();Signal signal = new Signal();signal.setId(signalId);signal.setName(signalName);signal.setScope((signalScope.toLowerCase().equals("processinstance")) ? Signal.SCOPE_PROCESS_INSTANCE: Signal.SCOPE_GLOBAL);bpmnModel.addSignal(signal);}}}if (nonEmptyPoolFound == false) {Process process = new Process();bpmnModel.getProcesses().add(process);process.setId(BpmnJsonConverterUtil.getPropertyValueAsString(PROPERTY_PROCESS_ID, modelNode));process.setName(BpmnJsonConverterUtil.getPropertyValueAsString(PROPERTY_NAME, modelNode));String namespace = BpmnJsonConverterUtil.getPropertyValueAsString(PROPERTY_PROCESS_NAMESPACE, modelNode);if (StringUtils.isNotEmpty(namespace)) {bpmnModel.setTargetNamespace(namespace);}process.setDocumentation(BpmnJsonConverterUtil.getPropertyValueAsString(PROPERTY_DOCUMENTATION, modelNode));JsonNode processExecutableNode = JsonConverterUtil.getProperty(PROPERTY_PROCESS_EXECUTABLE, modelNode);if ((processExecutableNode != null)&& StringUtils.isNotEmpty(processExecutableNode.asText())) {process.setExecutable(JsonConverterUtil.getPropertyValueAsBoolean(PROPERTY_PROCESS_EXECUTABLE,modelNode));}BpmnJsonConverterUtil.convertJsonToMessages(modelNode, bpmnModel);BpmnJsonConverterUtil.convertJsonToListeners(modelNode, process);JsonNode eventListenersNode = BpmnJsonConverterUtil.getProperty(PROPERTY_EVENT_LISTENERS, modelNode);if (eventListenersNode != null) {eventListenersNode = BpmnJsonConverterUtil.validateIfNodeIsTextual(eventListenersNode);BpmnJsonConverterUtil.parseEventListeners(eventListenersNode.get(PROPERTY_EVENTLISTENER_VALUE),process);}JsonNode processDataPropertiesNode = modelNode.get(EDITOR_SHAPE_PROPERTIES).get(PROPERTY_DATA_PROPERTIES);if (processDataPropertiesNode != null) {List<ValuedDataObject> dataObjects = BpmnJsonConverterUtil.convertJsonToDataProperties(processDataPropertiesNode,process);process.setDataObjects(dataObjects);process.getFlowElements().addAll(dataObjects);}processJsonElements(shapesArrayNode, modelNode, process, shapeMap,bpmnModel);} else {// sequence flows are on root level so need additional parsing for poolsfor (JsonNode shapeNode : shapesArrayNode) {if (STENCIL_SEQUENCE_FLOW.equalsIgnoreCase(BpmnJsonConverterUtil.getStencilId(shapeNode))|| STENCIL_ASSOCIATION.equalsIgnoreCase(BpmnJsonConverterUtil.getStencilId(shapeNode))) {String sourceRef = BpmnJsonConverterUtil.lookForSourceRef(shapeNode.get(EDITOR_SHAPE_ID).asText(),modelNode.get(EDITOR_CHILD_SHAPES));if (sourceRef != null) {Lane lane = elementInLaneMap.get(sourceRef);SequenceFlowJsonConverter flowConverter = new SequenceFlowJsonConverter();if (lane != null) {flowConverter.convertToBpmnModel(shapeNode,modelNode, this, lane, shapeMap, bpmnModel);} else {flowConverter.convertToBpmnModel(shapeNode,modelNode, this, bpmnModel.getProcesses().get(0), shapeMap, bpmnModel);}}}}}// sequence flows are now all on root levelMap<String, SubProcess> subShapesMap = new HashMap<String, SubProcess>();for (Process process : bpmnModel.getProcesses()) {for (FlowElement flowElement : process.findFlowElementsOfType(SubProcess.class)) {SubProcess subProcess = (SubProcess) flowElement;fillSubShapes(subShapesMap, subProcess);}if (subShapesMap.size() > 0) {List<String> removeSubFlowsList = new ArrayList<String>();for (FlowElement flowElement : process.findFlowElementsOfType(SequenceFlow.class)) {SequenceFlow sequenceFlow = (SequenceFlow) flowElement;if (subShapesMap.containsKey(sequenceFlow.getSourceRef())) {SubProcess subProcess = subShapesMap.get(sequenceFlow.getSourceRef());if (subProcess.getFlowElement(sequenceFlow.getId()) == null) {subProcess.addFlowElement(sequenceFlow);removeSubFlowsList.add(sequenceFlow.getId());}}}for (String flowId : removeSubFlowsList) {process.removeFlowElement(flowId);}}}Map<String, FlowWithContainer> allFlowMap = new HashMap<String, FlowWithContainer>();List<Gateway> gatewayWithOrderList = new ArrayList<Gateway>();// post handling of process elementsfor (Process process : bpmnModel.getProcesses()) {postProcessElements(process, process.getFlowElements(), edgeMap,bpmnModel, allFlowMap, gatewayWithOrderList);}// sort the sequence flowsfor (Gateway gateway : gatewayWithOrderList) {List<ExtensionElement> orderList = gateway.getExtensionElements().get("EDITOR_FLOW_ORDER");if (CollectionUtils.isNotEmpty(orderList)) {for (ExtensionElement orderElement : orderList) {String flowValue = orderElement.getElementText();if (StringUtils.isNotEmpty(flowValue)) {if (allFlowMap.containsKey(flowValue)) {FlowWithContainer flowWithContainer = allFlowMap.get(flowValue);flowWithContainer.getFlowContainer().removeFlowElement(flowWithContainer.getSequenceFlow().getId());flowWithContainer.getFlowContainer().addFlowElement(flowWithContainer.getSequenceFlow());}}}}gateway.getExtensionElements().remove("EDITOR_FLOW_ORDER");}return bpmnModel;}public void processJsonElements(JsonNode shapesArrayNode,JsonNode modelNode, BaseElement parentElement,Map<String, JsonNode> shapeMap, BpmnModel bpmnModel) {for (JsonNode shapeNode : shapesArrayNode) {String stencilId = BpmnJsonConverterUtil.getStencilId(shapeNode);Class<? extends BaseBpmnJsonConverter> converter = convertersToBpmnMap.get(stencilId);try {BaseBpmnJsonConverter converterInstance = converter.newInstance();converterInstance.convertToBpmnModel(shapeNode, modelNode,this, parentElement, shapeMap, bpmnModel);} catch (Exception e) {LOGGER.error("Error converting {}",BpmnJsonConverterUtil.getStencilId(shapeNode), e);}}}private void fillSubShapes(Map<String, SubProcess> subShapesMap,SubProcess subProcess) {for (FlowElement flowElement : subProcess.getFlowElements()) {if (flowElement instanceof SubProcess) {SubProcess childSubProcess = (SubProcess) flowElement;subShapesMap.put(childSubProcess.getId(), subProcess);fillSubShapes(subShapesMap, childSubProcess);} else {subShapesMap.put(flowElement.getId(), subProcess);}}}private void postProcessElements(FlowElementsContainer parentContainer,Collection<FlowElement> flowElementList,Map<String, JsonNode> edgeMap, BpmnModel bpmnModel,Map<String, FlowWithContainer> allFlowMap,List<Gateway> gatewayWithOrderList) {for (FlowElement flowElement : flowElementList) {if (flowElement instanceof Event) {Event event = (Event) flowElement;if (CollectionUtils.isNotEmpty(event.getEventDefinitions())) {EventDefinition eventDef = event.getEventDefinitions().get(0);if (eventDef instanceof SignalEventDefinition) {SignalEventDefinition signalEventDef = (SignalEventDefinition) eventDef;if (StringUtils.isNotEmpty(signalEventDef.getSignalRef())) {if (bpmnModel.getSignal(signalEventDef.getSignalRef()) == null) {bpmnModel.addSignal(new Signal(signalEventDef.getSignalRef(), signalEventDef.getSignalRef()));}}} else if (eventDef instanceof MessageEventDefinition) {MessageEventDefinition messageEventDef = (MessageEventDefinition) eventDef;if (StringUtils.isNotEmpty(messageEventDef.getMessageRef())) {if (bpmnModel.getMessage(messageEventDef.getMessageRef()) == null) {bpmnModel.addMessage(new Message(messageEventDef.getMessageRef(),messageEventDef.getMessageRef(), null));}}}}}if (flowElement instanceof BoundaryEvent) {BoundaryEvent boundaryEvent = (BoundaryEvent) flowElement;Activity activity = retrieveAttachedRefObject(boundaryEvent.getAttachedToRefId(),parentContainer.getFlowElements());if (activity == null) {LOGGER.warn("Boundary event " + boundaryEvent.getId()+ " is not attached to any activity");} else {boundaryEvent.setAttachedToRef(activity);activity.getBoundaryEvents().add(boundaryEvent);}} else if (flowElement instanceof Gateway) {if (flowElement.getExtensionElements().containsKey("EDITOR_FLOW_ORDER")) {gatewayWithOrderList.add((Gateway) flowElement);}} else if (flowElement instanceof SubProcess) {SubProcess subProcess = (SubProcess) flowElement;postProcessElements(subProcess, subProcess.getFlowElements(),edgeMap, bpmnModel, allFlowMap, gatewayWithOrderList);} else if (flowElement instanceof SequenceFlow) {SequenceFlow sequenceFlow = (SequenceFlow) flowElement;FlowElement sourceFlowElement = parentContainer.getFlowElement(sequenceFlow.getSourceRef());if ((sourceFlowElement != null)&& sourceFlowElement instanceof FlowNode) {FlowWithContainer flowWithContainer = new FlowWithContainer(sequenceFlow, parentContainer);if ((sequenceFlow.getExtensionElements().get("EDITOR_RESOURCEID") != null)&& (sequenceFlow.getExtensionElements().get("EDITOR_RESOURCEID").size() > 0)) {allFlowMap.put(sequenceFlow.getExtensionElements().get("EDITOR_RESOURCEID").get(0).getElementText(), flowWithContainer);sequenceFlow.getExtensionElements().remove("EDITOR_RESOURCEID");}((FlowNode) sourceFlowElement).getOutgoingFlows().add(sequenceFlow);JsonNode edgeNode = edgeMap.get(sequenceFlow.getId());if (edgeNode != null) {boolean isDefault = JsonConverterUtil.getPropertyValueAsBoolean("defaultflow",edgeNode);if (isDefault) {if (sourceFlowElement instanceof Activity) {((Activity) sourceFlowElement).setDefaultFlow(sequenceFlow.getId());} else if (sourceFlowElement instanceof Gateway) {((Gateway) sourceFlowElement).setDefaultFlow(sequenceFlow.getId());}}}}FlowElement targetFlowElement = parentContainer.getFlowElement(sequenceFlow.getTargetRef());if ((targetFlowElement != null)&& targetFlowElement instanceof FlowNode) {((FlowNode) targetFlowElement).getIncomingFlows().add(sequenceFlow);}}}}private Activity retrieveAttachedRefObject(String attachedToRefId,Collection<FlowElement> flowElementList) {Activity activity = null;if (StringUtils.isNotEmpty(attachedToRefId)) {for (FlowElement flowElement : flowElementList) {if (attachedToRefId.equals(flowElement.getId())) {activity = (Activity) flowElement;break;} else if (flowElement instanceof SubProcess) {SubProcess subProcess = (SubProcess) flowElement;Activity retrievedActivity = retrieveAttachedRefObject(attachedToRefId, subProcess.getFlowElements());if (retrievedActivity != null) {activity = retrievedActivity;break;}}}}return activity;}private void readShapeDI(JsonNode objectNode, double parentX,double parentY, Map<String, JsonNode> shapeMap,Map<String, JsonNode> sourceRefMap, BpmnModel bpmnModel) {if (objectNode.get(EDITOR_CHILD_SHAPES) != null) {for (JsonNode jsonChildNode : objectNode.get(EDITOR_CHILD_SHAPES)) {String stencilId = BpmnJsonConverterUtil.getStencilId(jsonChildNode);if (STENCIL_SEQUENCE_FLOW.equals(stencilId) == false) {GraphicInfo graphicInfo = new GraphicInfo();JsonNode boundsNode = jsonChildNode.get(EDITOR_BOUNDS);ObjectNode upperLeftNode = (ObjectNode) boundsNode.get(EDITOR_BOUNDS_UPPER_LEFT);graphicInfo.setX(upperLeftNode.get(EDITOR_BOUNDS_X).asDouble() + parentX);graphicInfo.setY(upperLeftNode.get(EDITOR_BOUNDS_Y).asDouble() + parentY);ObjectNode lowerRightNode = (ObjectNode) boundsNode.get(EDITOR_BOUNDS_LOWER_RIGHT);graphicInfo.setWidth(lowerRightNode.get(EDITOR_BOUNDS_X).asDouble() - graphicInfo.getX() + parentX);graphicInfo.setHeight(lowerRightNode.get(EDITOR_BOUNDS_Y).asDouble() - graphicInfo.getY() + parentY);String childShapeId = jsonChildNode.get(EDITOR_SHAPE_ID).asText();bpmnModel.addGraphicInfo(BpmnJsonConverterUtil.getElementId(jsonChildNode),graphicInfo);shapeMap.put(childShapeId, jsonChildNode);ArrayNode outgoingNode = (ArrayNode) jsonChildNode.get("outgoing");if ((outgoingNode != null) && (outgoingNode.size() > 0)) {for (JsonNode outgoingChildNode : outgoingNode) {JsonNode resourceNode = outgoingChildNode.get(EDITOR_SHAPE_ID);if (resourceNode != null) {sourceRefMap.put(resourceNode.asText(),jsonChildNode);}}}readShapeDI(jsonChildNode, graphicInfo.getX(),graphicInfo.getY(), shapeMap, sourceRefMap,bpmnModel);}}}}private void filterAllEdges(JsonNode objectNode,Map<String, JsonNode> edgeMap,Map<String, List<JsonNode>> sourceAndTargetMap,Map<String, JsonNode> shapeMap, Map<String, JsonNode> sourceRefMap) {if (objectNode.get(EDITOR_CHILD_SHAPES) != null) {for (JsonNode jsonChildNode : objectNode.get(EDITOR_CHILD_SHAPES)) {ObjectNode childNode = (ObjectNode) jsonChildNode;String stencilId = BpmnJsonConverterUtil.getStencilId(childNode);if (STENCIL_SUB_PROCESS.equals(stencilId)) {filterAllEdges(childNode, edgeMap, sourceAndTargetMap,shapeMap, sourceRefMap);} else if (STENCIL_SEQUENCE_FLOW.equals(stencilId)|| STENCIL_ASSOCIATION.equals(stencilId)) {String childEdgeId = BpmnJsonConverterUtil.getElementId(childNode);JsonNode targetNode = childNode.get("target");if ((targetNode != null) && (targetNode.isNull() == false)) {String targetRefId = targetNode.get(EDITOR_SHAPE_ID).asText();List<JsonNode> sourceAndTargetList = new ArrayList<JsonNode>();sourceAndTargetList.add(sourceRefMap.get(childNode.get(EDITOR_SHAPE_ID).asText()));sourceAndTargetList.add(shapeMap.get(targetRefId));sourceAndTargetMap.put(childEdgeId, sourceAndTargetList);}edgeMap.put(childEdgeId, childNode);}}}}private void readEdgeDI(Map<String, JsonNode> edgeMap,Map<String, List<JsonNode>> sourceAndTargetMap, BpmnModel bpmnModel) {for (String edgeId : edgeMap.keySet()) {JsonNode edgeNode = edgeMap.get(edgeId);List<JsonNode> sourceAndTargetList = sourceAndTargetMap.get(edgeId);JsonNode sourceRefNode = null;JsonNode targetRefNode = null;if ((sourceAndTargetList != null)&& (sourceAndTargetList.size() > 1)) {sourceRefNode = sourceAndTargetList.get(0);targetRefNode = sourceAndTargetList.get(1);}if (sourceRefNode == null) {LOGGER.info("Skipping edge {} because source ref is null",edgeId);continue;}if (targetRefNode == null) {LOGGER.info("Skipping edge {} because target ref is null",edgeId);continue;}JsonNode dockersNode = edgeNode.get(EDITOR_DOCKERS);double sourceDockersX = dockersNode.get(0).get(EDITOR_BOUNDS_X).asDouble();double sourceDockersY = dockersNode.get(0).get(EDITOR_BOUNDS_Y).asDouble();GraphicInfo sourceInfo = bpmnModel.getGraphicInfo(BpmnJsonConverterUtil.getElementId(sourceRefNode));GraphicInfo targetInfo = bpmnModel.getGraphicInfo(BpmnJsonConverterUtil.getElementId(targetRefNode));double sourceRefLineX = sourceInfo.getX() + sourceDockersX;double sourceRefLineY = sourceInfo.getY() + sourceDockersY;double nextPointInLineX;double nextPointInLineY;nextPointInLineX = dockersNode.get(1).get(EDITOR_BOUNDS_X).asDouble();nextPointInLineY = dockersNode.get(1).get(EDITOR_BOUNDS_Y).asDouble();if (dockersNode.size() == 2) {nextPointInLineX += targetInfo.getX();nextPointInLineY += targetInfo.getY();}Line2D firstLine = new Line2D(sourceRefLineX, sourceRefLineY,nextPointInLineX, nextPointInLineY);String sourceRefStencilId = BpmnJsonConverterUtil.getStencilId(sourceRefNode);String targetRefStencilId = BpmnJsonConverterUtil.getStencilId(targetRefNode);List<GraphicInfo> graphicInfoList = new ArrayList<GraphicInfo>();AbstractContinuousCurve2D source2D = null;if (DI_CIRCLES.contains(sourceRefStencilId)) {source2D = new Circle2D(sourceInfo.getX() + sourceDockersX,sourceInfo.getY() + sourceDockersY, sourceDockersX);} else if (DI_RECTANGLES.contains(sourceRefStencilId)) {source2D = createRectangle(sourceInfo);} else if (DI_GATEWAY.contains(sourceRefStencilId)) {source2D = createGateway(sourceInfo);}if (source2D != null) {Collection<Point2D> intersections = source2D.intersections(firstLine);if ((intersections != null) && (intersections.size() > 0)) {Point2D intersection = intersections.iterator().next();graphicInfoList.add(createGraphicInfo(intersection.x(),intersection.y()));} else {graphicInfoList.add(createGraphicInfo(sourceRefLineX,sourceRefLineY));}}Line2D lastLine = null;if (dockersNode.size() > 2) {for (int i = 1; i < (dockersNode.size() - 1); i++) {double x = dockersNode.get(i).get(EDITOR_BOUNDS_X).asDouble();double y = dockersNode.get(i).get(EDITOR_BOUNDS_Y).asDouble();graphicInfoList.add(createGraphicInfo(x, y));}double startLastLineX = dockersNode.get(dockersNode.size() - 2).get(EDITOR_BOUNDS_X).asDouble();double startLastLineY = dockersNode.get(dockersNode.size() - 2).get(EDITOR_BOUNDS_Y).asDouble();double endLastLineX = dockersNode.get(dockersNode.size() - 1).get(EDITOR_BOUNDS_X).asDouble();double endLastLineY = dockersNode.get(dockersNode.size() - 1).get(EDITOR_BOUNDS_Y).asDouble();endLastLineX += targetInfo.getX();endLastLineY += targetInfo.getY();lastLine = new Line2D(startLastLineX, startLastLineY,endLastLineX, endLastLineY);} else {lastLine = firstLine;}AbstractContinuousCurve2D target2D = null;if (DI_RECTANGLES.contains(targetRefStencilId)) {target2D = createRectangle(targetInfo);} else if (DI_CIRCLES.contains(targetRefStencilId)) {double targetDockersX = dockersNode.get(dockersNode.size() - 1).get(EDITOR_BOUNDS_X).asDouble();double targetDockersY = dockersNode.get(dockersNode.size() - 1).get(EDITOR_BOUNDS_Y).asDouble();target2D = new Circle2D(targetInfo.getX() + targetDockersX,targetInfo.getY() + targetDockersY, targetDockersX);} else if (DI_GATEWAY.contains(targetRefStencilId)) {target2D = createGateway(targetInfo);}if (target2D != null) {Collection<Point2D> intersections = target2D.intersections(lastLine);if ((intersections != null) && (intersections.size() > 0)) {Point2D intersection = intersections.iterator().next();graphicInfoList.add(createGraphicInfo(intersection.x(),intersection.y()));} else {graphicInfoList.add(createGraphicInfo(lastLine.getPoint2().x(), lastLine.getPoint2().y()));}}bpmnModel.addFlowGraphicInfoList(edgeId, graphicInfoList);// if sequence has a name, just add a label graphic infoif (!"".equals(edgeNode.get("properties").get("name"))) {bpmnModel.addLabelGraphicInfo(edgeId,createGraphicInfo(graphicInfoList.get(0).getX(),graphicInfoList.get(0).getY()));}}}private Polyline2D createRectangle(GraphicInfo graphicInfo) {Polyline2D rectangle = new Polyline2D(new Point2D(graphicInfo.getX(),graphicInfo.getY()), new Point2D(graphicInfo.getX()+ graphicInfo.getWidth(), graphicInfo.getY()), new Point2D(graphicInfo.getX() + graphicInfo.getWidth(), graphicInfo.getY()+ graphicInfo.getHeight()), new Point2D(graphicInfo.getX(), graphicInfo.getY()+ graphicInfo.getHeight()), new Point2D(graphicInfo.getX(), graphicInfo.getY()));return rectangle;}private Polyline2D createGateway(GraphicInfo graphicInfo) {double middleX = graphicInfo.getX() + (graphicInfo.getWidth() / 2);double middleY = graphicInfo.getY() + (graphicInfo.getHeight() / 2);Polyline2D gatewayRectangle = new Polyline2D(new Point2D(graphicInfo.getX(), middleY), new Point2D(middleX,graphicInfo.getY()), new Point2D(graphicInfo.getX()+ graphicInfo.getWidth(), middleY), new Point2D(middleX,graphicInfo.getY() + graphicInfo.getHeight()), new Point2D(graphicInfo.getX(), middleY));return gatewayRectangle;}private GraphicInfo createGraphicInfo(double x, double y) {GraphicInfo graphicInfo = new GraphicInfo();graphicInfo.setX(x);graphicInfo.setY(y);return graphicInfo;}class FlowWithContainer {protected SequenceFlow sequenceFlow;protected FlowElementsContainer flowContainer;public FlowWithContainer(SequenceFlow sequenceFlow,FlowElementsContainer flowContainer) {this.sequenceFlow = sequenceFlow;this.flowContainer = flowContainer;}public SequenceFlow getSequenceFlow() {return sequenceFlow;}public void setSequenceFlow(SequenceFlow sequenceFlow) {this.sequenceFlow = sequenceFlow;}public FlowElementsContainer getFlowContainer() {return flowContainer;}public void setFlowContainer(FlowElementsContainer flowContainer) {this.flowContainer = flowContainer;}} }

重新轉換模板再查看流程圖進行驗證。 注:這樣解決雖然能顯示連線名稱了,但是會出現連線名稱顯示位置不準確的問題。解決辦法:重寫DefaultProcessDiagramGenerator類的generateProcessDiagram方法:

public CustomProcessDiagramCanvas generateProcessDiagram(BpmnModel bpmnModel, String imageType,List<String> highLightedActivities, List<String> highLightedFlows, String activityFontName,String labelFontName, String annotationFontName, ClassLoader customClassLoader, double scaleFactor,Color [] colors) {prepareBpmnModel(bpmnModel);CustomProcessDiagramCanvas processDiagramCanvas = initProcessDiagramCanvas(bpmnModel, imageType, activityFontName, labelFontName, annotationFontName, customClassLoader);// Draw pool shape, if process is participant in collaborationfor (Pool pool : bpmnModel.getPools()) {GraphicInfo graphicInfo = bpmnModel.getGraphicInfo(pool.getId());processDiagramCanvas.drawPoolOrLane(pool.getName(), graphicInfo);}// Draw lanesfor (Process process : bpmnModel.getProcesses()) {for (Lane lane : process.getLanes()) {GraphicInfo graphicInfo = bpmnModel.getGraphicInfo(lane.getId());processDiagramCanvas.drawPoolOrLane(lane.getName(), graphicInfo);}}// Draw activities and their sequence-flowsfor (Process process: bpmnModel.getProcesses()) {List<FlowNode> flowNodeList= process.findFlowElementsOfType(FlowNode.class);for (FlowNode flowNode : flowNodeList) {drawActivity(processDiagramCanvas, bpmnModel, flowNode, highLightedActivities, highLightedFlows, scaleFactor, colors);}}// Draw artifactsfor (Process process : bpmnModel.getProcesses()) {for (Artifact artifact : process.getArtifacts()) {drawArtifact(processDiagramCanvas, bpmnModel, artifact);}List<SubProcess> subProcesses = process.findFlowElementsOfType(SubProcess.class, true);if (subProcesses != null) {for (SubProcess subProcess : subProcesses) {for (Artifact subProcessArtifact : subProcess.getArtifacts()) {drawArtifact(processDiagramCanvas, bpmnModel, subProcessArtifact);}}}}return processDiagramCanvas;}protected void drawActivity(CustomProcessDiagramCanvas processDiagramCanvas, BpmnModel bpmnModel, FlowNode flowNode,List<String> highLightedActivities, List<String> highLightedFlows, double scaleFactor, Color[] colors) {ActivityDrawInstruction drawInstruction = activityDrawInstructions.get(flowNode.getClass());if (drawInstruction != null) {drawInstruction.draw(processDiagramCanvas, bpmnModel, flowNode);// Gather info on the multi instance markerboolean multiInstanceSequential = false, multiInstanceParallel = false, collapsed = false;if (flowNode instanceof Activity) {Activity activity = (Activity) flowNode;MultiInstanceLoopCharacteristics multiInstanceLoopCharacteristics = activity.getLoopCharacteristics();if (multiInstanceLoopCharacteristics != null) {multiInstanceSequential = multiInstanceLoopCharacteristics.isSequential();multiInstanceParallel = !multiInstanceSequential;}}// Gather info on the collapsed markerGraphicInfo graphicInfo = bpmnModel.getGraphicInfo(flowNode.getId()); if (flowNode instanceof SubProcess) {collapsed = graphicInfo.getExpanded() != null && !graphicInfo.getExpanded();} else if (flowNode instanceof CallActivity) {collapsed = true;}if (scaleFactor == 1.0) {// Actually draw the markersprocessDiagramCanvas.drawActivityMarkers((int) graphicInfo.getX(), (int) graphicInfo.getY(),(int) graphicInfo.getWidth(), (int) graphicInfo.getHeight(), multiInstanceSequential, multiInstanceParallel, collapsed);}// Draw highlighted activitiesif (highLightedActivities.contains(flowNode.getId())) {if(flowNode.getId().equals(highLightedActivities.get(highLightedActivities.size()-1))&& !(flowNode instanceof EndEvent)) {//非結束節點,并且是當前節點 drawHighLight((flowNode instanceof StartEvent), processDiagramCanvas, bpmnModel.getGraphicInfo(flowNode.getId()), colors[1]); }else {//普通節點drawHighLight((flowNode instanceof StartEvent)||(flowNode instanceof EndEvent),processDiagramCanvas, bpmnModel.getGraphicInfo(flowNode.getId()), colors[0]);} }}// Outgoing transitions of activityfor (SequenceFlow sequenceFlow : flowNode.getOutgoingFlows()) {boolean highLighted = (highLightedFlows.contains(sequenceFlow.getId()));String defaultFlow = null;if (flowNode instanceof Activity) {defaultFlow = ((Activity) flowNode).getDefaultFlow();} else if (flowNode instanceof Gateway) {defaultFlow = ((Gateway) flowNode).getDefaultFlow();}boolean isDefault = false;if (defaultFlow != null && defaultFlow.equalsIgnoreCase(sequenceFlow.getId())) {isDefault = true;} // boolean drawConditionalIndicator = sequenceFlow.getConditionExpression() != null && !(flowNode instanceof Gateway);String sourceRef = sequenceFlow.getSourceRef();String targetRef = sequenceFlow.getTargetRef();FlowElement sourceElement = bpmnModel.getFlowElement(sourceRef);FlowElement targetElement = bpmnModel.getFlowElement(targetRef);List<GraphicInfo> graphicInfoList = bpmnModel.getFlowLocationGraphicInfo(sequenceFlow.getId());if (graphicInfoList != null && graphicInfoList.size() > 0) {graphicInfoList = connectionPerfectionizer(processDiagramCanvas, bpmnModel, sourceElement, targetElement, graphicInfoList);int xPoints[]= new int[graphicInfoList.size()];int yPoints[]= new int[graphicInfoList.size()];for (int i=1; i<graphicInfoList.size(); i++) {GraphicInfo graphicInfo = graphicInfoList.get(i);GraphicInfo previousGraphicInfo = graphicInfoList.get(i-1);if (i == 1) {xPoints[0] = (int) previousGraphicInfo.getX();yPoints[0] = (int) previousGraphicInfo.getY();}xPoints[i] = (int) graphicInfo.getX();yPoints[i] = (int) graphicInfo.getY();}//畫高亮線processDiagramCanvas.drawSequenceflow(xPoints, yPoints, false, isDefault, highLighted, scaleFactor, colors[0]);// Draw sequenceflow label // GraphicInfo labelGraphicInfo = bpmnModel.getLabelGraphicInfo(sequenceFlow.getId()); // if (labelGraphicInfo != null) { // processDiagramCanvas.drawLabel(sequenceFlow.getName(), labelGraphicInfo, false); // }else {//解決流程圖連線名稱不顯示的BUGGraphicInfo lineCenter = getLineCenter(graphicInfoList);processDiagramCanvas.drawLabel(highLighted, sequenceFlow.getName(), lineCenter, Math.abs(xPoints[1]-xPoints[0]) >= 5); // }}}

重點修改之處在注釋的幾行代碼上,請讀者自己查看思考。

轉載于:https://my.oschina.net/u/180480/blog/2248964

總結

以上是生活随笔為你收集整理的解决activiti中由模板转换的流程图连线名称缺失问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

成人av电影免费 | 日本激情视频中文字幕 | 精品字幕在线 | 久久免费视频6 | 日日夜夜骑 | 亚洲视频在线视频 | 九七人人干 | 婷婷色九月| 亚洲精选视频在线 | 欧美日韩xx | 99久久综合国产精品二区 | 狠狠干夜夜操天天爽 | 5月丁香婷婷综合 | 精品在线免费观看 | 天天综合中文 | 日韩字幕在线观看 | 欧美一级片免费观看 | 日日夜夜网 | 在线观看成人网 | 国产在线视频一区二区 | 久9在线 | 国产专区欧美专区 | 欧美一区二视频在线免费观看 | 免费av一级电影 | 97超碰资源总站 | av短片在线 | 久久精品视 | 国产一级视频在线观看 | 久久久影视 | 久久国产亚洲视频 | 精品视频久久久 | 国产精品欧美一区二区 | 国产毛片在线 | 激情久久综合网 | 日韩高清免费观看 | 2023国产精品自产拍在线观看 | 99精品久久久久久久久久综合 | 四虎免费在线观看视频 | 久久视频这里有久久精品视频11 | 久草免费在线 | 在线免费av观看 | 国产三级精品在线 | 国产小视频在线 | 国产精品美女久久久久久网站 | 久久成人视屏 | 国产亚洲欧美精品久久久久久 | 日韩在线视频线视频免费网站 | 中文字幕资源在线观看 | 在线精品亚洲 | 在线观看视频在线观看 | 日韩av播放在线 | 久久免费视频在线观看30 | 日韩电影中文字幕在线观看 | 91自拍视频在线观看 | 青青河边草免费视频 | 99精品在线视频播放 | 西西4444www大胆视频 | 婷婷激情小说网 | 精品在线小视频 | 国产精品一区二区 91 | av888av.com| 精品一区二区三区在线播放 | 国产成人免费在线观看 | 麻豆久久精品 | 日韩在线视 | 国产资源网 | 99久久精品网 | 91麻豆精品国产午夜天堂 | 综合久久综合久久 | 久久婷婷五月综合色丁香 | 国产一区二区高清视频 | 久久毛片高清国产 | 人人澡人人模 | 欧美乱码精品一区二区 | 三三级黄色片之日韩 | 91尤物国产尤物福利在线播放 | 69av国产 | 丁香五月亚洲综合在线 | 日韩精品一区电影 | 国产中文伊人 | 久久免费在线视频 | 午夜国产一区二区三区四区 | 久久免费视频1 | 国产69精品久久99的直播节目 | 狠狠操.com | 黄色成人免费电影 | 九九久久成人 | 国产精品久久久久久久免费 | 香蕉视频免费在线播放 | 国产免费中文字幕 | 精品视频免费看 | 欧美aaa级片 | 久操综合| 亚洲一区网站 | 天天爱天天舔 | 午夜精品剧场 | 色噜噜日韩精品一区二区三区视频 | 丝袜美腿在线视频 | 97精品超碰一区二区三区 | 在线影院 国内精品 | 九九激情视频 | 亚洲视频在线看 | 免费高清av在线看 | 97国产| 免费看污的网站 | 成人免费在线视频观看 | www.神马久久 | 国产99久久九九精品免费 | 天天爽天天爽天天爽 | 国产精品情侣视频 | 字幕网资源站中文字幕 | 日韩大片在线播放 | 日韩欧美网站 | 最近中文字幕免费大全 | 日韩视频在线观看视频 | 蜜桃视频成人在线观看 | 99久久久久久久久久 | 99视频久| 99免费在线观看视频 | 天天干天天拍天天操 | 少妇bbw搡bbbb搡bbb | 色综合久久88色综合天天6 | 亚洲精品久久久久久久不卡四虎 | 国产精品一区二区久久久 | 亚洲国产中文在线观看 | 激情偷乱人伦小说视频在线观看 | 黄色电影在线免费观看 | 国产美女永久免费 | 九九热精品视频在线观看 | 亚洲美女免费精品视频在线观看 | 国产盗摄精品一区二区 | 国产精品久久三 | 国产在线观看免费观看 | 九九九视频精品 | wwwwww色| 91在线播放综合 | 亚洲免费资源 | 国产成本人视频在线观看 | 摸bbb搡bbb搡bbbb | 一区二区三区日韩视频在线观看 | 欧美精品在线视频 | 日本黄色免费看 | 亚洲黄a | 天天干天天看 | 国产探花在线看 | 天天插天天色 | 久久人人爽人人人人片 | 在线视频 成人 | 91麻豆福利 | 免费av电影网站 | 亚洲国产精品第一区二区 | 国产亚洲成av片在线观看 | 国产区 在线 | 九九精品在线观看 | 日韩在线观看视频中文字幕 | 国产美女精品 | 9999精品 | 亚洲影视九九影院在线观看 | 免费看国产曰批40分钟 | www.com.黄 | 亚洲综合欧美日韩狠狠色 | 日日操天天操狠狠操 | 91视频成人免费 | 久久久综合 | 高清av不卡 | 精产嫩模国品一二三区 | 国产无套一区二区三区久久 | 国产精品美女久久久久久2018 | 日本久久电影网 | 免费一级日韩欧美性大片 | 色av男人的天堂免费在线 | 中日韩欧美精彩视频 | 一级黄毛片 | 黄色毛片一级 | 欧美a在线免费观看 | 国产成人区 | 二区三区精品 | 精品久久久一区二区 | 激情狠狠干 | 国产亚洲精品久久 | 丁香婷婷激情国产高清秒播 | 黄色小网站在线观看 | 免费久久久 | 麻豆久久一区 | www日韩在线 | 国产精品三级视频 | 国产五月婷婷 | 在线看日韩av | 国产一级免费观看 | 香蕉在线视频观看 | 国产日韩欧美综合在线 | 国产精品国产三级国产aⅴ9色 | 亚洲精品五月天 | 久久99久久久久 | 久久久国产一区二区 | 国产一区在线视频 | 国产又黄又爽又猛视频日本 | 日韩免费中文字幕 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 国产日韩欧美在线影视 | 9i看片成人免费看片 | 国产成人精品久久二区二区 | 日韩欧美在线观看一区二区 | 日本精品久久久久中文字幕 | 日日操网站 | 99热9| 国产91精品欧美 | 99久久国产免费看 | 亚洲永久国产精品 | 99国产精品一区 | 色姑娘综合网 | 亚州精品天堂中文字幕 | 最新色站 | 成人久久国产 | 五月天六月婷婷 | 国产一级黄色免费看 | 国产区 在线 | 国产剧情av在线播放 | 日韩成人免费在线观看 | 制服丝袜在线 | 狠狠做深爱婷婷综合一区 | 中文字幕日韩国产 | 亚洲国产精品传媒在线观看 | 91亚洲精品久久久久图片蜜桃 | 亚洲精品 在线视频 | 91精品久久久久久久91蜜桃 | 国外av在线 | 日韩三级在线观看 | 91插插插免费视频 | 久久综合色天天久久综合图片 | 91精品入口 | 成人精品一区二区三区中文字幕 | 精品一区二区三区久久 | 美女视频久久 | 黄色在线看网站 | 免费黄色在线网址 | 91成人在线观看喷潮 | 96精品高清视频在线观看软件特色 | 丁香婷婷在线 | 在线观看一区二区视频 | 美女视频a美女大全免费下载蜜臀 | 91女人18片女毛片60分钟 | 久久久久久久久久久电影 | 天天综合久久综合 | 在线有码中文 | 网站在线观看你们懂的 | 国产精品久久久久9999吃药 | 婷婷在线播放 | 婷五月天激情 | 国产精品久久久久久久久久99 | 久久午夜影视 | 免费黄色av片 | 亚洲在线看| 婷婷日韩| 毛片一二区 | 婷婷丁香六月天 | 日本精品久久久久中文字幕 | 日本大片免费观看在线 | 久久视频精品在线 | 蜜臀av网站| 国产视频网站在线观看 | 免费在线激情视频 | 成人久久18免费网站 | 精品一区在线看 | 欧美精品一区在线发布 | 视频在线观看99 | 97av色| 伊人久久婷婷 | 在线中文字幕网站 | 五月激情丁香图片 | 九色视频网址 | 99九九99九九九视频精品 | 中文字幕乱码日本亚洲一区二区 | 特级a老妇做爰全过程 | 久久成人国产 | 国产精品视频区 | 日韩精品视频免费专区在线播放 | 国内精品久久久久久中文字幕 | 欧美激情另类 | 黄色片免费在线 | 欧美日韩一区二区三区在线免费观看 | 精品国产伦一区二区三区免费 | 亚洲国产激情 | 久久综合色一综合色88 | 成人性生交大片免费看中文网站 | 欧美午夜激情网 | 91黄色小网站| 国内精品久久久久久久影视麻豆 | 99久e精品热线免费 99国产精品久久久久久久久久 | av在线观 | av成年人电影 | 亚洲小视频在线 | 午夜久久久精品 | 国产精品99久久久久久有的能看 | 国产在线久久久 | 婷婷六月天丁香 | av在线播放免费 | 国产精品成人免费精品自在线观看 | 成片免费观看视频999 | 免费高清在线视频一区· | 免费三级黄色 | 91色影院| 亚洲精品午夜国产va久久成人 | 亚洲精品在线免费 | 国产一级二级视频 | 久久99久久99免费视频 | 免费观看十分钟 | 国产韩国日本高清视频 | 欧美日韩一级视频 | 日韩视频免费在线 | 97av色| 国产精品久久久久久久久久免费看 | 久久综合久久综合这里只有精品 | 毛片一区二区 | 婷婷六月天在线 | 最新av在线免费观看 | 亚洲毛片一区二区三区 | 五月婷丁香网 | 日韩精品中文字幕在线 | 国产欧美三级 | 在线免费观看视频你懂的 | 成人高清av在线 | 国产精品一区二区麻豆 | 一区二区精品国产 | 久久av免费 | 久草视频播放 | 久久久免费国产 | 992tv在线观看网站 | 欧洲亚洲激情 | 久久99国产精品久久99 | 欧美精品一区二区蜜臀亚洲 | 九九九在线观看 | 亚洲永久精品在线观看 | 国产中文字幕国产 | 国产在线精品二区 | 一区二区三区播放 | 国产精品热视频 | 手机看片99| 久久久噜噜噜久久久 | 黄色视屏在线免费观看 | 免费看v片 | 亚洲国产精品99久久久久久久久 | 日韩欧美一区二区三区免费观看 | 日韩成人一级大片 | 97超碰在线播放 | av观看免费在线 | 日本黄色免费网站 | 五月天综合网 | 亚洲爱视频 | 最新中文字幕在线观看视频 | 日韩在线视频观看 | 狠狠躁夜夜av | 天天干夜夜想 | 久久国产精品久久精品 | 三级小视频在线观看 | 成人作爱视频 | 婷婷久久综合网 | 免费看毛片网站 | 91av视频在线观看 | 欧洲精品视频一区二区 | 国产超碰97 | 日日插日日干 | 免费看亚洲毛片 | 中文字幕一区二区三区四区久久 | 人人藻人人澡人人爽 | 久久久99精品免费观看app | 国产成人高清av | 免费av片在线 | 日本xxxx.com | 91精品天码美女少妇 | 天天干夜夜干 | 欧洲视频一区 | 国产成人精品免费在线观看 | 国产精品一区二区久久精品爱涩 | 天天草网站 | 999国内精品永久免费视频 | 在线精品国产 | www.狠狠插.com | 欧美性网站 | 日日夜色| 日b视频在线观看网址 | 中文字幕av在线不卡 | 4438全国亚洲精品观看视频 | 欧美极品一区二区三区 | 国产在线综合视频 | 免费av片在线 | 成人一区二区三区在线 | 日韩欧美成 | 日本精品久久久久影院 | 西西www444| 天天干天天做天天操 | 色夜视频 | 91香蕉国产在线观看软件 | 久久男人影院 | 人人爱天天操 | 欧美成人基地 | 99久久99久久精品国产片 | 91在线免费视频观看 | 婷婷精品进入 | 免费成人在线视频网站 | 麻豆综合网 | 国产日产亚洲精华av | 永久免费毛片在线观看 | 欧美日韩网址 | 久久久国产精品人人片99精片欧美一 | va视频在线观看 | 伊人影院在线观看 | 久久综合色一综合色88 | 精品伊人久久久 | 久久激情电影 | 成人免费一级 | 99视频免费播放 | 中文字幕文字幕一区二区 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 亚洲欧洲成人精品av97 | 国内视频在线 | 国产精品一区二区三区观看 | 亚洲人毛片| 国产精品久久久久久久久毛片 | 国产专区欧美专区 | 91精品国产自产在线观看 | 黄色免费看片网站 | 日韩一区精品 | 国产一区二区午夜 | 亚洲第一成网站 | 久久久久久综合网天天 | 久久人人射| 国产精品日韩欧美一区二区 | 中文字幕免费一区 | www四虎影院| 伊人导航 | 91香蕉视频在线下载 | 激情五月婷婷激情 | 最近中文字幕免费 | 99久视频| 最新动作电影 | 久久久国产日韩 | 一区二区视频电影在线观看 | 久久久亚洲麻豆日韩精品一区三区 | 99免费在线| 一级精品视频在线观看宜春院 | 日日干日日 | 日韩网站在线免费观看 | 欧美国产日韩激情 | 青青草国产精品 | 天天综合天天综合 | av成人免费在线看 | 丁香激情婷婷 | 久久香蕉国产 | 亚洲精品国产精品99久久 | 超碰日韩在线 | 色九九在线 | 天天综合网天天综合色 | 国产二区精品 | 天天干人人干 | 日韩视频中文字幕在线观看 | 日日碰狠狠躁久久躁综合网 | 国产一区二区三精品久久久无广告 | 日韩av一区二区在线 | av免费在线免费观看 | 国产精品第十页 | 日韩欧美网址 | 一区二区视频免费在线观看 | 久久免费黄色网址 | 97国产情侣爱久久免费观看 | 99福利片| 欧美日韩国产精品一区二区三区 | 黄色一级在线观看 | 在线国产福利 | 美女黄频免费 | 久久久久www | 国产精品中文在线 | www.com在线观看 | 成年人免费电影在线观看 | 亚洲一区在线看 | 国语黄色片 | 九九热99视频 | 久久综合色天天久久综合图片 | 午夜精品一二区 | 成人黄色在线观看视频 | 五月婷婷在线视频观看 | 精品国产亚洲在线 | 91精品网站在线观看 | 国内精品久久久久久久久久清纯 | 在线观看成人毛片 | 麻豆94tv免费版 | 久草资源在线 | 亚洲片在线观看 | 久久久久久在线观看 | 日韩aⅴ视频 | 久久99精品热在线观看 | 一区二区丝袜 | 一级一级一片免费 | 成人午夜免费剧场 | 久久久久免费精品国产 | 欧美日韩在线视频观看 | 欧美激情第八页 | a黄色影院| 日韩精品一区二区三区免费观看 | 国产原厂视频在线观看 | 69精品 | 成人 亚洲 欧美 | 成人av电影免费在线观看 | 国产精品日韩在线播放 | 国产小视频91 | 日韩精品一区二区三区免费视频观看 | 日韩特级片 | 日韩欧美精品在线观看视频 | 久久久久久久久久久久影院 | 日韩精品视频免费看 | 久草在线播放视频 | 精品国产伦一区二区三区免费 | 久久综合免费 | 国产精品免费成人 | 亚洲资源在线 | 操操操夜夜操 | 欧美巨大荫蒂茸毛毛人妖 | 国产成人精品999 | 九九热在线视频免费观看 | 国产又粗又硬又长又爽的视频 | 国产成人久久av | 韩国精品福利一区二区三区 | 中文字幕黄色网址 | 伊人五月综合 | 久久人人爽人人爽 | 麻豆传媒一区二区 | 免费av在线网站 | 中文字幕一区二区三区在线观看 | 日本一区二区三区免费观看 | 精品一二三区 | 黄色小说在线观看视频 | avhd高清在线谜片 | 亚洲网站在线 | 久久久精品国产一区二区电影四季 | 视频国产 | 精品国产一区在线观看 | 国产精品一区二区三区在线免费观看 | 92精品国产成人观看免费 | av片免费播放 | 在线观看国产高清视频 | 精品国产视频在线 | 91av视频在线免费观看 | 99色网站| 波多野结衣资源 | 婷婷成人综合 | 国产直播av| 国产成人精品一区二区在线观看 | 丁香综合 | 伊人精品影院 | 91日韩在线专区 | 国产99区| 成人av片在线观看 | 亚洲少妇xxxx | 欧美黄网站 | 日日干美女| 美女网站在线 | 久久精品国产免费看久久精品 | 波多野结衣在线视频一区 | 一区二区电影在线观看 | 808电影免费观看三年 | 日韩av女优视频 | 999久久久免费视频 午夜国产在线观看 | 深爱激情久久 | 欧美在线观看小视频 | 国产一区二区高清不卡 | 精品久久久99| av丝袜天堂 | 久草干| 亚州国产精品视频 | 久久国产一二区 | 九九久 | 国产精品久久三 | 人人看人人爱 | 久草视频在线免费 | 天天射综合 | 亚洲国产av精品毛片鲁大师 | 色av婷婷| 九九九九色 | 国产精品影音先锋 | 日韩在线观看你懂得 | 亚洲一级黄色av | 在线免费观看视频 | 婷婷伊人综合亚洲综合网 | 在线观看涩涩 | 国产精品手机播放 | 国产成人三级在线播放 | av高清在线观看 | 天天爱天天操天天干 | 久草在线在线精品观看 | 婷婷在线视频观看 | 亚洲在线视频网站 | 九九热免费精品视频 | 精品国产福利在线 | av在线免费播放网站 | 亚洲日本一区二区在线 | 亚洲一区二区观看 | 久久久久久久久久电影 | 日本中文字幕在线电影 | 国产男女爽爽爽免费视频 | 欧美黄色软件 | 欧美日韩国产一区二区在线观看 | 成人影片在线免费观看 | 91最新网址 | 欧美亚洲成人免费 | 青青五月天 | 日日日日 | 国产91精品看黄网站 | 成人小视频在线观看免费 | 中文字幕视频播放 | 国产一区二区免费 | 欧美日韩久久久 | 激情久久影院 | 亚洲国产一二三 | 97成人精品视频在线播放 | 国产无套精品久久久久久 | 在线观看aa| 91福利区一区二区三区 | 97超碰人人模人人人爽人人爱 | 色国产视频 | 久草电影网 | 中文字幕欧美激情 | 欧美日在线 | 日韩高清不卡一区二区三区 | 在线观看完整版免费 | 国产色视频123区 | 国产精品va视频 | 毛片黄色一级 | 亚洲最大成人免费网站 | 久久久久久久久久久久亚洲 | 欧美嫩草影院 | 国产91九色蝌蚪 | 亚洲黄色免费在线看 | 91成人看片 | 在线观看精品一区 | 啪啪动态视频 | 免费看国产曰批40分钟 | 九九久久久久99精品 | 国产一区二区精 | 亚洲成年人av | 午夜色影院 | 精品自拍sae8—视频 | 久久久久草 | av丝袜在线| 国内精品免费久久影院 | 天天综合亚洲 | 国产精品国产三级国产专区53 | 韩日精品中文字幕 | 一级黄色片在线免费看 | 国产在线1区 | 亚洲91av| 日本黄色免费观看 | 91麻豆精品91久久久久同性 | 四虎影视成人永久免费观看亚洲欧美 | 久久网站免费 | 日韩av网站在线播放 | 婷婷激情在线观看 | 精品久久久久久亚洲 | 久久视频在线观看 | 五月天堂网 | 亚洲另类人人澡 | 亚洲国产三级 | 九九综合久久 | 九九精品视频在线观看 | 久久精品成人热国产成 | 国产第一页精品 | 超碰成人网 | 麻豆传媒视频在线免费观看 | 日韩系列 | 欧美成人亚洲成人 | 久草精品视频 | 一区二区三区四区不卡 | 精品a在线 | 91视频在线国产 | 亚洲专区一二三 | 一本—道久久a久久精品蜜桃 | 91麻豆文化传媒在线观看 | 精品国产欧美一区二区 | 91视频久久久久 | 久久综合九色综合久久久精品综合 | 中文字幕一二三区 | 亚洲免费av电影 | a在线一区 | 久草久热| av中文天堂在线 | 黄色小视频在线观看免费 | 亚洲日本韩国一区二区 | 色橹橹欧美在线观看视频高清 | 在线观看亚洲视频 | 毛片网站免费 | 天天干天天想 | 日本黄色大片儿 | 亚洲日本成人网 | 国产乱对白刺激视频在线观看女王 | 在线视频一二区 | av中文字幕免费在线观看 | 特级西西www44高清大胆图片 | 久久精品国产一区二区电影 | 精品亚洲免费视频 | 国产精品乱码一区二区视频 | 中文字幕一区二区三 | 天天av资源 | 欧美精品久久久久久久免费 | 亚洲久久视频 | 国产欧美久久久精品影院 | 免费看v片网站 | 亚洲精品乱码久久久久久蜜桃不爽 | 91九色网站 | 黄色三级免费片 | 中文字幕免费观看全部电影 | 国产精品午夜在线观看 | 成人在线你懂得 | 91人人干 | 四虎国产免费 | av在观看 | 亚洲人人网 | 欧洲在线免费视频 | 操老逼免费视频 | 日韩视频免费观看高清 | 中文字幕免费高清在线观看 | 午夜视频免费播放 | 欧美精品久久久久久久久久 | 人人爽人人爽 | 国产一区久久久 | 综合网中文字幕 | 91av网址| 免费男女网站 | 99久久超碰中文字幕伊人 | 天天干天天射天天操 | 久久精品国亚洲 | 免费看片成年人 | 天天综合日日夜夜 | 黄色av电影免费观看 | 黄色国产在线观看 | 欧美一级片免费观看 | 成人黄色国产 | 精品免费观看 | 国产精品久久久久久久久久久久久 | 成人在线免费观看视视频 | 国产视频一区在线免费观看 | 久久精品高清视频 | 久久av免费电影 | 日韩欧美在线视频一区二区 | 久久国产精品久久精品国产演员表 | 久久精品视频播放 | 精品国产一区二区三区免费 | 色婷婷午夜| 国产精品综合在线 | 久久99国产精品自在自在app | 国产精品一区二区三区在线播放 | 免费av大片 | 国产精品网红直播 | a黄色一级 | 少妇bbb搡bbbb搡bbbb′ | 国产视频精品久久 | 毛片网在线播放 | 激情五月婷婷 | 精品国产aⅴ麻豆 | 午夜狠狠操 | 久久精品电影 | 精品国产区 | 四虎成人精品永久免费av | 狠狠色丁香 | 日韩免费视频网站 | 国产精品mv在线观看 | 国产精品系列在线播放 | 久久久久电影网站 | 国产 中文 日韩 欧美 | 日韩欧美亚州 | 99r国产精品 | 久久综合成人网 | 六月丁香激情网 | 一级性视频 | av五月婷婷 | 97在线精品国自产拍中文 | 日韩一级电影网站 | 91夫妻自拍| 欧美日韩在线精品 | 天天干天天射天天插 | av综合在线观看 | 国产精品青草综合久久久久99 | 国际精品久久久久 | 国产成人性色生活片 | 黄污网 | 国产999精品视频 | 91香蕉视频色版 | 免费观看一级特黄欧美大片 | 国产精品视频在线观看 | 在线精品播放 | 国产一级黄色免费看 | www.玖玖玖| 日韩欧美在线观看 | 久久在线精品 | 青草视频在线 | 99热国产在线 | 综合婷婷丁香 | 久久久国内精品 | 国产精品粉嫩 | www.色午夜.com| 国产又粗又猛又色又黄视频 | 亚洲视频综合在线 | 日本中文字幕在线一区 | 国内精品久久久久久中文字幕 | 亚洲精品午夜一区人人爽 | 欧美黄色免费 | 免费看污在线观看 | 91精品第一页 | 欧美一区二区三区免费观看 | 超碰人人超 | 亚洲国产精品影院 | 五月天伊人网 | 国产在线a | 在线黄色免费av | 精品一区二区三区久久久 | 婷婷亚洲综合 | 天天激情天天干 | 久久久免费高清视频 | 日韩在线视频播放 | 免费在线观看视频一区 | 久久免费精品 | av在线网站大全 | 久草男人天堂 | 中日韩三级视频 | 999精品 | 日韩精品一区二区三区免费视频观看 | 国产精品久久久久久久久久妇女 | 日本护士三级少妇三级999 | 最新国产在线观看 | 午夜av电影院 | 中文字幕在线观看一区二区 | 日韩在线视频观看 | 国产精品xxxx18a99 | 亚洲一二区精品 | 亚洲一区二区观看 | 日本精品视频免费观看 | 婷婷中文字幕在线观看 | 亚州精品在线视频 | 亚洲成av人电影 | 视频国产区| 美女国内精品自产拍在线播放 | 国产精品一区二区久久 | 亚洲国产播放 | 国产高清免费在线观看 | 91在线免费视频观看 | 2000xxx影视 | 精品国产自在精品国产精野外直播 | 国产永久免费高清在线观看视频 | 四虎国产精品成人免费4hu | 国产剧情一区二区 | 久久9精品| 午夜av在线免费 | 中文理论片 | 婷婷草 | 国产精品99精品久久免费 | 97热久久免费频精品99 | 女人高潮特级毛片 | 午夜久久久久久久久久久 | 国产精品免费观看国产网曝瓜 | 国产一区二区不卡视频 | 中字幕视频在线永久在线观看免费 | 午夜精品99久久免费 | 视频一区二区精品 | 欧洲精品码一区二区三区免费看 | 麻豆精品国产传媒 | 国产永久网站 | 在线亚洲成人 | 97免费在线观看视频 | 久久亚洲福利视频 | 黄色电影在线免费观看 | 波多野结衣在线观看一区二区三区 | 91大神电影| 天天干天天干天天色 | 九九热.com | 黄视频网站大全 | 亚洲精品美女在线 | 久久久免费精品视频 | 国产麻豆电影 | 91在线视频网址 | 少妇激情久久 | 麻豆免费在线视频 | 五月天伊人网 | 成人在线黄色 | 一区二区三区 亚洲 | 欧美日韩不卡一区 | 国产精品黑丝在线观看 | 欧美日韩视频一区二区 | 岛国精品一区二区 | 久久字幕精品一区 | 精品亚洲成a人在线观看 | 欧美孕妇与黑人孕交 | 国产一区二区在线免费播放 | 免费在线观看av的网站 | 国内精品毛片 | 中文字幕国产精品 | 黄色精品网站 | 久久超碰网 | 色视频 在线 | 久久久久免费精品国产 | 中文字幕在线免费观看视频 | 国产精品色视频 | 在线观看的av | 成人免费xxx在线观看 | 91精彩视频 | 中文字幕国产亚洲 | 蜜臀久久99精品久久久无需会员 | 欧美一二三区在线观看 | 天天做天天射 | 四川bbb搡bbb爽爽视频 | 综合av在线| 亚洲伦理电影在线 | 日产中文字幕 | 黄色一级大片在线观看 | 久久爱导航 | 亚洲综合色av | 免费视频91蜜桃 | 九九九热精品免费视频观看 | 国产午夜在线观看 | 国产精品电影一区二区 | 国产破处视频在线播放 | 国产精品入口传媒 | 精品久久久999 | 三级视频日韩 | 人人插人人插 | 久久精品中文字幕一区二区三区 | 久久免费电影网 | 色婷五月天 | 久久午夜免费观看 | 97超碰人人澡人人爱 | 免费观看国产精品视频 | 欧美国产日韩久久 | 天堂va在线高清一区 | 久久久国产一区二区三区 | 久久av一区二区三区亚洲 | 国产99在线 | 久久精品8 | av福利在线播放 | 又黄又爽又湿又无遮挡的在线视频 | 色综合久久中文综合久久牛 | 国产字幕av | 黄色成人影院 | 色噜噜噜噜 | 国产自在线| 亚洲高清视频在线观看免费 | 久久影视一区 | 国产精品黑丝在线观看 | 色吊丝在线永久观看最新版本 | 中文字幕av在线不卡 | 国产99久久久久久免费看 | 国产精品美女久久久久久2018 | 2021国产在线 | 婷婷免费在线视频 | 丁香婷婷综合色啪 | 国内丰满少妇猛烈精品播 | 日躁夜躁狠狠躁2001 | 天天爽天天搞 | 麻豆视频免费网站 | 国产精品永久在线观看 | 99精品小视频 | 国产视频二区三区 | 99视频精品免费视频 | 在线视频福利 | 亚洲一区二区视频在线播放 | 日韩网站在线播放 | 久草精品视频在线看网站免费 | 久久久久成人免费 | 国产精品久久久久久久久久 | 人人澡超碰碰97碰碰碰软件 | 天堂在线一区 | 涩涩网站在线看 | 国产精品手机在线 | 精品1区二区 | 玖玖色在线观看 | 中文字幕在线观看完整版 | 日韩欧美高清视频在线观看 | 久久精品伊人 | 国产一级免费观看视频 | 亚洲精品在线免费播放 | 91精品国产一区二区在线观看 | 国产乱码精品一区二区三区介绍 | 欧美一级免费片 | 国产在线观看地址 | 91视频三区 | 午夜成人免费电影 | 日韩欧美一区二区在线 | 在线观看免费成人 | 国产91粉嫩白浆在线观看 | 91资源在线播放 | 日韩毛片久久久 | 欧美91精品久久久久国产性生爱 | 久青草视频在线观看 | 精品国产一区二区三区日日嗨 | 伊人久久影视 | 日韩av一区二区在线影视 | 色久网| 国产九九热视频 | 欧美日韩亚洲精品在线 | 精品久久久久久亚洲综合网站 | 久久精品日本啪啪涩涩 | 日b黄色片 |