activiti--多实例任务实现会签
cookqq ›博客列表 ›activiti

activiti--多实例任务实现会签

2013-06-21 17:53:21.0|分类: activiti|浏览量: 3113

摘要: 本人博客开始迁移,博客整个架构自己搭建及编码 ...

本人博客开始迁移,博客整个架构自己搭建及编码 http://www.cookqq.com/listBlog.action 

Activiti中提供了多实例任务(for-each)将多实例应到到UserTask中可以实现会签功能。

Multi-instance (for each) 
Description 
A multi-instance activity is a way of defining repetition for a certain step in a business process. In programming concepts, a multi-instance matches the for each construct: it allows to execute a certain step or even a complete subprocess for each item in a given collection, sequentially or in parallel. 

A multi-instance is a regular activity that has extra properties defined (so-called 'multi-instance characteristics'') which will cause the activity to be executed multiple times at runtime. Following activities can become a multi-instance activity:


一.多实例用户任务的XML表示:

<userTask id="task" name="多实例任务">
		<multiInstanceLoopCharacteristics isSequential="false">
       		<loopDataInputRef>assigneeList</loopDataInputRef>
        	<inputDataItem name="assignee"></inputDataItem>
        	<!-- userIdList[user1,user2,user3]  -->
      		<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 0.6}</completionCondition>
      	</multiInstanceLoopCharacteristics>
</userTask>

在每个多实例创建后都会有3个变量,请看数据库中act_ru_variable表的截图:

nrOfInstances 实例总数

nrOfActiveInstances 当前还没有完成的实例

nrOfCompletedInstances 已经完成的实例个数

 multiInstanceLoopCharacteristics 是用了指定用户任务为多实例任务,isSequential 指定多实例是按照并行或者串行的方式进行,如果使用串行方式nrOfActiveInstances 变量始终是1 。isSequential串行并行是针对于assigneeList中的用户集合来说的,如果是并行assigneeList集合中的每个用户按照顺序执行。

变量assigneeList,我们可以在执行这个任务之前进行赋值:

Map<String, Object> variables =new HashMap<String, Object>();
		variables.put("pass", Boolean.parseBoolean(pass));
		List<String> assigneeList = Arrays.asList("10001#1001","10001#1002","10001#1003"); 
		variables.put("assigneeList", assigneeList);
		TaskService taskService = ActivitiUtils.getTaskService();
		taskService.complete(taskId, variables);


 loopDataInputRef 指定一个流程变量的引用,该变量是一个List,可以在发起或这执行任务之前作为流程变量放到引擎中,该list中的每一个元素将创建一个任务。元素的值通过 inputDataItem 元素的指定的变量来获取,如 在这个实例中ist<String> assigneeList = Arrays.asList("10001#1001","10001#1002","10001#1003");  这会创建3个用户任务,每个用户任务中都有一个 assignee 的变量,来分别得到list中的值。但是需要注意:选择isSequential串行时一个任务完成后创建另一个任务,并不是一次性创建3个任务。

assigneeList 的值程序序列化后保存到act_ge_bytearray表中,请看图:


 completionCondition 结束任务的条件,该示例中是任务完成 60% 结束。


在第一步中我们知道变量 assignee 是 会签人员的标识,只需要将指定代理人的地方用表达式来指定 assignee 变量就行了。  完整XML:

<userTask id="thisTask2" name="myTask2">
		<humanPerformer>
	      	<resourceAssignmentExpression>
	      		<formalExpression>${assignee}</formalExpression>
	      	</resourceAssignmentExpression>
	    </humanPerformer>
		<multiInstanceLoopCharacteristics isSequential="false">
       		<loopDataInputRef>assigneeList</loopDataInputRef>
        	<inputDataItem name="assignee"></inputDataItem>
        	<!-- userIdList[user1,user2,user3]  -->
     	<completionCondition>${nrOfCompletedInstances/nrOfInstances >= 0.6}</completionCondition>
      	</multiInstanceLoopCharacteristics>
</userTask><span style="white-space: pre;">	</span>

这里附上图:



参考:http://cooperay.iteye.com/blog/1461385

多实例实现的会签有办法实现撤回吗 多实例怎么实现指定候选人

引用来自“wdwnet”的评论

多实例怎么实现指定候选人
就是通过传递Map作为变量传入

引用来自“xueyingbing”的评论

多实例实现的会签有办法实现撤回吗
可以,但是确实有挺多麻烦事,现在我做的就是会签节点不允许退回与回收。

一键分享文章

分类列表

  • • struts源码分析
  • • flink
  • • struts
  • • redis
  • • kafka
  • • ubuntu
  • • zookeeper
  • • hadoop
  • • activiti
  • • linux
  • • 成长
  • • NIO
  • • 关键词提取
  • • mysql
  • • android studio
  • • zabbix
  • • 云计算
  • • mahout
  • • jmeter
  • • hive
  • • ActiveMQ
  • • lucene
  • • MongoDB
  • • netty
  • • flume
  • • 我遇到的问题
  • • GRUB
  • • nginx
  • • 大家好的文章
  • • android
  • • tomcat
  • • Python
  • • luke
  • • android源码编译
  • • 安全
  • • MPAndroidChart
  • • swing
  • • POI
  • • powerdesigner
  • • jquery
  • • html
  • • java
  • • eclipse
  • • shell
  • • jvm
  • • highcharts
  • • 设计模式
  • • 列式数据库
  • • spring cloud
  • • docker+node.js+zookeeper构建微服务
版权所有 cookqq 感谢访问 支持开源 京ICP备15030920号
CopyRight 2015-2018 cookqq.com All Right Reserved.