精华内容
下载资源
问答
  • activiti并行网关,驳回

    万次阅读 2016-11-28 18:03:59
    并行网关并不能实现驳回功能

    这里写图片描述
    并行网关官方并不支持实现驳回功能
    但是有方法
    思路:先将所有并行的任务-1直接走到end状态,然后留一条驳回,即可
    主要代码,将任务走到end状态

    ActivityImpl endActivity = findActivitiImpl(taskId, "end");
            commitProcess(taskId, null, endActivity.getId());
    
    /**
         * 根据任务ID和节点ID获取活动节点
         * 
         * @param taskId
         *            任务ID
         * @param activityId
         *            活动节点ID 如果为null或"",则默认查询当前活动节点 如果为"end",则查询结束节点
         * 
         * @return
         * @throws Exception
         */
        private ActivityImpl findActivitiImpl(String taskId, String activityId) throws Exception {
            // 取得流程定义
            ProcessDefinitionEntity processDefinition = findProcessDefinitionEntityByTaskId(taskId);
            // 获取当前活动节点ID
            if (activityId == null) {
                activityId = findTaskById(taskId).getTaskDefinitionKey();
            }
            // 根据流程定义,获取该流程实例的结束节点
            if (activityId.toUpperCase().equals("END")) {
                for (ActivityImpl activityImpl : processDefinition.getActivities()) {
                    List pvmTransitionList = activityImpl.getOutgoingTransitions();
                    if (pvmTransitionList.isEmpty()) {
                        return activityImpl;
                    }
                }
            }
            // 根据节点ID,获取对应的活动节点
            ActivityImpl activityImpl = ((ProcessDefinitionImpl) processDefinition).findActivity(activityId);
            return activityImpl;
        }
    /**
         * @param taskId
         *            当前任务ID
         * @param variables
         *            流程变量
         * @param activityId
         *            流程转向执行任务节点ID 此参数为空,默认为提交操作
         * @throws Exception
         */
        private void commitProcess(String taskId, Map<String, Object> variables, String activityId) throws Exception {
            if (variables == null) {
                variables = new HashMap<String, Object>();
            }
            // 跳转节点为空,默认提交操作
            if (activityId == null) {
                engine.getTaskService().complete(taskId, variables);
            } else {// 流程转向操作
                turnTransition(taskId, activityId, variables);
            }
        }
    /**
         * 流程转向操作
         * 
         * @param taskId
         *            当前任务ID
         * @param activityId
         *            目标节点任务ID
         * @param variables
         *            流程变量
         * @throws Exception
         */
        private void turnTransition(String taskId, String activityId, Map<String, Object> variables) throws Exception {
            // 当前节点
            ActivityImpl currActivity = findActivitiImpl(taskId, null);
            // 清空当前流向
            List oriPvmTransitionList = clearTransition(currActivity);
            // 创建新流向
            TransitionImpl newTransition = currActivity.createOutgoingTransition();
            // 目标节点
            ActivityImpl pointActivity = findActivitiImpl(taskId, activityId);
            // 设置新流向的目标节点
            newTransition.setDestination(pointActivity);
            // 执行转向任务
            engine.getTaskService().complete(taskId, variables);
            // 删除目标节点新流入
            pointActivity.getIncomingTransitions().remove(newTransition);
            // 还原以前流向
            restoreTransition(currActivity, oriPvmTransitionList);
        }
    展开全文
  • 流程图: 代码: package com.ytdx.parallelGateWay; import java.io.InputStream;...import org.activiti.engine.ProcessEngine; import org.activiti.engine.ProcessEngines; import org.act...

    流程图:

    代码:

    package com.ytdx.parallelGateWay;
    
    import java.io.InputStream;
    import java.util.List;
    
    import org.activiti.engine.ProcessEngine;
    import org.activiti.engine.ProcessEngines;
    import org.activiti.engine.repository.Deployment;
    import org.activiti.engine.runtime.ProcessInstance;
    import org.activiti.engine.task.Task;
    import org.junit.Test;
    
    /**
     * Activiti并行网关测试
     * @author lhy
     *
     */
    public class ParallelGateWayTest {
    
    	ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    	
    	/**
    	 * 部署流程定义(从inputStream)
    	 */
    	@Test
    	public void deploymentProcess_inputStream(){
    		InputStream inputStreamBpmn = this.getClass().getClassLoader().getResourceAsStream("parallelGateWay.bpmn");
    		InputStream inputStreamPng = this.getClass().getClassLoader().getResourceAsStream("parallelGateWay.png");
    		Deployment deployment = processEngine.getRepositoryService()                                                   //与流程定义和部署对象相关的Service
    				.createDeployment()                                                                                    //创建一个部署对象
    				.name("并行网关")                                                                                         //添加部署的名称
    				.addInputStream("parallelGateWay.bpmn", inputStreamBpmn)
    				.addInputStream("parallelGateWay.png", inputStreamPng)
    				.deploy();                                                                                             //完成部署
    		System.out.println("部署ID:"+deployment.getId());
    		System.out.println("部署名称:"+deployment.getName());
    	}
    	
    	/**
    	 * 启动流程实例
    	 */
    	@Test
    	public void startProcessInstance(){
    		String processDefinitionKey = "parallelGateWay";                                                       //流程定义的key
    		ProcessInstance pi = processEngine.getRuntimeService()                                                 //与正在执行的流程实例和执行对象相关的Service
    				.startProcessInstanceByKey(processDefinitionKey);                                              //使用流程定义的key启动流程实例,key对应parallelGateWay.bpmn文件中id的属性值,使用key值启动,默认是按照最新版本的流程定义启动
    		System.out.println("流程实例ID:"+pi.getId());                                                             //流程实例ID    101
    		System.out.println("流程定义ID:"+pi.getProcessDefinitionId());                                            //流程定义ID   helloworld:1:4
    	}
    	
    	/**
    	 * 查询当前人的个人任务
    	 */
    	@Test
    	public void findPersonalTask(){
    		String assignee = "商家";
    		List<Task> list = processEngine.getTaskService()                               //与正在执行的任务管理相关的Service
    			.createTaskQuery()                                                         //创建任务查询对象
    			/**查询条件(where部分)*/
    			.taskAssignee(assignee)                                                    //指定个人任务查询,指定办理人
    //			.taskCandidateUser(candidateUser)                                          //组任务的办理人查询
    //			.processDefinitionId(processDefinitionId)                                  //使用流程定义ID查询
    //			.processInstanceId(processInstanceId)                                      //使用流程实例ID查询
    //			.executionId(executionId)                                                  //使用执行对象ID查询
    			/**排序*/
    			.orderByTaskCreateTime().asc()                                             //使用创建时间的升序排列
    			/**返回结果集*/
    //			.singleResult()//返回惟一结果集
    //			.count()//返回结果集的数量
    //			.listPage(firstResult, maxResults);//分页查询
    			.list();                                                                   //返回列表
    		if(list !=null && list.size()>0){
    			for(Task task : list){
    				System.out.println("任务ID:"+task.getId());
    				System.out.println("任务名称:"+task.getName());
    				System.out.println("任务的创建时间:"+task.getCreateTime());
    				System.out.println("任务的办理人:"+task.getAssignee());
    				System.out.println("流程实例ID:"+task.getProcessInstanceId());
    				System.out.println("执行对象ID:"+task.getExecutionId());
    				System.out.println("流程定义ID:"+task.getProcessDefinitionId());
    				System.out.println("########################################################");
    			}
    		}
    	}
    	
    	/**
    	 * 完成我的任务
    	 */
    	@Test
    	public void completePersonalTask(){
    		String taskId = "3407";
    		processEngine.getTaskService()                                               //与正在执行的任务管理相关的Service
    					 .complete(taskId);
    		System.out.println("完成任务:任务ID:"+taskId);
    	}
    }
    

    总结:

     

    1) 一个流程中流程实例只有1个,执行对象有多个

    2) 并行网关的功能是基于进入和外出的顺序流的:

    分支(fork): 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支。

    汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网关。

    3) 并行网关的进入和外出都是使用相同节点标识

    4) 如果同一个并行网关有多个进入和多个外出顺序流, 它就同时具有分支和汇聚功能。 这时,网关会先汇聚所有进入的顺序流,然后再切分成多个并行分支。

    5) 并行网关不会解析条件。 即使顺序流中定义了条件,也会被忽略。

    并行网关不需要是“平衡的”(比如, 对应并行网关的进入和外出节点数目不一定相等)。

    展开全文
  • 1.流程图 2.部署流程定义+启动流程实例 3.查询我的个人任务 4.完成我的个人任务 ...汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网...

    1.流程图

    在这里插入图片描述

    2.部署流程定义+启动流程实例

    在这里插入图片描述

    3.查询我的个人任务

    在这里插入图片描述

    4.完成我的个人任务

    在这里插入图片描述

    分析:

    1. 一个流程中流程实例只有1个,执行对象有多个

    2. 并行网关的功能是基于进入和外出的顺序流的:

    • 分支(fork): 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支。
    • 汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网关。
    1. 并行网关的进入和外出都是使用相同节点标识

    2. 如果同一个并行网关有多个进入和多个外出顺序流, 它就同时具有分支和汇聚功能。 这时,网关会先汇聚所有进入的顺序流,然后再切分成多个并行分支。

    3. 并行网关不会解析条件。 即使顺序流中定义了条件,也会被忽略。

    4. 并行网关不需要是“平衡的”(比如, 对应并行网关的进入和外出节点数目不一定相等)。如图中标示是合法的:
      在这里插入图片描述

    展开全文
  • activiti并行网关

    2019-01-12 09:20:06
    import org.activiti.engine.ProcessEngine; import org.activiti.engine.ProcessEngines; import org.activiti.engine.TaskService; import org.activiti.engine.... * 测试并行网关 * 主要是丰富了我们的请假流程...
    import org.activiti.engine.ProcessEngine;
    import org.activiti.engine.ProcessEngines;
    import org.activiti.engine.TaskService;
    import org.activiti.engine.task.Task;
    
    /**
     *  测试并行网关
     *     主要是丰富了我们的请假流程
     */
    public class ParallelGateWayTest {
    
        //3.填写请假单的任务要执行完成
        public static void main(String[] args) {
            //1.得到ProcessEngine对象
            ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    
            //2.得到TaskService对象
            TaskService taskService = processEngine.getTaskService();
    
            //3.查询当前用户的任务
            Task task = taskService.createTaskQuery()
                    .processDefinitionKey("holidayParallel")
                    .taskAssignee("xiaowu")
                    .singleResult();
    
            //4.处理任务,结合当前用户任务列表的查询操作的话,任务ID:task.getId()
            if(task!=null){
                taskService.complete(task.getId());
                System.out.println("用户任务执行完毕...");
            }
    
    
            //5.输出任务的id
            System.out.println(task.getId());
        }
    
        //2.启动流程实例
       /*public static void main(String[] args) {
                //1.得到ProcessEngine对象
                ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    
                //2.得到RunService对象
                RuntimeService runtimeService = processEngine.getRuntimeService();
    
            Holiday holiday = new Holiday();
            holiday.setNum(5F);
            Map<String,Object> map = new HashMap<>();
            map.put("holiday",holiday);//流程变量赋值
    
                //3.创建流程实例  流程定义的key需要知道 holiday
                ProcessInstance processInstance = runtimeService.startProcessInstanceByKey("holidayParallel",map);
    
    
                //4.输出实例的相关信息
                System.out.println("流程定义ID"+processInstance.getProcessDefinitionId());//holiday:1:4
                System.out.println("流程实例ID"+processInstance.getId());//2501
        }*/
    
    
        //1.部署流程定义  带排他网关,同时还带并行网关
        /*public static void main(String[] args) {
            //1.创建ProcessEngine对象
            ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    
            //2.得到RepositoryService实例
            RepositoryService repositoryService = processEngine.getRepositoryService();
    
            //3.进行部署
            Deployment deployment = repositoryService.createDeployment()
                    .addClasspathResource("diagram/day05/holiday6.bpmn")  //添加bpmn资源
                    //.addClasspathResource("diagram/day05/holiday5.png")
                    .name("请假申请单流程")
                    .deploy();
    
            //4.输出部署的一些信息
            System.out.println(deployment.getName());
            System.out.println(deployment.getId());
        }*/
    }
    

     

    展开全文
  • 深入理解activiti并行网关

    千次阅读 2018-06-06 23:32:32
    有一段时间没有更新博文了,因为最近一直在写项目,没有太多的时间练习数据结构和算法,所以今天呢我和大家分享一下最近在项目中总结的一个比较重要的应用-activiti并行网关,如果我们经常开发的是一些管理系统,呢...
  • 1、排他网关 一个排他网关对应一个以上的顺序流,由排他网关流出的顺序流都有个conditionExpression元素,在内部维护 返回boolean类型的决策结果。决策网关只会返回一条结果。当流程执行到排他网关时,流程引擎会...
  • Activiti并行网关

    千次阅读 2017-03-14 16:42:11
     并行网关:是会有多条线路同时并行执行,当都执行完才继续执行后面的。 重新画一个流程图取名 employeeMyProcess4.bpmn: 整体业务是: 员工发起请假申请——>需要项目组长、项目经理多同意审批——>才...
  • Activiti的排他网关、并行网关

    千次阅读 2017-05-05 11:50:16
    activiti工作流中我们经常用到的网关有两种: 1. Exclusive Gateway 排他网关 排他网关.png 排他网关(也叫异或(XOR)网关,或更技术性的叫法 基于数据的排他网关), 用来在> 流程中实现决策。 当流程执行到这个...
  • 并行网关,出来的分支不需要带任何条件,每个分支都需要运行,然后汇聚到并行网关。在Activiti中,并行网关的XML代码基本格式如下 <parallelGateway id="parallelgateway1" name="Parallel Gateway"></...
  • activiti工作流中我们经常用到的网关有两种: 1. Exclusive Gateway 排他网关 排他网关.png 排他网关(也叫异或(XOR)网关,或更技术性的叫法 基于数据的排他网关), 用来在流程中实现决策。 当流程执行到这...
  • 什么是并行网关? 并行网关允许将流程分成多条分支,也可以将多条分支合并到一起,并行网关是基于进入和外出顺序流的 fork分支: 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支 jion汇聚: 所有达到并行网关,在...
  • 排他网关 并行网关
  • Activiti并行网关和串行网关区别

    千次阅读 2018-08-04 11:35:22
    Activiti多实例任务有并行、串行区分。 并行代表同时进行,如把任务分给5个人来处理,这5个人同时会收到任务,并且可以同时处理,不受各自的影响。 串行代表工作或任务由一个人完成后,再由另一个人去处理,直至...
  • activiti6.0之并行网关

    2021-03-24 14:28:23
    绘制流程图: 具体的xml代码如下: ...definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:activiti="http://activiti.org/bpmn" xmlns:bpmndi="http://www.omg.org/spec/BPMN/2...
  • Activiti并行网关 所谓排他网关 顾名思义 执行到该网关,会有多条线路同时并行执行,当都执行完才继续执行后面的; ...
  • activiti实战系列 并行网关(parallelGateWay)

    万次阅读 多人点赞 2016-04-16 08:43:09
    流程图 13.2:部署流程定义+启动流程实例 13.3:查询我的个人任务 ...2) 并行网关的功能是基于进入和外出的顺序流的: ...分支(fork): 并行后的...汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所...
  • activiti并行网关(Parallel Gateway)

    千次阅读 2018-05-05 13:19:01
    1.什么是并行网关?它可以将分支(fork)为多个路径,也可以合并(join)多个入口路径。2.使用场景:场景一:在一个政府机关的办公OA系统设计的时候,有这么一个需求:政府需要做一个财务呈批的业务,由财务部门发起...
  • activiti 并行网关中强制结束任务

    千次阅读 2020-05-31 23:05:18
    并行网关中如果强制结束任务可使用终结任务,结束任务对并行网关是不起作用的,并不会真正的结束流程 如上面 两个并行节点只要有一个人驳回就结束流程 这时就可以使用终结任务 在网关设置走不同意的线就结束...
  • activiti 入门】activiti6.0之并行网关

    千次阅读 2019-09-24 11:02:27
    首先是环境搭建可参考之前的博客,而且有具体demo提供下载...demo中仅涵盖了排他网关的实例。 接下来准备绘制流程图: 具体的xml代码如下: <?xml version="1.0" encoding="UTF-8" standalone="yes"?...
  • 上次讲了排他网关的做法,今天来说说并行网关的做法 并行网关 并行网关是指流程中需要并行执行的部分,他允许流程从一个流程分出多个分支,也可以把多个流程合并成一个。 就像上面说到的,并行网关有两个功能,...
  • Activiti 并行网关实现撤回功能

    千次阅读 2019-04-26 23:35:11
    最近在工作中遇到一个Activiti 工作流的撤回功能,不是驳回,驳回可以直接由当前任务操作人员完成,但是撤回不一样,撤回是上一个任务人员操作的,并且把当前任务结束掉,活动任务回到上一个任务上面去,以下是自己...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 984
精华内容 393
关键字:

activiti条件并行网关