`
subject
  • 浏览: 40345 次
  • 性别: Icon_minigender_1
  • 来自: 墨尔本
社区版块
存档分类
最新评论

activiti获取下一个节点信息

阅读更多
  在实际的工作流业务开发中, 当用户完成当前用户任务时, 需要指定下一个用户任务的审核人。此时我们需要获取下一个节点的一些信息, 来确定下一个用户任务的审核人有哪些。
     
      在实际工作流程中, 当前用户任务后的节点可能为用户任务, 也可能为网关。如果下一个节点为网关我们需要判断流程线路。
/** 
     * 获取下一个用户任务用户组信息  
     * @param String taskId     任务Id信息  
     * @return  下一个用户任务用户组信息  
     * @throws Exception 
     */  
    public Set<Expression> getNextTaskGroup(String taskId) throws Exception {  
          
        ProcessDefinitionEntity processDefinitionEntity = null;  
          
        String id = null;  
          
        TaskDefinition task = null;  
          
        //获取流程实例Id信息   
        String processInstanceId = taskService.createTaskQuery().taskId(taskId).singleResult().getProcessInstanceId();  
          
        //获取流程发布Id信息   
        String definitionId = runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).singleResult().getProcessDefinitionId();  
          
        processDefinitionEntity = (ProcessDefinitionEntity) ((RepositoryServiceImpl) repositoryService)  
                .getDeployedProcessDefinition(definitionId);  
          
        ExecutionEntity execution = (ExecutionEntity) runtimeService.createProcessInstanceQuery().processInstanceId(processInstanceId).singleResult();  
          
        //当前流程节点Id信息   
        String activitiId = execution.getActivityId();    
          
        //获取流程所有节点信息   
        List<ActivityImpl> activitiList = processDefinitionEntity.getActivities();   
          
        //遍历所有节点信息   
        for(ActivityImpl activityImpl : activitiList){      
            id = activityImpl.getId();     
              
            // 找到当前节点信息  
            if (activitiId.equals(id)) {  
                  
                //获取下一个节点信息   
                task = nextTaskDefinition(activityImpl, activityImpl.getId(), null, processInstanceId);  
  
                break;  
            }  
        }  
          
        return task.getCandidateGroupIdExpressions();  
    }  
      
    /**  
     * 下一个任务节点信息,  
     *  
     * 如果下一个节点为用户任务则直接返回,  
     *  
     * 如果下一个节点为排他网关, 获取排他网关Id信息, 根据排他网关Id信息和execution获取流程实例排他网关Id为key的变量值,  
     * 根据变量值分别执行排他网关后线路中的el表达式, 并找到el表达式通过的线路后的用户任务信息  
     * @param ActivityImpl activityImpl     流程节点信息  
     * @param String activityId             当前流程节点Id信息  
     * @param String elString               排他网关顺序流线段判断条件, 例如排他网关顺序留线段判断条件为${money>1000}, 若满足流程启动时设置variables中的money>1000, 则流程流向该顺序流信息  
     * @param String processInstanceId      流程实例Id信息  
     * @return  
     */    
    private TaskDefinition nextTaskDefinition(ActivityImpl activityImpl, String activityId, String elString, String processInstanceId){   
              
        PvmActivity ac = null;  
          
        Object s = null;  
          
        //如果遍历节点为用户任务并且节点不是当前节点信息   
            if("userTask".equals(activityImpl.getProperty("type")) && !activityId.equals(activityImpl.getId())){    
                //获取该节点下一个节点信息   
                TaskDefinition taskDefinition = ((UserTaskActivityBehavior)activityImpl.getActivityBehavior()).getTaskDefinition();    
                return taskDefinition;    
            }else{    
                //获取节点所有流向线路信息   
                List<PvmTransition> outTransitions = activityImpl.getOutgoingTransitions();    
                List<PvmTransition> outTransitionsTemp = null;    
                for(PvmTransition tr : outTransitions){      
                    ac = tr.getDestination(); //获取线路的终点节点      
                    //如果流向线路为排他网关   
                    if("exclusiveGateway".equals(ac.getProperty("type"))){    
                        outTransitionsTemp = ac.getOutgoingTransitions();  
                          
                        //如果网关路线判断条件为空信息   
                        if(StrUtils.isEmpty(elString)) {  
                            //获取流程启动时设置的网关判断条件信息   
                            elString = getGatewayCondition(ac.getId(), processInstanceId);  
                        }  
                          
                        //如果排他网关只有一条线路信息   
                        if(outTransitionsTemp.size() == 1){    
                            return nextTaskDefinition((ActivityImpl)outTransitionsTemp.get(0).getDestination(), activityId, elString, processInstanceId);    
                        }else if(outTransitionsTemp.size() > 1){  //如果排他网关有多条线路信息   
                            for(PvmTransition tr1 : outTransitionsTemp){    
                                s = tr1.getProperty("conditionText");  //获取排他网关线路判断条件信息   
                                //判断el表达式是否成立   
                                if(isCondition(ac.getId(), StrUtils.trim(s.toString()), elString)){    
                                    return nextTaskDefinition((ActivityImpl)tr1.getDestination(), activityId, elString, processInstanceId);    
                                }    
                            }    
                        }    
                    }else if("userTask".equals(ac.getProperty("type"))){    
                        return ((UserTaskActivityBehavior)((ActivityImpl)ac).getActivityBehavior()).getTaskDefinition();    
                    }else{    
                    }    
                }     
            return null;    
        }    
    }  
      
    /** 
     * 查询流程启动时设置排他网关判断条件信息  
     * @param String gatewayId          排他网关Id信息, 流程启动时设置网关路线判断条件key为网关Id信息  
     * @param String processInstanceId  流程实例Id信息  
     * @return 
     */  
    public String getGatewayCondition(String gatewayId, String processInstanceId) {  
        Execution execution = runtimeService.createExecutionQuery().processInstanceId(processInstanceId).singleResult();  
        return runtimeService.getVariable(execution.getId(), gatewayId).toString();  
    }  
      
    /** 
     * 根据key和value判断el表达式是否通过信息  
     * @param String key    el表达式key信息  
     * @param String el     el表达式信息  
     * @param String value  el表达式传入值信息  
     * @return 
     */  
    public boolean isCondition(String key, String el, String value) {  
        ExpressionFactory factory = new ExpressionFactoryImpl();    
        SimpleContext context = new SimpleContext();    
        context.setVariable(key, factory.createValueExpression(value, String.class));    
        ValueExpression e = factory.createValueExpression(context, el, boolean.class);    
        return (Boolean) e.getValue(context);  
    }  
分享到:
评论

相关推荐

    ACTIVITI如何获取下一步节点

    获取下一步节点是ACTIVITI中进行流程控制的关键操作之一,这对于流程的执行和监控至关重要。 首先,我们要明白在ACTIVITI中,流程实例是由一系列活动(Activity)组成的,这些活动可以是任务(Task)、网关...

    Activiti12流程跟踪任务节点和线高亮显示

    Activiti流程跟踪任务节点和线高亮显示 Activiti是Activiti BPMN 2.0流程引擎的Java实现,提供了强大的流程管理和自动化功能。在Activiti中,我们可以通过流程跟踪功能来追踪和监控流程的执行情况。流程跟踪任务...

    Activiti 学习笔记十:开始活动节点(判断流程是否结束及查询历史)

    Activiti 是一个开源的工作流引擎,它被广泛用于企业级应用中来管理业务流程。本学习笔记主要聚焦在开始活动节点以及如何判断流程是否结束,同时涵盖了查询历史流程实例的相关内容。 一、开始活动节点(Start Event...

    Activity 工作流节点新增节点和获取节点属性修改底层文件

    在这个场景中,“新增节点”可能指的是在应用程序的工作流程中添加新的Activity,而“获取节点属性”则涉及到读取或修改已存在的Activity的状态或配置信息。 首先,让我们深入理解Activity的工作流。Activity的工作...

    activiti5.22 实现撤回操作

    在企业级应用开发中,流程引擎 Activiti 是一个非常重要的工具,它可以帮助开发者轻松地管理和自动化业务流程。本文将深入探讨如何在 Activiti 5.22 版本中实现撤回操作,确保这一功能的实现不影响流程设计,并且...

    activiti 5.22 退回代码

    工作流 activiti 5.22 退回代码实现。 activiti在设计的时候没有回退相关的...这里写一个比较简单的回退。不支持回退到并行网关前面节点,虽然回退到前面节点不会报错 但会导致任务无法结束。使用没有并行网关的回退。

    Activiti5实现任务撤回,任意跳转(代码+注释 spring-activiti-withdraw.zip)

    2、获取节点的所有流出流向,把流向保存到临时变量oldPvmTransitionList 3、清空流向,即删除流向 4、新增流向,将流向的Destination设置成跳转节点 5、领取任务,完成任务 6、删除当前节点的流向,将流向还原成临时...

    使用activiti工作流引擎显示流程图时高亮显示流程图中已执行节点和已执行路径方法源代码

    接下来,我们需要解析流程图的 XML 文件(*.bpmn20.xml),从中获取节点和连接线的信息。这可以通过 Activiti 的 BpmnModel 类来完成。BpmnModel 对象包含了流程图的所有元素,我们可以根据历史数据找到对应的节点和...

    Activiti5学习-在流程图中为带条件的顺序流添加提示信息

    为了在用户界面中显示这些提示信息,我们需要开发一个定制的Activiti模型查看器或者利用现有的工具如Activiti Modeler进行扩展。在查看流程图时,当鼠标悬停在条件顺序流上时,可以弹出一个提示框,显示对应的`...

    activiti取会签人员

    在用activiti的时候经常遇到取会签人员的问题,这个文档解决怎么获取会签人员。

    oa-activity.zip

    Activiti 是一个开源的工作流和业务自动化引擎,广泛应用于企业级应用中,提供流程定义、执行、监控等功能。本示例"oa-activity.zip"是一个基于Activiti6的OA(Office Automation)活动演示,用于展示如何使用...

    Activiti-5.4中实现会签

    在企业级应用中,流程管理是一个关键的环节,而Activiti是一个开源的工作流和业务流程管理系统,它提供了强大的流程建模、执行和监控能力。在 Activiti-5.4 版本中,会签(Concurrent Signatures)是流程设计中的一...

    activiti流程图查看demo

    Activiti 是一个开源的工作流和业务自动化引擎,它支持企业级的业务流程管理(BPM)系统和模型驱动的应用程序。这个"activiti流程图查看demo"是一个示例项目,旨在帮助用户理解如何在Activiti中查看和操作流程图。在...

    Activiti数据库表单设计

    我花了半天时间把网上零散的资源整理成了一张excel表单,activiti 24张表及其每个字段都做了比较详细的介绍,看上去一目了然

    activiti6.0实现流程图片自定义颜色 当前任务为红色,走过的任务为绿色,自定义文字颜色连线文字显示

    在IT行业中,Activiti是一个非常流行的开源工作流引擎,它被广泛用于企业级应用中来管理业务流程。本文将深入探讨如何在Activiti 6.0版本中实现流程图片的自定义颜色功能,以增强流程图的可读性和美观性。 首先,...

    activiti-explorer.rar_Activiti Explorer_Explorer_activiti_activi

    activiti 5.22 explorer的war包

    Activiti流程图部署及流程图部分操作.pdf

    Activiti 是一个开源的工作流和业务自动化引擎,它支持企业级的业务流程管理(BPM)和业务规则管理(BRM)。在这个主题中,我们主要关注如何在Activiti中进行流程图的部署以及如何操作流程图。 流程图的部署是...

    activiti工作流高亮图配置.zip

    可以使用Activiti提供的Rest API获取流程实例的详细信息,然后在前端页面上动态更新流程图的高亮状态。使用JavaScript库如jQuery或Vue.js可以方便地操作DOM元素,实现节点的高亮。 5. **后端处理**:后端需要处理...

    Activiti 学习笔记九:并行网关(parallelGateWay)

    并行网关(Parallel Gateway)在 Activiti 流程引擎中扮演着重要的角色,它是流程设计中的一个关键组件,用于实现分支和合并的功能。在本篇学习笔记中,我们将深入探讨并行网关的工作原理、使用场景以及如何在 ...

Global site tag (gtag.js) - Google Analytics