如图绘制流程图
连线属性设置
@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 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 variables = new HashMap<>();
variables.put("message", "重要");
processEngine.getTaskService()
.complete(taskId, variables);
System.out.println("任务完成");
说明:
1)使用流程变量,设置连线需要的流程变量的名称message,并设置流程变量的值
对应:
流程会按照指定的连线完成任务。
1、一个活动中可以指定一个或多个SequenceFlow(Start中有一个,End中没有)。
* 开始活动中有一个SequenceFlow 。
* 结束活动中没有SequenceFlow 。
* 其他活动中有1条或多条SequenceFlow
2、如果只有一个,则可以不使用流程变量设置codition的名称;
如果有多个,则需要使用流程变量设置codition的名称。message表示流程变量的名称,‘不重要’表示流程变量的值,${}中间的内容要使用boolean类型的表达式,用来判断应该执行的连线。
@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 variables = new HashMap<>();
variables.put("money", 1000);
processEngine.getTaskService()
.complete(taskId, variables);
System.out.println("任务完成");
}
/*
* 部署
*/
@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);
}
分支(fork): 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支。
汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网关。
流程图
部署流程定义+启动流程实例+查询流程实例+查询历史流程实例
总结
1):结束节点没有出口
2):其他节点有一个或多个出口。
如果有一个出口,则代表是一个单线流程;
如果有多个出口,则代表是开启并发流程。
接收任务是一个简单任务,它会等待对应消息的到达。 当前,官方只实现了这个任务的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 vars = new HashMap();
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。