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<String, Object> variables = new HashMap<String, Object>();
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.流程的挂起和激活操作
上面的操作是对流程实例的挂起和激活,同理也可以对流程定义进行挂起和激活。