jbpm学习之forks-join实现撤消
采用forks-join实现撤消,现在基本实现不过还有一些值得注意的问题,这些问题应该在程序设计中解决,在这就不多说了。
实现过程,主要能过设计join结点的nOutOfM属性,将其设置为1就行,通过一个action完成,这个action与进入结点事件node-enter绑定。实现:
Join join = (Join) executionContext.getNode();//取得join子令牌,即没有处理或是执行的任务的token,这话说的有点不对,主要是我也还没弄清楚。我的理解就是取得没有结束的子令牌。Map map = executionContext.getToken().getActiveChildren();Iterator it = map.values().iterator();while(it.hasNext()) {Token token = (Token) it.next();Collection<TaskInstance> unfinishedTasks =executionContext.getTaskMgmtInstance().getUnfinishedTasks(token);for (TaskInstance unfinishedTaskInstance : unfinishedTasks) {//这里就是我说的不是单间的end,其实end中是让任务向下运行,如果还有其它的后续结点,那么一样是会出问题的,应该如下做:将当前任务结束。unfinishedTaskInstance.setOpen(false);unfinishedTaskInstance.setSignalling(false);unfinishedTaskInstance.setEnd(Clock.getCurrentTime());}}主要的代码就是这一点,仔细看看,理解了思路和话,结合自己的代码应该没有什么问题。
不过其中是有一些值得思考的问题的,如当你结束的时候,审批有可能刚好完成,也就是如何同步,我还不知道jbpm能不能解决这个问题如果不能,那就只能在程序设计时想办法了。
不好意思,我也是新手,希望对大家有帮助。
说真的,感觉是真真的高手从来都不帮我们这些新人,可能是我们的问题在过单间,只是我想说,再高的高手也是一点点学习成长起来的。好了,不发牢骚了。
1 楼 yangjun82101 2008-11-04 //只要这样就行了,先取消流转,再取任务。这样就不会转到下会的任务。
unfinishedTaskInstance.setSignalling(false);
unfinishedTaskInstance.cancel();