码迷,mamicode.com
首页 > 编程语言 > 详细

activiti6+springboot2 的第三个简单demo 动态设置任务节点处理人(多人并行 无序)

时间:2019-11-20 16:55:55      阅读:379      评论:0      收藏:0      [点我收藏+]

标签:hashmap   ice   变量   mic   arraylist   addclass   res   public   启动流程   

技术图片

 

 

 

 

技术图片

 

 

 ${nrOfCompletedInstances/nrOfInstances==1}   ==1表示所有任务实力完成才可以进入下一个节点;  ==0.75 表示 3/4的完成可进入下一节点;以此类推

 

 

 

    @RequestMapping("multi_assignee")
    public void setMultiAssignee() {
        //根据bpmn文件部署流程
        repositoryService.createDeployment().addClasspathResource("processes/multi_assignee.bpmn").deploy();
        // 设置多个处理人变量 这里设置了三个人
        Map<String, Object> variables = new HashMap<>();
        List<String> userList = new ArrayList<>();
        userList.add("user1");
        userList.add("user2");
        userList.add("user3");
        variables.put("userList", userList);
        //采用key来启动流程定义并设置流程变量,返回流程实例
        ProcessInstance pi = runtimeService.startProcessInstanceByKey("multi_assignee", variables);
        String processId = pi.getId();
        System.out.println("流程创建成功,当前流程实例ID:"+processId);
        // 查看user1的任务
        List<Task> list = taskService.createTaskQuery().taskAssignee("user1").list();
        if(list!=null && list.size()>0){
            for(org.activiti.engine.task.Task task:list){
                System.out.println("任务ID:"+task.getId());
                System.out.println("任务的办理人:"+task.getAssignee());
                System.out.println("任务名称:"+task.getName());
                System.out.println("任务的创建时间:"+task.getCreateTime());
                System.out.println("流程实例ID:"+task.getProcessInstanceId());
                System.out.println("#######################################");
            }
        }
        // 查看user2的任务
        List<Task> list2 = taskService.createTaskQuery().taskAssignee("user2").list();
        if(list2!=null && list2.size()>0){
            for(org.activiti.engine.task.Task task:list2){
                System.out.println("任务ID:"+task.getId());
                System.out.println("任务的办理人:"+task.getAssignee());
                System.out.println("任务名称:"+task.getName());
                System.out.println("任务的创建时间:"+task.getCreateTime());
                System.out.println("流程实例ID:"+task.getProcessInstanceId());
                System.out.println("#######################################");
            }
        }
        // 查看user3的任务
        List<Task> list3 = taskService.createTaskQuery().taskAssignee("user3").list();
        if(list3!=null && list3.size()>0){
            for(org.activiti.engine.task.Task task:list3){
                System.out.println("任务ID:"+task.getId());
                System.out.println("任务的办理人:"+task.getAssignee());
                System.out.println("任务名称:"+task.getName());
                System.out.println("任务的创建时间:"+task.getCreateTime());
                System.out.println("流程实例ID:"+task.getProcessInstanceId());
                System.out.println("#######################################");
            }
        }
    }

 

activiti6+springboot2 的第三个简单demo 动态设置任务节点处理人(多人并行 无序)

标签:hashmap   ice   变量   mic   arraylist   addclass   res   public   启动流程   

原文地址:https://www.cnblogs.com/woshuaile/p/11898576.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!