flowable显示流程图,路径和节点
背景:在正常的flowable就是显示当前节点,路径需要我们自己获取,特别是来回的驳回会导致节点混乱,这里主要就是如何正确的显示流程图
效果:
已经结束的流程
正在执行的流程
代码:1、生成图片
public byte[] createImage2(String processInstanceId) { //1.获取当前的流程实例 ProcessInstance processInstance = runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).singleResult(); String processDefinitionId = null; List<String> activeActivityIds = null; //2.获取所有的历史轨迹对象 List<HistoricActivityInstance> list = historyService.createHistoricActivityInstanceQuery() .processInstanceId(processInstanceId).list(); Map<String, HistoricActivityInstance> hisActivityMap = new HashMap<>(); list.forEach(historicActivityInstance -> { if (!hisActivityMap.containsKey(historicActivityInstance.getActivityId())) { hisActivityMap.put(historicActivityInstance.getActivityId(), historicActivityInstance); } }); //3. 获取流程定义id和高亮的节点id if (processInstance != null) { //3.1. 正在运行的流程实例 processDefinitionId = processInstance.getProcessDefinitionId(); activeActivityIds = runtimeService.getActiveActivityIds(processInstanceId); } else { //3.2. 已经结束的流程实例 HistoricProcessInstance historicProcessInstance = historyService.createHistoricProcessInstanceQuery().processInstanceId(processInstanceId).singleResult(); processDefinitionId = historicProcessInstance.getProcessDefinitionId(); activeActivityIds = new ArrayList<>(); List<EndEvent> endEvents = bpmnModelService.findEndFlowElement(processDefinitionId); List<String> finalActiveActivityIds = activeActivityIds; endEvents.forEach(endEvent -> { if (hisActivityMap.containsKey(endEvent.getId())) { finalActiveActivityIds.add(endEvent.getId()); } }); } //4. 获取流程定义的所有节点信息 List<FlowNode> flowNodes = bpmnModelService.findFlowNodes(processDefinitionId); Map<String, FlowNode> activityMap = flowNodes.stream().collect(Collectors.toMap(FlowNode::getId, flowNode -> flowNode)); List<String> highLightedFlows = new ArrayList<>(); //5. 递归得到高亮线 activeActivityIds.forEach(activeActivityId -> this.getHighLightedFlows(activityMap, hisActivityMap, activeActivityId, highLightedFlows, activeActivityId)); //6. 获取bpmnModel对象 BpmnModel bpmnModel = bpmnModelService.getBpmnModelByProcessDefId(processDefinitionId); //7. 生成图片流 InputStream inputStream = flowProcessDiagramGenerator.generateDiagram(bpmnModel, activeActivityIds, highLightedFlows); //8. 转化成byte便于网络传输 byte[] datas = IoUtil.readInputStream(inputStream, "image inputStream name"); return datas; }
2、递归获取高private void getHighLightedFlows(
Map<String, FlowNode> flowNodeMap, Map<String, HistoricActivityInstance> hisActivityMap, String activeActivityId, List<String> highLightedFlows, String oldActivityId) { FlowNode flowNode = flowNodeMap.get(activeActivityId); List<SequenceFlow> incomingFlows = flowNode.getIncomingFlows(); for (SequenceFlow sequenceFlow : incomingFlows) { String sourceRefId = sequenceFlow.getSourceRef(); if (hisActivityMap.containsKey(sourceRefId) && !oldActivityId.equals(sourceRefId)) { highLightedFlows.add(sequenceFlow.getId()); this.getHighLightedFlows(flowNodeMap, hisActivityMap, sourceRefId, highLightedFlows, oldActivityId); } else {
if (hisActivityMap.containsKey(sourceRefId)){
highLightedFlows.add(sequenceFlow.getId());
}
break;
} } }
如果有什么不懂的,可以随时问我,也可以加入我们qq群633168411,里面都是flowable爱好者,不搞虚的,只讲实的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?