activiti进阶实践

1.并行网关的使用


说明:

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

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

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

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

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

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

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

2.receiveTask任务活动的使用(接收活动即等待活动))


       和userTask的区别就是userTask可以指定当前任务的办理人,并且当前任务会在正在活动的任务表中记录当前任务活动,而receiveTask任务却不会记录到当前活动的任务表中,也就是说它比userTask慢一步,用途就是:可以在任务之前处理一些业务数据之后,然后让流程向后走一步。查receiveTask一般使用执行对象(Execution)。

3.组任务的使用

组任务及三种分配方式:

1:在taskProcess.bpmn中直接写 candidate-users=“小A,小B,小C,小D"

2:在taskProcess.bpmn中写 candidate-users =“#{userIDs}”,变量的值要是String的。

使用流程变量指定办理人

      Map variables = new HashMap();

      variables.put("userIDs", "大大,小小,中中");

3,使用TaskListener接口,使用类实现该接口,在类中定义:

//添加组任务的用户

      delegateTask.addCandidateUser(userId1);

      delegateTask.addCandidateUser(userId2);

组任务分配给个人任务(认领任务):

      processEngine.getTaskService().claim(taskId, userId);

个人任务分配给组任务:

      processEngine.getTaskService(). setAssignee(taskId, null);

向组任务添加人员:

      processEngine.getTaskService().addCandidateUser(taskId, userId);

向组任务删除人员:

      processEngine.getTaskService().deleteCandidateUser(taskId, userId);

个人任务和组任务存放办理人对应的表:

act_ru_identitylink表存放任务的办理人,包括个人任务和组任务,表示正在执行的任务

act_hi_identitylink表存放任务的办理人,包括个人任务和组任务,表示历史任务

区别在于:如果是个人任务TYPE的类型表示participant(参与者)

如果是组任务TYPE的类型表示candidate(候选者)和participant(参与者)

4.activiti中内置角色人员的使用



       用上面的方法将流程部署完成之后,接下的查找任务和组任务类似,也是通过参与者,候选人等这样的方式来拾取任务,完成任务的办理。了解一下就ok,实际开发中每个系统的人员角色不可能使用activity中内置的实体建模,所以了解即可。

4.流程的挂起和激活操作




上面的操作是对流程实例的挂起和激活,同理也可以对流程定义进行挂起和激活。




你可能感兴趣的:(activiti进阶实践)