BPMN 2.0 constructs
BPMN 2.0 构件
自定义扩展
The BPMN 2.0 standard is a good thing for all parties involved. End-users don't suffer from a vendor lock-in that comes by depending on a proprietary solution. Frameworks, and particularly open-source frameworks such as Activiti, can implement a solution that has the same (and often better implemented) features as those of a big vendor. Due to the BPMN 2.0 standard, the transition from such a big vendor solution towards Activiti is an easy and smooth path.
BPMN2.0标准对于每一个参与方都是一个很好的标准。最终用户也不需要绑定某个厂商的私有解决方案。一个框架,特别是开源框架,如Activiti,可以实现同样(通常会更好)和那些大厂商所提供功能。基于BPMN2.0标准,你可以非常容易而且可以平滑的由大厂商所提供的解决方案迁移到Activiti。
The downside of a standard however, is the fact that it is always the result of many discussions and compromises between different companies (and often visions). As a developer reading the BPMN 2.0 XML of a process definition, sometimes it feels like certain constructs or way to do things are too cumbersome. Since Activiti puts ease of development as a top-priority, we introduced something called the'Activiti BPMN extensions'. These 'extensions' are new constructs or ways to simplify certain constructs, that are not in the BPMN 2.0 specification.
对于标准来说不利的一面那就是,标准通常是厂商之间协商和折中的一种方案(通常是对标准的愿景)。作为一个开发人员阅读BPMN2.0流程定义XML时,经常发现某些构件或做事的方式是很笨重的。因此,Activit把易于开发作为最高优先级,接下来我们会介绍一些被称之为'Activiti BPMN extensions'的东东。这些扩展构件在BPMN2.0标准中是不存在的,它们有些是新的构件,有些是对既有构件的简化。
Although the BPMN 2.0 specification clearly states that it was made for custom extension, we make sure that:
尽管BPMN2.0标准明确的表示可以进行自定义扩展,但是我们还是确保:
So whether you want to use a custom extension or not, is completely up to you. Several factors will influence this decision (graphical editor usage, company policy, etc.). We only provide them since we believe that some points in the standard can be done simpler or more efficient. Feel free to give us (positive and/or negative) feedback on our extensions, or to post new ideas for custom extensions. Who knows, some day your idea might pop up in the specification!.
使用或者不使用自定义扩展,都完全取决于你。许多因素都会影响你的决定(图形编辑器的用法,公司策略等)。我们只是提供这些自定义扩展,因为我们相信标准在某些方面可以做的更简单一点,更有效率一点。你可以将你使用我们自定义的扩展感受(好的方面/不好的方面)告诉我们,也可以将你的在自定义扩展方面的好的点子告诉我们。谁知道,或许某一天你的点子就会加入到标准中。
事件(Event)
Events are used to model something that happens during the lifetime process. Events are always visualized as a circle. In BPMN 2.0, there exist two main event categories: catching or throwing event.
事件(Event)用来为发生在流程生命周期某些东东进行建模。事件(Event)常常使用圆来表示。在BPMN2.0中存在两类主要事件:catching事件和throwing事件。
启动事件
A start event indicates where a process starts. The type of start event (process starts on arrival of message, on specific time intervals, etc.), defining how the process is started is shown as a small icon in the visual representation of the event. In the XML representation, the type is given by the declaration of a sub-element.
一个启动事件表示一个流程的起始点。启动事件的类型(当一个消息到达后启动、在特定时间间隔启动等)定义了流程如何启动,在可视化表示中使用小图标进行区分,在XML表示中使用子元素进行区分。
Start events are always catching: conceptually the event is (at any time) waiting until a certain trigger happens.
启动事件就是catching事件:因为事件(总是)等待一个特定的触发器发生。
In a start event, following activiti-specific properties can be specified:
对于启动事件,下面列出了可以被赋值的activiti属性:
<startEvent id="request" activiti:form="org/activiti/examples/taskforms/request.form" />
<startEvent id="request" activiti:initiator="initiator" />The authenticated user must be set with the method IdentityService.setAuthenticatedUserId(String) in a try-finally block like this:
使用IdentityService.setAuthenticatedUserId(String)来设置验证用户信息时,必须使用try-finally包围,像下面一样:
try { identityService.setAuthenticatedUserId("bono"); runtimeService.startProcessInstanceByKey("someProcessKey"); } finally { identityService.setAuthenticatedUserId(null); }
This code is baked into the Activiti Explorer application. So it works in combination with Chapter 8, Task Forms
这段代码已经整合到Activiti Explorer应用中了。因此它可以和Chapter 8, Task Forms整合使用。
None start event
None start event
描述
A 'none' start event technically means that the trigger for starting the process instance is unspecified. This means that the engine cannot anticipate when the process instance must be started. The none start event is used when the process instance is started through the API by calling one of the startProcessInstanceByXXX methods.
None start event 从技术的角度上来讲就是表示触发流程启动的触发器没有被指定。也就是说流程引擎不能够预测到流程实例何时被启动。None start event一般是通过调用startProcessInstanceByXXX API函数来启动一个流程实例。
ProcessInstance processInstance = runtimeService.startProcessInstanceByXXX();Note: a subprocess (currently not yet implemented) always has a none start event.
注意:子流程(现在还没有支持)通常是含有一个none start event。
图形符号
A none start event is visualized as a circle with no inner icon (i.e. no trigger type).
None start event使用一个没有内部图标的圆来表示(也就是说没有指定触发器类型)。
XML representation
XML 表示
The XML representation of a none start event is the normal start event declaration, without any sub-element (other start event types all have a sub-element declaring the type).
None start evnet的XML表示就是普通的start event表示,没有子元素(其他start event都有一个子元素用来表示类型)。
<startEvent id="start" name="my start event" />
End events
结束事件
An end event signifies the end (of a path) of a (sub)process. An end event is always throwing. This means that when process execution arrives in the end event, a result is thrown. The type of result is depicted by the inner black icon of the event. In the XML representation, the type is given by the declaration of a sub-element.
一个结束事件通常意味着一个(子)流程结束,或者(子)流程的一个路径结束。结束事件就是一个throwing事件。也就是说当流程执行到一个结束事件时,一个result就会被抛出。result 的类型使用内部黑图标进行表示。在XML中则是通过子元素进行表示。
None end event
描述
A 'none' end event means that the result thrown when the event is reached is unspecified. As such, the engine will not do anything extra besides ending the current path of execution.
None end event意味着在流程结束时,抛出的result是没有被指定的。也就是说,流程引擎除了把当前执行流程结束掉之外不做任何其它事情。
图形符号
A none end event is visualized as a circle with a thick border with no inner icon (no result type).
None end event 使用一个厚边框的圆表示,圆内部没有图标(也就是说没有指定result类型)。
XML representation
XML 表示
The XML representation of a none end event is the normal end event declaration, without any sub-element (other end event types all have a sub-element declaring the type).
None end event的XML表示就是普通的end event的XML表示,没有子元素(其它end event则包含一个用来指示类型的子元素)。
<!--EndFragment--> family�a;�Z��n�font-family:Arial;color:black; mso-font-kerning:0pt'>的类型使用内部黑图标进行表示。在 XML 中则是通过子元素进行表示。
None end event
描述
A 'none' end event means that the result thrown when the event is reached is unspecified. As such, the engine will not do anything extra besides ending the current path of execution.
None end event意味着在流程结束时,抛出的result是没有被指定的。也就是说,流程引擎除了把当前执行流程结束掉之外不做任何其它事情。
图形符号
A none end event is visualized as a circle with a thick border with no inner icon (no result type).
None end event 使用一个厚边框的圆表示,圆内部没有图标(也就是说没有指定result类型)。
<endEvent id="end" name="my end event" />