Activiti工作流(五)连线,排他网关,并行网关,等待活动

流程图

如图绘制流程图 

连线属性设置

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

 

@Test
	public void TestSequenceFlow(){
		//获取流程引擎
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		Deployment deployment = processEngine.getRepositoryService()
							.createDeployment()
							.name("连线流程")
							.addClasspathResource("diagrams/SequenceProcess.bpmn")
							.addClasspathResource("diagrams/SequenceProcess.png")
							.deploy();
		System.out.println("部署流程:"+deployment.getId()+"||"+deployment.getName());
		ProcessInstance processInstance = processEngine.getRuntimeService().
				startProcessInstanceByKey("sequenceProcessID");
		System.out.println("流程实例ID为:"+processInstance.getId());
	}

查询个人任务

@Test
	public void queryTask(){
		//获取流程引擎
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		List<Task> list = processEngine.getTaskService()
						.createTaskQuery()
						.taskAssignee("张三")
						.list();
		for (Task task : list) {
			System.out.println(task.getId());	
			System.out.println(task.getName());
			System.out.println(task.getExecutionId());
			System.out.println(task.getProcessDefinitionId());
			System.out.println(task.getProcessInstanceId());
		}
	}

 

完成任务

@Test
	public void completeTask(){
		String taskId = "62503";
		//获取流程引擎
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		Map<String, Object> variables = new HashMap<>();
		variables.put("message", "重要");
		processEngine.getTaskService()
					.complete(taskId, variables);
		System.out.println("任务完成");

 

说明:

1)使用流程变量,设置连线需要的流程变量的名称message,并设置流程变量的值

对应:

扫描二维码关注公众号,回复: 4943771 查看本文章

流程会按照指定的连线完成任务。

总结

1、一个活动中可以指定一个或多个SequenceFlow(Start中有一个,End中没有)。

  * 开始活动中有一个SequenceFlow 。

  * 结束活动中没有SequenceFlow 。

  * 其他活动中有1条或多条SequenceFlow

2、如果只有一个,则可以不使用流程变量设置codition的名称;

如果有多个,则需要使用流程变量设置codition的名称。message表示流程变量的名称,‘不重要’表示流程变量的值,${}中间的内容要使用boolean类型的表达式,用来判断应该执行的连线。

排他网关(ExclusiveGateWay)

@Test
	public void TestExclusiveGateWay(){
		//获取流程引擎
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		Deployment deployment = processEngine.getRepositoryService()
							.createDeployment()
							.name("排他网关流程")
							.addClasspathResource("diagrams/ExclusiveGateWayProcess.bpmn")
							.addClasspathResource("diagrams/ExclusiveGateWayProcess.png")
							.deploy();
		System.out.println("部署流程:"+deployment.getId()+"||"+deployment.getName());
		ProcessInstance processInstance = processEngine.getRuntimeService().
				startProcessInstanceByKey("ExclusiveGateWayProcessID");
		System.out.println("流程实例ID为:"+processInstance.getId());
	}
@Test
	public void completeTask(){
		String taskId = "85004";
		//获取流程引擎
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		Map<String, Object> variables = new HashMap<>();
		variables.put("money", 1000);
		processEngine.getTaskService()
					.complete(taskId, variables);
		System.out.println("任务完成");
	}
  1. 一个排他网关对应一个以上的顺序流
  2. 由排他网关流出的顺序流都有个conditionExpression元素,在内部维护返回boolean类型的决策结果。
  3. 决策网关只会返回一条结果。当流程执行到排他网关时,流程引擎会自动检索网关出口,从上到下检索如果发现第一条决策结果为true或者没有设置条件的(默认为成立),则流出。
  4. 如果没有任何一个出口符合条件,则抛出异常
  5. 使用流程变量,设置连线的条件,并按照连线的条件执行工作流,如果没有条件符合的条件,则以默认的连线离开。

并行网关(parallelGateWay)

/*
	 * 部署
	 */
	@Test
	public void deploy(){
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		Deployment deployment = processEngine.getRepositoryService()
						.createDeployment()
						.name("并行网关")
						.addClasspathResource("diagrams/parallelGateWay.bpmn")
						.addClasspathResource("diagrams/parallelGateWay.png")
						.deploy();
		System.out.println("部署ID:"+deployment.getId());
		System.out.println("部署NAME:"+deployment.getName());
	}
/*
	 * 启动流程
	 */
	@Test
	public void startProcess(){
		String processDefinitionKey="parallelGateWayID";
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		ProcessInstance instance = processEngine.getRuntimeService()
								.startProcessInstanceByKey(processDefinitionKey);
		System.out.println("流程实例ID:"+instance.getId());
		System.out.println("流程定义ID:"+instance.getProcessDefinitionId());
	}
/*
	 * 完成任务
	 */
	@Test
	public void completeTask(){
		String taskID="110002";
		ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
		processEngine.getTaskService().complete(taskID);
		System.out.println("完成任务任务ID为:"+taskID);
	}
  • 一个流程中流程实例只有1个,执行对象有多个
  • 并行网关的功能是基于进入和外出的顺序流的:

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

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

  • 并行网关的进入和外出都是使用相同节点标识
  • 如果同一个并行网关有多个进入和多个外出顺序流, 它就同时具有分支和汇聚功能。 这时,网关会先汇聚所有进入的顺序流,然后再切分成多个并行分支。
  • 并行网关不会解析条件。 即使顺序流中定义了条件,也会被忽略。
  • 并行网关不需要是“平衡的”(比如, 对应并行网关的进入和外出节点数目不一定相等)。如图中标示是合法的:

开始活动节点

流程图

部署流程定义+启动流程实例+查询流程实例+查询历史流程实例

总结

1):结束节点没有出口

2):其他节点有一个或多个出口。

如果有一个出口,则代表是一个单线流程;

如果有多个出口,则代表是开启并发流程。

接收活动(receiveTask,即等待活动)

接收任务是一个简单任务,它会等待对应消息的到达。 当前,官方只实现了这个任务的java语义。 当流程达到接收任务,流程状态会保存到数据库中。

在任务创建后,意味着流程会进入等待状态, 直到引擎接收了一个特定的消息, 这会触发流程穿过接收任务继续执行。

流程图

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

/**

     * ReceiceTask任务,机器自动完成的任务

     * 只会在act_ru_execution表中产生一条数据

     * @throws Exception

     */

   

    @Test

    public void testExecution() throws Exception {

        // 1 发布流程

        InputStream inputStreamBpmn = this.getClass().getResourceAsStream("receiveTask.bpmn");

        InputStream inputStreamPng = this.getClass().getResourceAsStream("receiveTask.png");

        processEngine.getRepositoryService()//

                       .createDeployment()//

                       .addInputStream("receiveTask.bpmn", inputStreamBpmn)//

                       .addInputStream("receiveTask.png", inputStreamPng)//

                       .deploy();

       

        // 2 启动流程

        ProcessInstance pi = processEngine.getRuntimeService()//

                           .startProcessInstanceByKey("receiveTaskDemo");

        System.out.println("pid:" + pi.getId());

        String pid = pi.getId();

       

        // 3查询是否有一个执行对象在描述”汇总当日销售额“

        Execution e1 = processEngine.getRuntimeService()//

                       .createExecutionQuery()//

                       .processInstanceId(pid)//

                       .activityId("汇总当日销售额")//

                       .singleResult();

        // 4执行一堆逻辑,并设置流程变量

        Map<String,Object> vars = new HashMap<String, Object>();

        vars.put("当日销售额", 10000);

        //  5流程向后执行一步:往后推移e1,使用signal给流程引擎信号,告诉他当前任务已经完成了,可以往后执行

        processEngine.getRuntimeService()

               .signal(e1.getId(),vars);

       

        // 6判断当前流程是否在”给老板发短信“节点

        Execution e2 = processEngine.getRuntimeService()//

                       .createExecutionQuery()//

                       .processInstanceId(pid)//

                       .activityId("给总经理发短信")//

                       .singleResult();

       

        // 7获取流程变量

        Integer money = (Integer) processEngine.getRuntimeService()//

                               .getVariable(e2.getId(), "当日销售额");

        System.out.println("老板,今天赚了" +money);

        // 8向后执行一步:任务完成,往后推移”给老板发短信“任务

        processEngine.getRuntimeService()//

               .signal(e2.getId());

       

       

        // 9查询流程状态

        pi = processEngine.getRuntimeService()//

                    .createProcessInstanceQuery()//

                    .processInstanceId(pid)//

                    .singleResult();

        if(pi==null){

             System.out.println("流程正常执行!!!,已经结束了");

        }

    }

说明:

当前任务(一般指机器自动完成,但需要耗费一定时间的工作)完成后,向后推移流程,可以调用runtimeService.signal(executionId),传递接收执行对象的id。

猜你喜欢

转载自blog.csdn.net/baiyan3212/article/details/86089714
今日推荐